Sto tentando di calcolare il meccanismo di impostazione e controllo del valore delle canarie.Saltare alla successiva "istruzione" utilizzando gdb
#include int main(void) { return printf("Hi!\n"); }
Quando smontare il principale, ottengo
(gdb) disas main 0x080483f4 : lea 0x4(%esp),%ecx 0x080483f8 : and $0xfffffff0,%esp 0x080483fb : pushl -0x4(%ecx) 0x080483fe : push %ebp 0x080483ff : mov %esp,%ebp 0x08048401 : push %ecx 0x08048402 : sub $0x14,%esp 0x08048405 : mov %gs:0x14,%eax 0x0804840b : mov %eax,-0x8(%ebp) 0x0804840e : xor %eax,%eax 0x08048410 : movl $0x8048500,(%esp) 0x08048417 : call 0x8048320 0x0804841c : mov -0x8(%ebp),%edx 0x0804841f : xor %gs:0x14,%edx 0x08048426 : je 0x804842d 0x08048428 : call 0x8048330 0x0804842d : add $0x14,%esp 0x08048430 : pop %ecx 0x08048431 : pop %ebp 0x08048432 : lea -0x4(%ecx),%esp 0x08048435 : ret
Ho impostato un punto di interruzione 0x0804840e utilizzando
b *0x0804840e
Dopo che il flusso del programma si ferma a questo punto di interruzione vorrei gdb
di andare a la successiva istruzione anziché la successiva riga del codice c. Non penso di poter usare next
per questo. Quindi quale altra opzione ho a parte dall'impostare un breakpoint ad ogni istruzione?
GDB ha abbastanza buona help' help' in linea ti porterà un elenco di argomenti, tra i quali è in esecuzione; 'help running' lists" stepi - Step one instruction esattamente ", e' help stepi' fornisce una descrizione più dettagliata. – Cascabel