- 1、本文档共84页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ARM7TDMI的指令系统和汇编语言 2.1 ARM处理器寻址方式 寻址方式是根据指令中给出的地址码字段来寻找真实操作数地址的方式。 ARM处理器支持的基本寻址方式有: 1.寄存器寻址 2.立即寻址 3.寄存器移位寻址 4.寄存器间接寻址 5.变址寻址 6.多寄存器寻址 7.堆栈寻址 8.块拷贝寻址 9.相对寻址 2.1 ARM处理器寻址方式 1.寄存器寻址 所需要的值在寄存器中; 指令中地址码给出的是寄存器编号,而寄存器中的内容为操作数。 例如: ADD R0,R1,R2 ;R0←R1+R2 这条指令将2个寄存器(R1和R2)的内容相加,结果放入第3个寄存器R0中。 必须注意写操作数的顺序,第1个是结果寄存器,然后是第一操作数寄存器,最后是第二操作数寄存器。 2.1 ARM处理器寻址方式 例如: MOV R1,R2 ;读取R2的值 SUB R0,R1,R2 ;将R1的值减去R2的 ;值,结果保存到R0 2.1 ARM处理器寻址方式 2.立即寻址 数据就包含在指令中,只要取出指令也就取出了可以立即使用的操作数。这样的数称为立即数。 例如: ADD R3,R3,#1 ;R3←R3 + 1 AND R8,R7,#0xff ;R8←R7[7 : 0] 以“#”为前缀表示一个立即数,十六进制值在“#”后加“0x”或“”表示。 第2条指令完成R7的32位值与0FFH相“与”,结果为将R7的低8位送到R8中,高24位清0。 2.1 ARM处理器寻址方式 例如 SUBS R0, R0,#1 R0减1,结果放入R0,并影响标志位 MOV R0, #0xFF000 将立即数0xFF000装入R0寄存器 2.1 ARM处理器寻址方式 3.寄存器移位寻址 ARM处理器特有的寻址方式。 第2个寄存器操作数在与第1个操作数结合之前,选择进行移位操作。 例如: ADD R3,R2,R1,LSL#3 寄存器R1的内容逻辑左移3位( × 8),再与寄存器R2内容相加,结果放入R3中。 2.1 ARM处理器寻址方式 例如 MOV R0,R2,LSL #3 R2的值左移3位,结果放入R0 ANDS R1,R1,R2,LSL R3 R2的值左移R3位,然后与R1相“与”,结果放入R1 LSL 逻辑左移(Logical Shift Left)。寄存器中字的低端空出的位补0。 LSR 逻辑右移(Logical Shift Right)。寄存器中字的高端空出的位补0。 ASR 算术右移(Arithmetic Shift Right)。算术移位的对象是带符号数,在移位过程中必须保持操作数的符号不变。若源操作数为正数,则字的高端空出的位补0。若源操作数为负数,则字的高端空出的位补1。 ROR 循环右移(Rotate Right)。从字的最低端移出的位填入字的高端空出的位。 RRX 扩展为1的循环右移(Rotate Right extended by 1 place)。操作数右移1位,空位用原C标志值填充。 2.1 ARM处理器寻址方式 4.寄存器间接寻址 指令中的地址码给出某一通用寄存器的编号。在被指定的寄存器中存放操作数的有效地址,而操作数则存放在存储单元中,即寄存器为地址指针。例如指令: LDR R0,[R1] ;R0←[R1] STR R0,[R1] ;R0→[R1] 寄存器间接寻址使用一个寄存器(基址寄存器)的值作为存储器的地址。 第1条指令将寄存器R1指向的地址单元的内容加载到寄存器R0中。 2.1 ARM处理器寻址方式 5.变址寻址 变址寻址就是将基址寄存器的内容与指令中给出的偏移量相加,形成操作数的有效地址。 举例: LDR R2, [R3, #0x0C] ;读取R3+0x0C地址上的存储单元的内容,放人R2 STR R1, [R0, #-4] ! ;先R0=R0-4,然后把R1的值保存到R0指定的存储单元 LDR R0, [R1], #4 ;读取R1地址上的存储单元的内容,放人R0,然后把R1=R1+4 LDR R1, [R0,R3,LSL#1] ;将R0+R3×2地址上的存储单元的内容读出,存入R1 2.1 ARM处理器寻址方式 6.多寄存器寻址 多寄存器寻址即是一次可传送几个寄存器值,允许一条指令传送16个寄存器的任何子集或所有寄存器。 举例: LDMIA R1, {R2-R7, R12} ;将R1指向的单元中的数据读出到R2~R7、R12中。 STMIA R0, {R2-R7, R12} ;将寄存器R2~R7、R12的值保存到R0指向的存储单元中。 2.1 ARM处理器寻址方式 6.多寄存器寻址
您可能关注的文档
最近下载
- 2025形势与政策-加快建设社会主义文化强国.pptx
- 人教版(2025)七年级下册Unit1Animal FriendsSection B How are animals part of our lives Section B 1a~2b课件+音频(共3.pptx VIP
- 110kv变电站继电保护毕业设计.doc VIP
- 公路隧道工程施工.pptx
- 电信行业运营商业务连续性保障方案.doc VIP
- 生态酒店设计分析.pptx
- GB∕T 702-2017 热轧钢棒尺寸、外形、重量及允许偏差(高清版).pdf
- 2025-2030年中国采血器产业运行动态分析及投资战略咨询报告.docx
- 江苏旅游资源的特征与分类及开发思考.pptx VIP
- 海南大学2022-2023学年《细胞生物学》期末考试试卷(B卷)附参考答案.docx
文档评论(0)