- 1、本文档共35页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第五章ARM体系结构(二编程模型)报告
嵌入式系统及应用 第五章 ARM体系结构(二)编程模型 ARM7TDMI ARM7TDMI指令流水线 为增加处理器指令流的速度,ARM7 系列使用3级流水线。 允许多个操作同时处理,而非顺序执行。 PC指向正被取指的指令,而非正在执行的指令。 ARM7TDMI指令流水线 Write Buffer:当数据写到Write Buffer后不需要CPU的任何干预而由Write Buffer控制逻辑自动的将数据写到最终的地方;Cache的回写则需要CPU的干预。Write Buffer较小,通常只有几十个字节。 Read Buffer:当读数据时Read Buffer自动多读取一些字节,但是不占用CPU的总线时间,所以能加快读数据的速度;当使用Cache时如果要从内存中读取数据则每个数据都会占用CPU的时间,这是与Read Buffer的最大不同点。Read Buffer较小,通常只有几十个字节。 ARM9TDMI Harvard架构 增加了可用的存储器宽度 指令存储器接口 数据存储器接口 可以实现对指令和数据存储器的同时访问 5 级流水线 实现了以下改进: 改进 CPI 到 ~1.5 提高了最大时钟频率 ARM9TDMI ARM微处理器:编程模型 数据类型 字节型数据(Byte):数据宽度为8bits 半字数据类型(HalfWord):数据宽度为16bits,存取式必须以2字节对齐的方式 字数据类型(Word):数据宽度为32bits,存取式必须以4字节对齐的方式 ARM微处理器:CPU模式(processor mode) CPU模式的转变: 软件控制 异常 外部中断 ARM微处理器:CPU模式 ARM微处理器:处理器工作状态(PROCESSOR OPERATING STATES) 处理器有两种工作状态: ARM:32位,执行字对准的ARM指令 Thumb:16位,执行半字对准的Thumb指令 ARM和Thumb之间状态的切换不影响处理器的模式或寄存器的内容 ARM微处理器:处理器工作状态 进入Thumb状态: 执行BX指令,并设置操作数寄存器的状态(位[0])为1。 在Thumb状态进入异常(IRQ, FIQ, UNDEF, ABORT,SWI etc.),当异常处理返回时自动转换到Thumb状态 进入ARM状态: 执行BX指令,并设置操作数寄存器的状态(位[0])为0。 进入异常时,将PC放入异常模式链接寄存器中,从异常向量地址开始执行也可进入ARM状态 ARM微处理器:处理器工作状态 Thumb-2?:增加了混合模式能力 定义了一个新的32-bit指令集能在传统的16-bit指令运行的Thumb状态下同时运行。 这样能在一个系统中更好地平衡ARM和Thumb代码的能力,使系统能更好地利用ARM级别的性能和Thumb代码的密度的优势 ARM微处理器:寄存器 ARM处理器有37个寄存器 31个通用寄存器:程序计数器、堆栈及其他通用寄存器 6个状态寄存器 这些寄存器不能同时看到 不同的处理器状态和工作模式确定哪些寄存器是对编程者是可见的 ARM微处理器: ARM State寄存器 ARM微处理器: Thumb State寄存器 ARM State 与Thumb State寄存器关系 ARM微处理器:通用寄存器 通用寄存器是R0-R15的寄存器,分为三类 没有对应影子寄存器的寄存器R0-R7 有对应影子寄存器的寄存器R8-R14 程序计数器R15 (或者PC) 影子寄存器是指该寄存器在不同的模式下对应的物理寄存器 ARM微处理器:通用寄存器 R0-R7 所有模式下,R0-R7所对应的物理寄存器都是相同的 这八个寄存器是真正意义上的通用寄存器,ARM体系结构中对它们没有作任何特殊的假设,它们的功能都是等同的。 在中断或者异常处理程序中一般都需要对这几个寄存器进行保存。 ARM微处理器:通用寄存器 R8-R14 访问的物理寄存器取决于当前的处理器模式,若要访问特定的物理寄存器而不依赖当前的处理器模式,则要使用规定的名字。 R8-R12各有两组物理寄存器:一组为FIQ模式,另一组是除FIQ以外的其他模式。 R13-R14各有6个分组的物理寄存器,一个用于用户模式和系统模式,其他5个分别用于5种异常模式。 R13(也被称为SP指针)被用作栈指针,通常在系统初始化时需要对所有模式下的SP指针赋值,当CPU在不同的模式时栈指针会被自动切换成相应模式下的值。 R14有两个用途,一是在调用子程序时用于保存调用返回地址,二是在发生异常时用于保存异常返回地址。 ARM微处理器:通用寄存器 R15 用作程序计数器(PC),可以被读写 ARM state: bits [1:0]为0,bits[31:2]即为 P
您可能关注的文档
- 第五次上机作业-word(2016年)报告.doc
- 第五单元第18讲遗传的染色体学说报告.ppt
- 第五版高分子化学学习课件报告.ppt
- 第五单元第16讲报告.ppt
- 第五次1107111051工作面供电设计后期最终版报告.doc
- 第五、六讲恋爱、婚姻、家庭报告.ppt
- 第五章 摩擦报告.ppt
- 第五章 钢的热处理报告.ppt
- 第五章 场效应管放大电路报告.ppt
- 第五章 热分析报告.ppt
- 生物制药行业生物制药行业技术创新与产业升级策略报告.docx
- 天然植物精油护肤品牌2025年产品创新趋势分析报告.docx
- 乡村绿色建筑技术产业政策优化与实施路径分析.docx
- 2025年金融衍生品市场风险管理策略与投资组合风险预警研究报告.docx
- 金融行业客户关系管理数字化转型关键路径及2025年实践指南报告.docx
- 乡村研学旅行基地研学课程设计与评估报告.docx
- 2025年跨境电商办公用品电商供应链跨境电商供应链金融风险管理报告.docx
- 乡村非遗手工艺品电商化运营与品牌形象塑造研究.docx
- 2025年餐饮供应链绿色物流配送模式报告.docx
- 2025年互联网金融平台合规性优化与可持续发展策略研究报告.docx
文档评论(0)