- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
嵌入式系统第三章概要1
本章重点;3.1 ARM处理器的寻址方式; 3.1.1 数据处理指令寻址方式; 3.1.1 数据处理指令寻址方式;3.1.1 数据处理指令寻址方式;3.1.1 数据处理指令寻址方式;先介绍 :#immediate——立即数
MOV R0,#0;R0=0规定这个立即数必须是一个8bit的常数通过循环右移偶数位得到。;在一条ARM指令中获得一个合法的立即数; 立即数寻址指令中的操作码字段后面的地址码部分即是操作数本身,也就是说,数据就包含在指令当中,取出指令也就取出了可以立即使用的操作数(这样的数称为立即数)。立即寻址指令举例如下:
SUBS R0,R0,#1 ;R0减1,结果放入R0,并且影响标志位
MOV R0,#0xFF ;将立即数0xFF装入R0寄存器
注意:立即数要以”#”号为前缀,表示十六进制数值以”0x”表示.; 操作数的值在寄存器中,指令中的地址码字段指出的是寄存器编号,指令执行时直接取出寄存器值来操作。寄存器寻址指令举例如下:
MOV R1,R2 ;将R2的值存入R1
SUB R0,R1,R2 ;将R1的值减去R2的值,结果保存到R0 ; 寄存器移位寻址是ARM指令集特有的寻址方式。当第2个操作数是寄存器移位方式时,第2个寄存器操作数在与第1个操作数结合之前,选择进行移位操作。寄存器移位寻址指令举例如下:
MOV R0,R2,LSL #3 ;R2的值左移3位,结果放入R0, ;即是R0=R2×8
ANDS R1,R1,R2,LSL R3 ;R2的值左移R3位,然后和R1相 ;“与”操作,结果放入R1;LSL逻辑左移操作
可完成对通用寄存器中的内容进行逻辑左移操作,按操作数所指定的数量向左移位,低位用零来填充。其中,操作数可以是通用寄存器,也可以是立即数。;LSR逻辑右移操作
可完成对通用寄存器中的内容进行右移操作,按操作数所指定的数量向右移位,左端用零来填充。其中,操作数可以是通用寄存器,也可以是立即数。;ASR算术右移操作
可完成对通用寄存器中的内容进行右移操作,按操作数所指定的数量向右移位,左端用第31位的值来填充。其中,操作数可以是通用寄存器,也可以是立即数。;ROR循环右移操作
可完成对通用寄存器中的内容进行循环右移操作,按操作数所指定的数量向右循环移位,左端用右端移出的位来填充。其中,操作数可以是通用寄存器,也可以是立即数。;RRX带扩展的循环右移操作
可完成对通用寄存器中的内容进行带扩展的循环右移操作,向右循环移1位,左端用进位标志位C来填充。;3.1.1 数据处理指令寻址方式;3.1.2 内存访问指令寻址方式;3.1.2 内存访问指令寻址方式;;Load指令用于从存储器(包括内存和外存)中读取数据放入寄存器中; Store指令用于将寄存器的数据保存到存储器。
各种类型的Load/Store指令的寻址方式由两部分组成:
1〉基址寄存器:一般使用通用寄存器
2〉地址偏移量:立即数、寄存器、寄存器及一个移位常数。
需要的地址=基址寄存器+地址偏移量
; 变址寻址就是将基址寄存器中的地址与指令中给出的偏移量相加/减,形成有效地址。变址寻址用于访问基址附近的存储单元,常用于查表、数组操作、功能部件寄存器访问等。;LDR 指令的语法格式如下:
LDR{cond}{B}{T} Rd,address_mode;T后缀,在特权模式下对存储器的访问,将被存储器看成是用户模式(即非特权)的访问。(destination目的地);偏移量方法
LDR R0,[R1,R2,LSL #2];R0←[R1+R2*4],R1不变
事先更新基址(前索引)(前变址)
LDR R0,[R1,R2,LSL #2]!
;R0←[R1+R2*4] ,更新R1为R1+R2*4
事后更新基址(后索引)(后变址)
LDR R0,[R1] ,R2,LSL #2;R0←[R1],更新R1为R1+R2*4;Pre or Post Indexed store寻址;3.1.2 内存访问指令寻址方式;批量Load/Store指令的寻址方式;批量Load/Store指令的寻址方式;;;3.1.2 内存访问指令寻址方式;所以可以组合出四种类型的堆栈方式:
满递增:堆栈向上增长,堆栈指针指向最高有效数据项。指令如LDMFA、STMFA等;
空递增:堆栈向上增长,堆栈指针指向堆栈上的第一个空位置。指令如LDMEA、STMEA等;
满递减:堆栈向下增长,堆栈指针指向最低有效数据项。指令如LDMFD、STMFD等;
空递减:堆栈向下
原创力文档


文档评论(0)