- 1、本文档共9页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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:
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
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、寄存器间接寻址
本质上,相当于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、栈的寻址
栈有四种寻址方式
对栈的操作:
STM --( 多个STR,一次可以完成多个数据的存储
LDM--( 多个LDR,一次可以完成多个数据的
文档评论(0)