【问题标题】:How to get the value of the base pointer, stack pointer and saved base pointer如何获取基指针、栈指针和保存的基指针的值
【发布时间】:2015-05-19 05:06:14
【问题描述】:

我知道如何使用 gdb 和使用过的信息框架,但我找不到基址、堆栈和保存的基址指针的值。我如何得到这些?我可以在给我的信息信息框中找到它们还是我必须做其他事情?

【问题讨论】:

  • 如果您想查看另一个帧中寄存器的值,请使用第 N 帧(或上/下)选择帧,然后执行 info reg,如 abligh 所述。

标签: c pointers gdb stack


【解决方案1】:

info reg 会告诉你寄存器的内容,包括堆栈指针(rsp 在 64 位 x86 上)和基指针(rbp 在 64 位 x86 上):

(gdb) info reg
rax            0x401340 4199232
rbx            0x0  0
rcx            0x0  0
rdx            0x7fffffffe608   140737488348680
rsi            0x7fffffffe5f8   140737488348664
rdi            0x0  0
rbp            0x0  0x0
rsp            0x7fffffffe508   0x7fffffffe508
r8             0x7ffff7dd4e80   140737351863936
r9             0x7ffff7dea560   140737351951712
r10            0x7fffffffe2d0   140737488347856
r11            0x7ffff7a50290   140737348174480
r12            0x4013e2 4199394
r13            0x7fffffffe5f0   140737488348656
r14            0x0  0
r15            0x0  0
rip            0x7ffff7a50290   0x7ffff7a50290 <__GI_exit>
eflags         0x202    [ IF ]
cs             0x33 51
ss             0x2b 43
ds             0x0  0
es             0x0  0
fs             0x0  0
gs             0x0  0

其余信息可通过info frame获得:

(gdb) info frame
Stack level 0, frame at 0x7fffffffe510:
 rip = 0x7ffff7a50290 in __GI_exit (exit.c:104); saved rip = 0x40134d
 called by frame at 0x7fffffffe520
 source language c.
 Arglist at 0x7fffffffe500, args: status=0
 Locals at 0x7fffffffe500, Previous frame's sp is 0x7fffffffe510
 Saved registers:
  rip at 0x7fffffffe508

【讨论】:

    猜你喜欢
    • 2012-05-03
    • 2011-12-09
    • 2021-09-17
    • 2010-12-23
    • 1970-01-01
    • 1970-01-01
    • 2010-11-26
    • 2011-05-03
    相关资源
    最近更新 更多