изменение значения точки наблюдения в кольце 0 приводит к странному поведению gdb - PullRequest
1 голос
/ 17 января 2012

src.c:

main()
{
   char c='x';
   read(0,&c,1);
   printf("go\n");
   printf("come\n");
}

gcc src.c -g, вы получите исполняемый файл a.out, затем GDB a.out

(gdb) b main
Breakpoint 1 at 0x80483e5: file gdb.c, line 3.
(gdb) r
Starting program: /tmp/tx

Breakpoint 1, main () at gdb.c:3
3       char c='x';
(gdb) set $foo=&c
(gdb) watch *$foo   //set a watchpoint for the address in which c reside
Hardware watchpoint 2: *$foo
(gdb) del 1
(gdb) c
Continuing.
Hardware watchpoint 2: *$foo

Old value = 0 '\0'
New value = 120 'x'
main () at gdb.c:4
4       read(0,&c,1);
(gdb) c
Continuing.       **//type carrige return**

Hardware watchpoint 2: *$foo

Old value = 120 'x'
New value = 10 '\n'
0x00ae3402 in __kernel_vsyscall ()
(gdb)
Continuing.

Program received signal SIGTRAP, Trace/breakpoint trap. **//from now on,gdb receive SIGTRAP repeatedly,why?**

0x009f23f3 in __read_nocancel () from /lib/libc.so.6
(gdb)
Continuing.

Program received signal SIGTRAP, Trace/breakpoint trap.
0x009f23f4 in __read_nocancel () from /lib/libc.so.6
(gdb)
Continuing.

Program received signal SIGTRAP, Trace/breakpoint trap.
0x009f23f9 in __read_nocancel () from /lib/libc.so.6
(gdb)

однако, если я изменю исходный код на:

main()
{
    char c='x';

    printf("go\n");
    c++;

    printf("come\n");
}

тогда все идет хорошо, без проводного поведения.

В 1-й программе значение точки наблюдения изменяется в режиме ядра, затем gdb получает SIGTRAP; во 2-й программе точка наблюдения изменяется в режиме пользователя, ничего не происходит. Может кто-нибудь сказать мне, почему? Огромное спасибо заранее.

...