ARM中的STM和LDM指令详解.pdfVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 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 !,

文档评论(0)

ligennv1314 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档