- 1、本文档共62页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第4节ARM体系结构与ARM指令简介
ARM的寄存器个数 ARM寄存器 R0(a1) R1(a2) R2(a3) R3(a4) R4(v1) R5(v2) R6(v3) R7(v4) R8(v5) R9(SB,v6) R10(SL,v7) R11(FP,v8) R12(IP) R13(SP) R14(LR) R15(PC) R16(CPSR) 桶形移位器 条件位的产生 ARM指令系统简介 ARM指令系统的重要性 ARM处理器指令的特点 1ARM指令系统的重要性 无操作系统下开发与学习(裸板) 裸机开发----启动代码 BOOTLOADER 基于操作系统下的开发与学习 BOOTLOADER移植 操作系统的移植 2ARM处理器指令的特点 指令的类别 RISC 指令长度 长度固定。 32位(ARM状态)OR16位(THUMB指令) 条件执行 上一条指令的运行结果可以作为下一条执行与否的条件 条件执行及标志位 ARM指令可以通过添加适当的条件码后缀来达到条件执行的目的。 这样可以提高代码密度,减少分支跳转指令数目,提高性能。 CMP r3,#0 CMP r3,#0 BEQ skip ADDNE r0,r1,r2 ADD r0,r1,r2 skip 默认情况下,数据处理指令不影响程序状态寄存器的条件码标志位,但可以选择通过添加“S”来影响标志位。 CMP不需要增加 “S”就可改变相应的标志位。 loop … SUBS r1,r1,#1 BNE loop 条件码标志 任何数据处理指令都可以设置条件码 (N, Z, V, and C) 适用于除比较操作外的所有数据处理指令 特殊的请求,必须在汇编语言中实现,这种请求是通过把”S”增加到选择代码中指定的 算术操作设置所有的标志位 (N, Z, C, and V) 逻辑和移位操作设置 N and Z 指令所包涵的主要内容 学习ARM指令与伪指令 伪指令的作用 ARM指令与伪指令的区别 熟悉指令集,可以读、写ARM汇编程序 简单的ARM程序 结束 如果 Z标志清零则跳转 R1减1,并设置标志位 ; 影响条件位C ADDS r2, r2, r0 ARM指令编码格式—数据处理指令 说明 Cond 指令执行的条件编码 Opcode 指令操作符编码 S 决定指令的操作是否影响CPSR的值 Rd 操作目标寄存器编码 Rn 包含第一操作数的寄存器编码 Shifter_operand 表示第二操作数 cond 001 opcode s Rn Rd Shifter_operand 31 28 27 25 24 21 20 19 16 15 12 11 8 7 0 从不执行(不要使用) 任何 NV 1111 无条件执行 (指令默认条件) 任何 AL 1110 有符号数小于或等于 Z=1,N!=V LE 1101 有符号数大于 Z=0,N=V GT 1100 有符号数小于 N!=V LT 1011 有符号数大于或等于 N=V GE 1010 无符号数小于或等于 C=0,Z=1 LS 1001 无符号数大于 C=1,Z=0 HI 1000 没有溢出 V=0 VC 0111 溢出 V=1 VS 0110 正数或零 N=0 PL 0101 负数 N=1 MI 0100 无符号数小于 C=0 CC/LO 0011 无符号数大于或等于 C=1 CS/HS 0010 不相等 Z=0 NE 0001 相等 Z=1 EQ 0000 含义 标志 条件助记符 操作码 指令条件码表 ;文件名:TEST1.S ;功能:实现两个寄存器相加 ;说明:使用ARMulate软件仿真调试 AREA Example1,CODE,READONLY ;声明代码段Example1 ENTRY ;标识程序入口 CODE32 ;声明32位ARM指令 START MOV R0,#0 ;设置参数 MOV R1,#10 LOOP BL ADD_SUB ;调用子程序ADD_SUB B LOOP ;跳转到LOOP ADD_SUB ADDS R0,R0,R1 ;R0 = R0 + R1 MOV PC,LR ;子程序返回 END ;文件结束 使用“;”进行注释 标号顶格写 实际代码段 声明文件结束 指令长度 指令集可以是以下任一种 32 bits
您可能关注的文档
- 第4章 ARM处理器编程模型与指令系统.ppt
- 第4章 ERP的生产控制系统1.ppt
- 第4章 中国对外贸易约束.ppt
- 第4章 企业物流与供应链配送仓储管理b.ppt
- 第4章 剩余与市场效率.ppt
- 第4章 门电路.ppt
- 第4章 存储程序控制原理(4.3).ppt
- 第4章 奇妙的有色和无色世界热辐射——光与物质的相互作用1:黑体辐射.ppt
- 第4章 建筑产品(4.4 建筑产品价格).ppt
- 第4章 操作风险管理.ppt
- 2024高考物理一轮复习规范演练7共点力的平衡含解析新人教版.doc
- 高中语文第5课苏轼词两首学案3新人教版必修4.doc
- 2024_2025学年高中英语课时分层作业9Unit3LifeinthefutureSectionⅢⅣ含解析新人教版必修5.doc
- 2024_2025学年新教材高中英语模块素养检测含解析译林版必修第一册.doc
- 2024_2025学年新教材高中英语单元综合检测5含解析外研版选择性必修第一册.doc
- 2024高考政治一轮复习第1单元生活与消费第三课多彩的消费练习含解析新人教版必修1.doc
- 2024_2025学年新教材高中英语WELCOMEUNITSectionⅡReadingandThi.doc
- 2024_2025学年高中历史专题九当今世界政治格局的多极化趋势测评含解析人民版必修1.docx
- 2024高考生物一轮复习第9单元生物与环境第29讲生态系统的结构和功能教案.docx
- 2024_2025学年新教材高中英语UNIT5LANGUAGESAROUNDTHEWORLDSect.doc
文档评论(0)