嵌入式系统原理及应用教程第2章精选.pptVIP

嵌入式系统原理及应用教程第2章精选.ppt

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
嵌入式系统原理及应用教程第2章精选

2.6.2 Thumb状态下的寄存器组织 在Thumb状态中访问高寄存器 在Thumb状态中,高寄存器(R8~R15)不是标准寄存器集的一部分。汇编语言程序员对它们的访问受到限制,但可以将它们用于快速暂存。 可以使用MOV、CMP和ADD指令对高寄存器操作。 * 2.6.2 Thumb状态下的寄存器组织 ARM状态和Thumb状态之间寄存器的关系 Thumb状态R0~R7与ARM状态R0~R7相同; Thumb状态CPSR和SPSR与ARM状态CPSR和SPSR相同; Thumb状态SP映射到ARM状态R13; Thumb状态LR映射到ARM状态R14; Thumb状态PC映射到ARM状态PC(R15)。 * Thumb状态寄存器在ARM状态寄存器上的映射 R1 R2 R3 R4 R5 R6 R7 R8 R9 R10 R11 R12 R0 堆栈指针 (R13) 连接寄存器 (R14) 程序计数器 (R15) 低寄存器 高寄存器 * 2.6.3 程序状态寄存器 程序状态寄存器—CPSR(1)+SPSR(5) CPSR反映了当前处理器的状态: 4个条件代码标志; 2个中断控制位; 5个对当前处理器模式进行编码的位; 1个指示当前执行指令的工作状态位; 保留位。 SPSR:备份程序状态字,保存异常事件发    生之前的CPSR.  每个异常模式带有一个备份程序状态寄存器,用于保存在异常事件发生之前的CPSR;CPSR和SPSR通过特殊指令进行访问。 * N Z C V — — I M0 M1 M2 M3 M4 T F — . . . 31 30 29 28 27 26 8 7 6 5 4 3 2 1 0 条件代码标志 保留 控制位 溢出标志 进位或借位扩展 零 负或小于 IRQ禁止 FIQ禁止 状态位 模式位 N Z C V I T F CPSR寄存器的格式   大多数“数值处理指令”可以选择是否影响条件代码标志位(指令带S后缀);但有些指令执行总是影响条件代码标志。 所有ARM指令都可按条件来执行,而Thumb指令中只有分支指令可按条件执行。   运算结果的最高位反映在该标志位。对于有符号二进制补码,结果为负数时N=1,结果为正数或零时N=0;   指令结果为0时Z=1(表示比较结果“相等”),否则Z=0;  当进行加法运算,并且最高位产生进位时C=1,否则C=0。  当进行减法运算,并且最高位产生借位时C=0,否则C=1。  对于移位操作指令,C为从最高位最后移出的值,其它指令C通常不变;  当进行加法/减法运算,并且发生有符号溢出时V=1,否则V=0,其它指令V通常不变。  保留位被保留将来使用。为了提高程序的可移植性,当改变CPSR标志和控制位时,请不要改变这些保留位。另外,请确保您程序的运行不受保留位的值影响,因为将来的处理器可能会将这些位设置为1或者0。 2.6.3 程序状态寄存器 * CPSR模式位设置表 M[4:0] 模式 M[4:0] 模式 10000 用户 10111 中止 10001 快中断 11011 未定义 10010 中断 11111 系统 10011 管理 注意:不是所有模式位的组合都定义了有效的处理器模式,如果使用了错误的设置,将引起一个无法恢复的错误。 * 2.7 异常(Exceptions) 当正常的程序执行流程发生暂时的停止时,称之为异常。 例如处理一个外部的中断请求。在处理异常之前,当前处理器的状态必须保留,这样当异常处理完成之后,当前程序可以继续执行。 处理器允许多个异常同时发生,它们将会按固定的优先级进行处理。 ARM体系结构中的异常,与8位/16位体系结构的中断有很大的相似之处,但异常与中断的概念并不完全等同。 * 2.7.1 ARM体系结构所支持的异常类型 异常类型 模式 正常地址 复位 管理 0未定义指令 未定义 0软件中断(SWI) 管理 0预取中止(取指令存储器中止) 中止 0x0000000C 数据中止(数据访问存储器中止) 中止 0IRQ(中断) IRQ 0FIQ(快速中断) FIQ 0x0000001C 2.7.2 异常优先级 * 异常类型 优先级 复位 1(最高优先级) 数据中止 2 FIQ 3 IRQ 4 预取中止 5 未定义指令 6 SWI 7(最低优先级) 优先级降低 2.7.2 异常优先

文档评论(0)

bodkd + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档