gpt4 book ai didi

c - 如何从 `push %ebp`获取汇编指令的相对偏移量

转载 作者:行者123 更新时间:2023-11-30 17:41:56 27 4
gpt4 key购买 nike

当我使用disas时在gdb 。我可能会得到这样的东西。

(gdb) disas bar
Dump of assembler code for function bar:
0x08048e84 <+0>: push %ebp
0x08048e85 <+1>: mov %esp,%ebp
0x08048e87 <+3>: sub $0x8,%esp
0x08048e8a <+6>: mov 0xc(%ebp),%eax
0x08048e8d <+9>: mov 0x8(%ebp),%edx
0x08048e90 <+12>: add %edx,%eax
0x08048e92 <+14>: mov %eax,-0x4(%ebp)
0x08048e95 <+17>: mov 0x81f4074,%eax
0x08048e9a <+22>: mov %eax,(%esp)
0x08048e9d <+25>: call 0x8048ed8 <traceback>
0x08048ea2 <+30>: mov -0x4(%ebp),%eax
0x08048ea5 <+33>: mov %eax,0x8(%ebp)
0x08048ea8 <+36>: leave
0x08048ea9 <+37>: ret
End of assembler dump.

假设我有0x08048ea2在我的C程序中。我怎样才能获得偏移量<+30>并得到0x08048e84

最佳答案

很难说清楚你到底在追求什么,但回溯函数通常会查看“堆栈帧”并从那里找到返回地址。然后,他们解析函数列表,查找每个返回地址的前一个函数。如果您在调试器中,那么也可能可以知道返回地址代表哪一行代码。

从这里我不确定问题是“如何评估堆栈帧”还是“如何找到“紧邻的前一个函数”。

堆栈帧的生成是特定于平台的,但通常使用特定的寄存器来保存地址,该地址是在函数入口处建立的堆栈上的固定位置。堆栈帧通常指向堆栈中前一个堆栈帧指针处(或旁边)的位置。这允许使用帧指针遍历堆栈并评估返回地址(通常位于相对于堆栈帧信息的固定位置。

请注意,编译器可以进行各种优化,这些优化会影响堆栈帧(具体有两种:禁用堆栈帧生成和返回值优化)。

确定函数地址也取决于平台。如果需要,编译器和链接器将创建和管理调试符号。这本质上嵌入了一个函数名称和起始地址的查找表,该查找表被加载到内存中供调试器访问。更好的系统还将提供在发布版本中查找符号名称的能力。他们通常通过让 IDE 提供函数基地址(映射文件)来实现此目的,然后找出代码段加载到内存中的位置。我怀疑此信息是由操作系统调用提供的,但也许还有其他机制。

关于c - 如何从 `push %ebp`获取汇编指令的相对偏移量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20921878/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com