ARM的汇编指令详解.docx

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
汇编知识点的要求: 1、能看的懂 2、可以做修改 3、不需要用汇编直接编写程序 汇编代码的应用场合: 1、 ARM 的启动代码必须要汇编,如: uboot 最开始初始化硬件的代码 2、内核在最开始初始化的位置。 。。。 一、 ARM 汇编指令的编码格式 1、编码格式 ARM 汇编指令编译成机器码以后, 机器码的长度是 32bits ,这 32bits 的编码有一个固定的格式。 不同 ARM 汇编指令,编码格式不同。 2、举例 C: if ( a==10) a++; else a--; 1 汇编 1: CMP R0, #10; ADDEQ R0 , R0, #1 SUBNE R0 , R0 , #1 汇编 2 SUBS R1, R0, #10; //S --- 运算的结果会影响条件码标志位: CPSR: NZCV ADDEQ R0 , R0, #1 SUBNE R0 , R0 , #1 提示: 空指令 NOP ,实际上是占用 CPU 的时间,但是执行后,没有什么意义。 NOP ---- MOV R0 , R0 3、条件码标识 10 -10 Z = 1 C = 0 N = 0 V = 0 ================================================================================= 二、 ARM 的寻址方式 1、立即数寻址 操作数,有立即数。 ADD R0 , R0, #1 2 MOV R1 , #10 ORR R1 , R1, #0xf @ R1=R1 | 0xf BIC R1 , R1, #0xf @R1 = R1(~(0xf)) 错误: ADD R1 , #1,#2 注意:立即数合法的条件 在 ARM 汇编指令中,并不是所有的立即数,立即数是有一定的限制的。什么样的立即数是合法的??? 1、如果一个立即数是小于 256 的(即该立即数是 8bits 以内的, 0~255),该立即数是合法的。 2、如果一个立即数是大于等于 256,该立即数经过循环左移 偶数 位,可以得到一个小于 256 的数,则该立 即数合法。 256 = 0x100 ------ 左移 20 位 0--- 左移 4 0x1 合法 0x111 非法 0x102 非法 0x104 合法 0xfff 0xff00 0x12000 0x450000 0xab 原因: 在数据处理指令编码的时候,立即数用 12bits 来表示: 高 4bits:循环左移左移偶数位除以 2 低 8bits:循环左移后的结果。 重要问题: ADD R1 , R0, #0xffff 非法 解决: LDR R2 , =0xffff // R2=0xffff ,将立即数 0xffff 的值传送给 R2 ADD R1, R0, R2 2、寄存器寻址 所有的操作数都是寄存器,没有立即数 ADD R0 , R0, R1 MOV R1 , R0 ORR R1 , R1, R0 @ R1=R1 | 0xf BIC R1 , R1, R0 @R1 = R1(~(0xf)) 3 3、寄存器间接寻址 本质上,相当于 C 语言的指针 问题:读取 0地址下的内容,该内容是 int 型的??? C: int a ; a = *(int *)0汇编: LDR R0 , =0LDR R1 , [R0] //LDR = loader, 数据加载指令,加载一个地址下的内容 STR R2 , [R1] //STR---store ,数据存储指令,将一个数据存放到一个地址下。 错误的写法: LDR R1, [0 注意:间接寻址的地址需要存放到一个通用寄存器中,然后在使用。 4、寄存器的偏移寻址 MOV R0, R2,LSL #3 //LSL — 逻辑左移。 R0 = R23 ADD R0,R1,R2,LSL #4 //R0 = R1 + (R24) SUB R0, R1, R2,LSL R3 //R0= R1- (R2R3) 5、基址变址寻址 是一个间接寻址的变形,地址是由基地址和偏移量组成的 1)先变址 LDR R0, [R1, #4] // 将 R1+4 作为新地址,将新的地址下的内容加载给 R0 2)后变址 LDR R0, [R1] , #4 //先将 R1 地址下的内容加载给 R0,然后 R1=R1+4 3)自动变址 LDR R0, [R1, #4]! //!--- 》自动变址, 将 R1+4 作为新地址, 将新的地址下的内容加载给 R0;然后 R1=R1+4 6、栈的寻址 栈有四种寻址方式 4 对栈的操作: STM --

文档评论(0)

137****7230 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档