MASM汇编器指令——.SETFRAME

目录

1. 基本功能

2. 语法格式

3.  使用说明

4.  示例


.SETFRAME 汇编器指令

1. 基本功能

使用具体的寄存器(reg)和偏移(offset)来填充解开信息(unwind information)(即异常处理的机制的相关信息)的寄存器域和偏移域。偏移的大小必须是16的倍数且小于等于240。这个汇编器指令(注意,不是汇编指令)也会为使用当前序言偏移(prologue offset)的具体寄存器产生一个UWOP_SET_FPREG解开数据入口代码。

2. 语法格式

.SETFRAME reg, offset

3.  使用说明

.SETFRAME允许ml64.exe用户指定一个桢函数如何解开(即,当发生异常时,如何从异常环境中还原相应的栈结构并继续向下正常执行其它任务),并且仅允许在序言(prologue)中使用,prologue从桢的声明开始延伸到.ENDPROLOG指令截止。这些汇编器指令不会产生代码;它们仅仅生成.xdata和.pdata。因此,.SETFRAME前面应该前置实际完成解开动作的汇编指令。好的实践方法是将解开指令和它们实际所指的解开代码封包到一个宏中以确保一致性。

4.  示例

; ml64 frmex2.asm /link /entry:frmex2 /SUBSYSTEM:CONSOLE

_text SEGMENT

frmex2 PROC FRAME

   push rbp

.pushreg rbp

   sub rsp, 010h

.allocstack 010h

   mov rbp, rsp

.setframe rbp, 0

.endprolog

   ; modify the stack pointer outside of the prologue (similar to alloca)

   sub rsp, 060h

   ; we can unwind from the following AV because of the frame pointer

   mov rax, 0

   mov rax, [rax] ; AV!

   add rsp, 060h

   add rsp, 010h

   pop rbp

   ret

frmex2 ENDP

_text ENDS

END

示例说明:

mov rbp, rsp 将当前栈指针存入rbp基指针;.setframe rbp, 0 表明当前栈指针与基地址指针的地址差值为0字节。再比如,有如下两句(STK_LOCAL2为常量):

lea rbp,[rsp+STK_LOCAL2] ;set frame pointer

.setframe rbp,STK_LOCAL2

以上语句表明,当前栈与基址指针之见的位移为STK_LOCAL2个字节。

特别注意:在X64模式下,汇编语言函数可以使用任意非易失性(non-volatile)寄存器作为栈基地址指针,使用RBP寄存器作为基地址指针是为了保持X86_64和遗留X86汇编语言代码之间的一致性。

参考资料:

MASM官方文档:.SETFRAME | Microsoft DocsLearn more about: .SETFRAME

icon-default.png?t=M7J4

https://docs.microsoft.com/en-us/cpp/assembler/masm/dot-setframe?view=msvc-170

 汇编语言教材:<<Modern X86 Assembly Language Programming>> 2nd Edition,Daniel Kusswurm

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


学习编程是顺着互联网的发展潮流,是一件好事。新手如何学习编程?其实不难,不过在学习编程之前你得先了解你的目的是什么?这个很重要,因为目的决定你的发展方向、决定你的发展速度。
IT行业是什么工作做什么?IT行业的工作有:产品策划类、页面设计类、前端与移动、开发与测试、营销推广类、数据运营类、运营维护类、游戏相关类等,根据不同的分类下面有细分了不同的岗位。
女生学Java好就业吗?女生适合学Java编程吗?目前有不少女生学习Java开发,但要结合自身的情况,先了解自己适不适合去学习Java,不要盲目的选择不适合自己的Java培训班进行学习。只要肯下功夫钻研,多看、多想、多练
Can’t connect to local MySQL server through socket \'/var/lib/mysql/mysql.sock问题 1.进入mysql路径
oracle基本命令 一、登录操作 1.管理员登录 # 管理员登录 sqlplus / as sysdba 2.普通用户登录
一、背景 因为项目中需要通北京网络,所以需要连vpn,但是服务器有时候会断掉,所以写个shell脚本每五分钟去判断是否连接,于是就有下面的shell脚本。
BETWEEN 操作符选取介于两个值之间的数据范围内的值。这些值可以是数值、文本或者日期。
假如你已经使用过苹果开发者中心上架app,你肯定知道在苹果开发者中心的web界面,无法直接提交ipa文件,而是需要使用第三方工具,将ipa文件上传到构建版本,开...
下面的 SQL 语句指定了两个别名,一个是 name 列的别名,一个是 country 列的别名。**提示:**如果列名称包含空格,要求使用双引号或方括号:
在使用H5混合开发的app打包后,需要将ipa文件上传到appstore进行发布,就需要去苹果开发者中心进行发布。​
+----+--------------+---------------------------+-------+---------+
数组的声明并不是声明一个个单独的变量,比如 number0、number1、...、number99,而是声明一个数组变量,比如 numbers,然后使用 nu...
第一步:到appuploader官网下载辅助工具和iCloud驱动,使用前面创建的AppID登录。
如需删除表中的列,请使用下面的语法(请注意,某些数据库系统不允许这种在数据库表中删除列的方式):
前不久在制作win11pe,制作了一版,1.26GB,太大了,不满意,想再裁剪下,发现这次dism mount正常,commit或discard巨慢,以前都很快...
赛门铁克各个版本概览:https://knowledge.broadcom.com/external/article?legacyId=tech163829
实测Python 3.6.6用pip 21.3.1,再高就报错了,Python 3.10.7用pip 22.3.1是可以的
Broadcom Corporation (博通公司,股票代号AVGO)是全球领先的有线和无线通信半导体公司。其产品实现向家庭、 办公室和移动环境以及在这些环境...
发现个问题,server2016上安装了c4d这些版本,低版本的正常显示窗格,但红色圈出的高版本c4d打开后不显示窗格,
TAT:https://cloud.tencent.com/document/product/1340