Si vous préférez laisser /proc/sys/kernel/yama/ptrace_scope
fixé à sa valeur par défaut de 1
alors, comme solution de contournement, vous pouvez envisager d'utiliser l'option gdb
pour exécuter le programme que vous voulez déboguer. Vous pouvez alors faire apparaître le débogueur en appuyant simplement sur ^C
. Par exemple, pour déboguer vers le programme (ennuyeux) sleep 60
faites ce qui suit :
$ gdb -q sleep -ex 'run 60'
Voici un exemple complet.
$ gdb -q sleep -ex 'run 60'
Reading symbols from sleep...(no debugging symbols found)...done.
Starting program: /bin/sleep 60
^C
Program received signal SIGINT, Interrupt.
0x00007ffff7ad5d60 in __nanosleep_nocancel () at ../sysdeps/unix/syscall-template.S:81
81 ../sysdeps/unix/syscall-template.S: No such file or directory.
(gdb) backtrace
#0 0x00007ffff7ad5d60 in __nanosleep_nocancel () at ../sysdeps/unix/syscall-template.S:81
#1 0x0000000000403cd7 in ?? ()
#2 0x0000000000403b88 in ?? ()
#3 0x00000000004016c9 in ?? ()
#4 0x00007ffff7a35ec5 in __libc_start_main (main=0x401540, argc=2, argv=0x7fffffffea08, init=<optimized out>,
fini=<optimized out>, rtld_fini=<optimized out>, stack_end=0x7fffffffe9f8) at libc-start.c:287
#5 0x00000000004017d5 in ?? ()
(gdb) continue
Continuing.
[Inferior 1 (process 3531) exited normally]
(gdb) quit
Desde /bin/sleep
a été (sans surprise) compilé sans informations de débogage, le backtrace ci-dessus contient des informations minimales.