在汇编代码中读取访问冲突

时间:2011-01-05 15:56:06

标签: assembly inline-assembly

这是我在VC ++项目中插入的一个简单的asm代码。 return_addr是堆栈帧的返回地址。我有一个StackWalk函数(我不是由codeproject.com/KB/threads/StackWalker.aspx编写的),它使用StackWalk64()来提取帧。详细信息无关紧要。使用返回地址,我从当前正在检查的堆栈中的函数代码中提取单个字节。

__asm{
       push eax
       push ecx

       mov eax, return_addr

       mov cl, BYTE PTR [eax - 5]  //Problem Statement
       mov ret_5, cl  

       pop ecx
       pop eax
}

我运行我的代码以及其他应用程序,如gtalk,vlc等。当我包含问题陈述时,应用程序总是崩溃。当我删除这些语句时,一切正常。我运行了一个调试器,它在问题陈述中断开,显示访问冲突读取位置0xzzzzzz错误。我想应用程序正在尝试读取某些受限制的dll或代码段的代码,并引发错误。我使用了try catch块,但这没有帮助。关于我能做什么的任何建议?

1 个答案:

答案 0 :(得分:0)

很明显,无论return_addr值是什么,它都不会指向有效的内存位置,因为否则不会发生访问冲突。因此,细节非常相关。