- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ARM中的STM和LDM指令详解
ARM 中的 STM 和 LDM 指令详解
STM 和 LDM 的主要用途是现场保护、数据复制、参数传递等,其模式有 8 种,如下:
注:前面 4 种用于数据块的传输,后面 4 种用于堆栈操作
(1 )IA 每次传送后地址加 4
(2 )IB 每次传送前地址加 4
(3 )DA 每次传送后地址减 4
(4 )DB 每次传送前地址减 4
(5 )FD 满递减堆栈
(6 )FA 满递增堆栈
(7 )ED 空递减堆栈
(8 )EA 空递增堆栈
下面的讲述对于空递减堆栈和空递增堆栈同样适用 .
在堆栈操作时,经常错误以为使用 STMFD 满递减将寄存器压入堆栈后,在弹出数据的时候
应该使用 LDMFA 。
但是 FD 和 FA 仅用于只是目前操作的堆栈是何种模式 (堆栈共有四种模式 ) ,FD 指明目前的堆栈
是满递减堆栈,
则数据入栈时的指令为 STMFD ,那么数据出栈时的指令对应的为 LDMFD ,而不是 LDMFA 。
我们可以这样认为 STMFD 等价于 STMDB ,LDMFD 等价于 STMIA
那么,数据传输的顺序和数据入栈的顺序又是如何呢
先来看 STMFD SP!,{R1-R3} 执行的结果图(操作之后 SP 指向 SP )
SP
|R3|
|R2|
SP |R1|
那么 STMFD SP!,{R3 ,R2 ,R1} 执行后的堆栈顺序是不是刚好和上面的堆栈顺序相反,实际情
况时这两个指令执行后的堆栈数据顺序一样, 因为 ARM 编译器会自动将 STMFD SP!,{R3 ,R2 ,
R1} 转换为 STMFD SP!,{R0-R3} 指令,也就是说, ARM 编译器默认高寄存器优先存入堆栈。即
便你在指令 STMFD SP!,{R3 ,R2 , R1} 中刻意“安排”了寄存器入栈顺序,而在编译时编译器
又重新做了处理,打乱了你期望的数据入栈顺序。
同理 STMDB R0!,{R1-R3} 和 STMDB R0!,{R3 ,R2 ,R1} 指令执行后数据在堆栈中的顺序完
全一致。
STMFD SP!,{R1-R3} 指令对应的出栈指令是 LDMFD SP!,{R1-R3} (R1,R2,R3 的顺序任意)
STMFD 指令
STMFD Rn{!},{reglist}{^}
STMFD SP !,{R0-R7 ,LR}
对于这条指令伪代码的解释,个人理解如下:
sp = address;
sp = sp - 4;
Memory[address] = LR;
for( i=7;i0;i--)
{
sp = sp-4;
Memory[address] = Ri;
}
由于 ARM 堆栈结构是从高向低压栈的,此时 SP 即是栈顶。
这里的 sp = sp-4 ,是因为处理器是 32 位的 ARM ,所以每次压一次栈 SP 就会
移动 4 个字节( 32 位)。
假设此时 SP 地址为 : 0 由前面解释伪代码可得下图( 蓝色填充区为
地址):
蓝色标注的 SP 为执行指令前的 SP 地址,红色标注的 SP 是执行指令后的 SP
地址,由此看出 STMFD 指令 是向下压栈的。
LDMFD 指令
LDMFD Rn{!},{reglist}{^}
这条指令的意思是以 Rn 为基址(起始地址),取值写入寄存器列表。
LDMFD SP !,
您可能关注的文档
- (2016北师大版)六年级上册数学比赛场次和看图找关系.pdf
- (2×2)DLP大屏幕拼接解决方案模板.pdf
- (一)倡导勤俭节约践行中华美德——《中山市东升镇小学生消费心理现状调查与纠正》实践调查活动报告.pdf
- (B级)答案精解2004年12月.pdf
- (三追两检一挂牌)交通安全重点隐患单位挂牌整治实施意见.pdf
- (中考十年)江苏省常州市2007—2016年中考世现史试题汇编.pdf
- (一)径赛前的编排工作.pdf
- (人教版)高中历史必修三:第22课《文学的繁荣》优化训练及答案.pdf
- (人民版)必修3历史:专题3《近代中国思想解放的潮流》检测卷(含答案).pdf
- (人民版)必修三历史【专题3】近代中国思想解放的潮流》检测卷及答案.pdf
文档评论(0)