从Microsoft C读取RSP寄存器

由于在编译x64体系结构时,Microsoft C中没有内联汇编程序,因此我无法弄清楚如何访问RSP寄存器(堆栈指针).我知道我可以使用RtlCaptureContext读取它,但这也会执行许多不需要的操作.它也会慢几千倍(为了我的目的,不能接受).如果我写一个单独的ASM函数,RSP显然会改变,所以这也不是一个替代方案.

那么如何使用Microsoft C读取x64 RSP寄存器的内容呢?

您可以使用_AddressOfReturnAddress()(参见 MSDN reference)内在函数间接获取它.
显然,您无法确定当前堆栈帧停止的位置,但您可以使用您拥有的任何堆栈变量并通过查看生成的程序集来猜测它.

结合Olipro的建议:在独立函数中使用_AddressOfReturnAddress(),获得堆栈地址变得非常容易.更不用说用C语言编写的函数很可能只包含对此内在函数调用.

相关文章

(1)when you ping a computer from itsafe,the ping command should return the local IP address. (...
1、点击win菜单,点击设置图标 2、选择系统选项 3、选择应用与程序选项 4、拉到最下方,选择程序与功能...
目前一直直接往Windows 2008 R2 Server中复制文件(暂时还没有搭建ftp服务),突然不能复制了,于是百度...
windows下使用vscode配合xebug调试php脚本 要下载有php_xebug.dll扩展的版本,最新版可能没有这个扩展,p...
在控制面板的程序与功能里启用和关闭windows功能打开,适用于linux的windows子系统
效果演示 推荐一个非常牛的文档网站生成器:docsify 我通过这个工具,成功将码云上的个人学习笔记发布到...