Mar*_* Ba 30 debugging x86 stack cpu-registers visual-c++
是的,我确信这已被多次隐含地回答,但我似乎无法完全理解它.
如果你有一个(x86)堆栈跟踪(比如,在WinDbg中查看它),并且你看一下寄存器,那么EBP和ESP值相隔x个字节意味着什么?
链接:
举一个最近的堆栈跟踪示例,我有:
0:016> k
ChildEBP RetAddr
1ac5ee8c 76b831bb ntdll!NtDelayExecution+0x15
1ac5eef4 76b83a8b KERNELBASE!SleepEx+0x65
1ac5ef04 0060e848 KERNELBASE!Sleep+0xf
1ac5ef10 76859d77 MyApp!application_crash::CommonUnhandledExceptionFilter+0x48 [...\applicationcrash.inc.cpp @ 47]
1ac5ef98 775a0df7 kernel32!UnhandledExceptionFilter+0x127
1ac5efa0 775a0cd4 ntdll!__RtlUserThreadStart+0x62
1ac5efb4 775a0b71 ntdll!_EH4_CallFilterFunc+0x12
1ac5efdc 77576ac9 ntdll!_except_handler4+0x8e
1ac5f000 77576a9b ntdll!ExecuteHandler2+0x26
1ac5f0b0 7754010f ntdll!ExecuteHandler+0x24
1ac5f0b0 6e8858bb ntdll!KiUserExceptionDispatcher+0xf
1ac5f400 74e68ed7 mfc80u!ATL::CSimpleStringT<wchar_t,1>::GetString [f:\dd\vctools\vc7libs\ship\atlmfc\include\atlsimpstr.h @ 548]
1ac5fec0 6e8c818e msvcr80!_NLG_Return [F:\dd\vctools\crt_bld\SELF_X86\crt\prebuild\eh\i386\lowhelpr.asm @ 73]
1ac5ff48 74e429bb mfc80u!_AfxThreadEntry+0xf2 [f:\dd\vctools\vc7libs\ship\atlmfc\src\mfc\thrdcore.cpp @ 109]
1ac5ff80 74e42a47 msvcr80!_callthreadstartex+0x1b [f:\dd\vctools\crt_bld\self_x86\crt\src\threadex.c @ 348]
1ac5ff88 76833677 msvcr80!_threadstartex+0x66 [f:\dd\vctools\crt_bld\self_x86\crt\src\threadex.c @ 326]
1ac5ff94 77569f02 kernel32!BaseThreadInitThunk+0xe
1ac5ffd4 77569ed5 ntdll!__RtlUserThreadStart+0x70
1ac5ffec 00000000 ntdll!_RtlUserThreadStart+0x1b
0:016> r
eax=00000000 ebx=1ac5efc8 ecx=19850614 edx=00000000 esi=1ac5eed0 edi=00000000
eip=7754fd21 esp=1ac5ee8c ebp=1ac5eef4 iopl=0 nv up ei pl nz na pe nc
cs=0023 ss=002b ds=002b es=002b fs=0053 gs=002b efl=00010206
Run Code Online (Sandbox Code Playgroud)
ESP的值1ac5ee8c- EBP 1ac5eef4= 104字节的差异.那里有什么?
小智 76
ESP是当前的堆栈指针.EBP是当前堆栈帧的基指针.
调用函数时,通常会在堆栈上为局部变量保留空间.这个空间通常通过EBP引用(在函数调用期间,所有局部变量和函数参数都是该寄存器的已知常量偏移量.)另一方面,ESP在函数调用期间会随着其他函数的调用而改变,或者作为临时堆栈空间用于部分操作结果.
请注意,目前大多数编译器都可以选择通过ESP引用所有局部变量.这释放了EBP以用作通用寄存器.
通常,当您查看函数顶部的反汇编代码时,您会看到如下所示的内容:
push EBP
mov EBP, ESP
sub ESP, <some_number>
Run Code Online (Sandbox Code Playgroud)
因此,EBP将指向此帧的堆栈顶部,ESP将指向堆栈上的下一个可用字节.(堆栈通常 - 但不必 - 在内存中长大.)
| 归档时间: |
|
| 查看次数: |
68189 次 |
| 最近记录: |