Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to print -0x4(%rbp) in gdb?

In the disassembly there's such code:

movl   $0x6,-0x4(%rbp)

I try to print the value this way but fails:

(gdb) p  0x4(%esp)
A syntax error in expression, near `%esp)'.
(gdb) p 0x4+$esp
Argument to arithmetic operation not a number or boolean.

How to print it correctly?

like image 556
compiler Avatar asked Mar 28 '11 07:03

compiler


1 Answers

It looks like you're working with 64 bit code, in which case you just need, e.g.:

(gdb) p $rbp-0x4
$1 = (void *) 0x7fff5fbff71c

If you want to see what's actually at this address, then you need to cast the void * address, e.g.

(gdb) p /x *(int *)($rbp-0x4)
$2 = 0x7fff

or, more succinctly, use x instead of p, e.g.

(gdb) x /w $rbp-0x4
0x7fff5fbff71c: 0x00007fff
like image 88
Paul R Avatar answered Sep 22 '22 15:09

Paul R