第三章 ARM体系结构及编程模型 提纲 ARM技术的应用领域及特点 ARM微处理器系列 ARM处理器的工作状态

Slides:



Advertisements
Similar presentations
第2章ARM/THUMB微处理器结构及指令系统
Advertisements

第二部分 嵌入式硬件系统 第2章 嵌入式处理器 第3章 ARM内核与ARM处理器 第4章 嵌入式系统的外围设备.
2017年3月5日 单片机原理与应用 背景知识调查.
第3章 体系结构与指令系统 本章将对ARM技术进行全面论述,通过本章的学习,使大家对ARM技术有个全面的了解和掌握。了解ARM体系结构、编程模式、异常、片上总线等内容;掌握ARM指令集及其寻址模式。
NEUSOFT Institute of information Technology .ChengDu
第二章 嵌入式处理器.
嵌入式体系结构与应用 第二章-ARM处理器.
实验四 利用中规模芯片设计时序电路(二).
第3章 基于ARM的处理器体系结构1 主讲 马洪连.
第2章ARM/THUMB微处理器结构及指令系统
微机原理与接口技术 第二章 ARM微处理器硬件结构
第3章 基于ARM的处理器体系结构1 主讲 丁男.
基于解释性语言的手机跨平台架构 Sloan Yi. Qt MTK.
Oracle数据库 Oracle 子程序.
ARM 架构.
Kvm异步缺页中断 浙江大学计算机体系结构实验室 徐浩.
ARM的体系结构与编程.
考核方式和评分标准 考核方式 平时作业和表现(占10%)+实验(占20%)+笔试(70%,闭卷考试 )
嵌入式系统课程简介 宋健建 南京大学软件学院 2004/02/10.
异 常 处 理.
存储系统.
嵌入式系統概論-以S3C2440核心為架構 第1章 嵌入式系統概念.
微机原理与接口技术 ——80x86微处理器 西安邮电大学 计算机学院 范琳.
第四章 Thumb 指令集 4.1 Thumb 指令集概述 4.2 Thumb 指令详细介绍.
第一单元 初识C程序与C程序开发平台搭建 ---观其大略
数 控 技 术 华中科技大学机械科学与工程学院.
Windows网络操作系统管理 ——Windows Server 2008 R2.
2004全国高校ARM嵌入式教学及科研师资高级 培训班讲稿 - 基于ARM和uClinux的开发
第2章 ARM微处理器硬件结构 计算机体系结构分类 ARM版本及系列 ARM处理器结构 存储系统机制.
第3章 ARM寻址方式与指令系统 ARM编程模型 ARM指令格式和寻址方式 ARM指令集 Thumb指令集.
逆向工程-汇编语言
CPU结构和功能.
(第2版).
用event class 从input的root文件中,由DmpDataBuffer::ReadObject读取数据的问题
宁波市高校慕课联盟课程 与 进行交互 Linux 系统管理.
宁波市高校慕课联盟课程 与 进行交互 Linux 系统管理.
厂商—型号 荣耀-HiRouter-H1 外观设计 产品类型:无线路由器 建议零售价格:149元 上市时间:2017 年 5月
ARM 架构.
ARM 架构.
C语言程序设计 主讲教师:陆幼利.
第四章 MCS-51定时器/计数器 一、定时器结构 1.定时器结构框图
第2章ARM/THUMB微处理器结构及指令系统
ARM指令集 Author : Steve Furber Advisor: Mei-Ling Chiang Speaker: 徐翔宇
嵌入式系统教案 武汉创维特信息技术有限公司 2019/4/29.
姚金宇 MIT SCHEME 使用说明 姚金宇
实验七 安全FTP服务器实验 2019/4/28.
<编程达人入门课程> 本节内容 内存的使用 视频提供:昆山爱达人信息技术有限公司 官网地址: 联系QQ: QQ交流群: ,
ARM處理器.
iSIGHT 基本培训 使用 Excel的栅栏问题
实验二 带进位控制8位算术逻辑运算实验 带进位控制8位算术逻辑运算: ① 带进位运算 ② 保存运算后产生进位
§6.7 子空间的直和 一、直和的定义 二、直和的判定 三、多个子空间的直和.
College of Computer Science & Technology
ARM简介及BootLoader介绍 黄大荣
HSC高速输出例程 HORNER APG.
微机原理与接口技术 ——8086微处理器 西安邮电大学 计算机学院 范琳.
临界区问题的硬件指令解决方案 (Synchronization Hardware)
本节内容 C语言的汇编表示 视频提供:昆山爱达人信息技术有限公司 官网地址: 联系QQ: QQ交流群 : 联系电话:
3. 逻辑运算指令 A、简单逻辑操作指令 CLR A. (不影响CY、AC、 OV标志) CPL A
微處理機 Microprocessor (100上) ARM 內核嵌入式SOC原理
本节内容 Windows线程切换_时钟中断切换 视频提供:昆山滴水信息技术有限公司 官网地址: 论坛地址: QQ交流 :
第一章 嵌入式控制系统简介.
第3章 目录 1.简介 2.ARM7TDMI 3.ARM7TDMI的模块和内部框图 4.体系结构直接支持的数据类型 5.处理器状态
基于列存储的RDF数据管理 朱敏
C++语言程序设计 C++语言程序设计 第一章 C++语言概述 第十一组 C++语言程序设计.
第3章 ARM7体系结构.
FVX1100介绍 法视特(上海)图像科技有限公司 施 俊.
上节复习(11.7) 1、定时/计数器的基本原理? 2、定时/计数器的结构组成? 3、定时/计数器的控制关系?
入侵检测技术 大连理工大学软件学院 毕玲.
DSP技术与应用 电子与信息技术系.
一个实时嵌入式操作系统移植问题研究 报告人:荣峰华.
Presentation transcript:

第三章 ARM体系结构及编程模型 提纲 1 2 3 4 5 6 7 ARM技术的应用领域及特点 ARM微处理器系列 ARM处理器的工作状态

ARM-Advanced RISC Machines 1991年ARM公司成立于英国剑桥,主要出售芯片设计技术的授权。目前,采用ARM技术知识产权(IP)核的微处理器,即我们通常所说的ARM微处理器,已遍及工业控制、消费类电子产品、通信系统、网络系统、无线系统等各类产品市场,基于ARM技术的微处理器应用约占据了32位RISC微处理器75%以上的市场份额,ARM技术正在逐步渗入到我们生活的各个方面。 ARM公司是专门从事基于RISC技术芯片设计开发的公司,作为知识产权供应商,本身不直接从事芯片生产,靠转让设计许可由合作公司生产各具特色的芯片,世界各大半导体生产商从ARM公司购买其设计的ARM微处理器核,根据各自不同的应用领域,加入适当的外围电路,从而形成自己的ARM微处理器芯片进入市场。目前,全世界有几十家大的半导体公司都使用ARM公司的授权,因此既使得ARM技术获得更多的第三方工具、制造、软件的支持,又使整个系统成本降低,使产品更容易进入市场被消费者所接受,更具有竞争力。

ARM 公司的Chip less模式 ARM技术的应用领域及特点 世界各大半导体生产商从ARM公司购买其设计的ARM微处理器核,根据各自不同的应用领域,加入适当的外围电路,从而形成自己的ARM微处理器芯片进入市场。 基于ARM技术的微处理器应用约占据了32位RISC微处 理器75%以上的市场份额,ARM技术正在逐步渗入到我们生活的各个方面。 我国的中兴集成电路、大唐电讯、中芯国际和上海华虹,以及国外的一些公司如德州仪器、意法半导体、Philips、Intel、Samsung等都推出了自己设计的基于ARM核的处理器。

ARM微处理器的应用领域 ARM技术的应用领域及特点 到目前为止,ARM微处理器及技术的应用已经广泛深入到国民经济的各个领域 工业控制领域:作为32的RISC架构,基于ARM核的微控制器芯片不但占据了高端微控制器市场的大部分市场份额,同时也逐渐向低端微控制器应用领域扩展,ARM微控制器的低功耗、高性价比,向传统的8位/16位微控制器提出了挑战。

ARM微处理器的应用领域 ARM技术的应用领域及特点 网络应用:随着宽带技术的推广,采用ARM技术的ADSL芯片正逐步获得竞争优势。此外,ARM在语音及视频处理上行了优化,并获得广泛支持,也对DSP的应用领域提出了挑战。 消费类电子产品:ARM技术在目前流行的数字音频播放器、数字机顶盒和游戏机中得到广泛采用。 成像和安全产品:现在流行的数码相机和打印机中绝大部分采用ARM技术。手机中的32位SIM智能卡也采用了ARM技术。 ……

ARM微处理器的特点—低功耗、低成本、高性能 采用RISC指令集 使用大量的寄存器 ARM/THUMB指令支持 三/五级流水线

ARM微处理器的特点—采用RISC体系结构 采用RISC架构的ARM处理器一般具有如下特点: 固定长度的指令格式,指令归整、简单、基 本寻址方式有2~3种; 使用单周期指令,便于流水线操作执行; 大量使用寄存器,数据处理指令只对寄存器进行操作,只有加载/存储指令可以访问存储器,以提高指令的执行效率。

ARM微处理器的特点—大量使用寄存器 ARM技术的应用领域及特点 ARM 处理器共有37个寄存器,被分为若干个组,这些寄存器包括: 31个通用寄存器,包括程序计数器(PC 指针),均为32位的寄存器; 6个状态寄存器,用以标识CPU的工作状态及程序的运行状态,均为32位。

ARM微处理器的特点—高效的指令系统 ARM技术的应用领域及特点 ARM微处理器支持两种指令集:ARM指令集和Thumb指令集。 ARM指令为32位的长度,Thumb指令为16位长度。Thumb指令集为ARM指令集的功能子集,但与等价的ARM代码相比较,可节省30%~40%以上的存储空间,同时具备32位代码的所有优点。

ARM微处理器的特点—其他技术 ARM技术的应用领域及特点 所有的指令都可根据前面的执行结果决定是否被执行,从而提高指令的执行效率。 可用加载/存储指令批量传输数据,以提高数据的传输效率。 可在一条数据处理指令中同时完成逻辑处理和移位处理。 在循环处理中使用地址的自动增减来提高运行效率。

ARM微处理器系列 ARM微处理器系列 ARM7系列 ARM9系列 ARM9E系列 ARM10E系列 SecurCore系列 Intel的Xscale 其中,ARM7、ARM9、ARM9E和ARM10为4个通用处理器系列,每一个系列提供一套相对独特的性能来满足不同应用领域的需求。SecurCore系列专门为安全要求较高的应用而设计。

ARM微处理器系列 ARM7微处理器系列 ARM7系列是为低功耗的32位RISC处理器,最适合用于对价位和功耗要求较高的消费类应用。ARM7系列有如下特点: 具有嵌入式ICE-RT逻辑,调试开发方便; 极低的功耗,适合对功耗要求较高的应用,如便携式产品; 能够提供0.9MIPS/MHz的三级流水线结构; 代码密度高,并兼容16位的Thumb指令集; 对操作系统的支持广泛,如Windows CE、Linux、Palm OS等; 指令系统与ARM9系列、ARM9E系列和ARM10E系列兼容,便于用户的产品升级换代; 主频最高可达130M,高速的运算处理能力能胜任绝大多数的复杂应用。

ARM微处理器系列 ARM7微处理器系列 主要应用领域:工业控制、Internet设备、网络和调制解调器设备、移动电话等多种多媒体和嵌入式应用。 ARM7系列微处理器包括如下几种类型的核:ARM7TDMI、ARM7TDMI-S、ARM720T、ARM7EJ。其中,ARM7TMDI是目前使用最广泛的32位嵌入式RISC处理器,属低端ARM处理器核。TDMI的基本含义为: T:支持16位压缩指令集Thumb; D:支持片上Debug; M:内嵌硬件乘法器(Multiplier) I:嵌入式ICE,支持片上断点和调试点;

ARM9微处理器系列 ARM微处理器系列 ARM9系列微处理器在高性能和低功耗特性方面提供最佳的表现。具有以下特点: 5级整数流水线,指令执行效率更高。 提供1.1MIPS/MHz的哈佛结构。 支持32位ARM指令集和16位Thumb指令集。 支持32位的高速AMBA总线接口。 全性能的MMU,支持Windows CE、Linux、Palm OS等多种主流嵌入式操作系统。 MPU支持实时操作系统。 支持数据Cache和指令Cache,具有更高的指令和数据处理能力。

ARM微处理器系列 ARM9微处理器系列 ARM9系列微处理器主要应用于无线设备、仪器仪表、安全系统、机顶盒、高端打印机、数字照相机和数字摄像机等。 ARM9系列微处理器包含ARM920T、ARM922T和ARM940T三种类型,以适用于不同的应用场合。

ARM9E微处理器系列 ARM微处理器系列 ARM9E系列微处理器的主要特点如下: 支持DSP指令集,适合于需要高速数字信号处理的场合。 5级整数流水线,指令执行效率更高。 支持32位ARM指令集和16位Thumb指令集。 支持32位的高速AMBA总线接口。 支持VFP9浮点处理协处理器。 全性能的MMU,支持众多主流嵌入式操作系统。 ARM9E系列微处理器为可综合处理器,使用单一的处理器内核提供了微控制器、DSP、Java应用系统的解决方案,极大的减少了芯片的面积和系统的复杂程度。ARM9E系列微处理器提供了增强的DSP处理能力,很适合于那些需要同时使用DSP和微控制器的应用场合。 支持数据Cache和指令Cache,具有更高的处理能力。 主频最高可达300M。

ARM微处理器系列 ARM9E微处理器系列 ARM9E系列微处理器主要应用于下一代无线设备、数字消费品、成像设备、工业控制、存储设备和网络设备等领域。 ARM9E系列微处理器包含ARM926EJ-S、ARM946E-S和ARM966E-S三种类型,以适用于不同的应用场合。

ARM10E微处理器系列 ARM微处理器系列 ARM10E系列微处理器的主要特点如下: 支持DSP指令集,适合于需要高速数字信号处理的场合。 6级整数流水线,指令执行效率更高。 支持32位ARM指令集和16位Thumb指令集。 支持32位的高速AMBA总线接口。 支持VFP10浮点处理协处理器。 全性能的MMU,支持众多主流嵌入式操作系统。 支持数据Cache和指令Cache,具有更高的处理能力 ARM10E系列微处理器具有高性能、低功耗的特点,由于采用了新的体系结构,与同等的ARM9器件相比较,在同样的时钟频率下,性能提高了近50%,同时,ARM10E系列微处理器采用了两种先进的节能方式,使其功耗极低。 主频最高可达400M。 内嵌并行读/写操作部件。

ARM微处理器系列 ARM10E微处理器系列 ARM10E系列微处理器主要应用于下一代无线设备、数字消费品、成像设备、工业控制、通信和信息系统等领域。 ARM10E系列微处理器包含ARM1020E、ARM1022E和ARM1026EJ-S三种类型,以适用于不同的应用场合。

SecurCore微处理器系列 ARM微处理器系列 带有灵活的保护单元,确保操作系统和应用数据的安全。 采用软内核技术,防止外部对其进行扫描探测。 可集成用户自己的安全特性和其他协处理器。 ecurCore系列微处理器专为安全需要而设计,提供了完善的32位RISC技术的安全解决方案,因此,SecurCore系列微处理器除了具有ARM体系结构的低功耗、高性能的特点外,还具有其独特的优势,即提供了对安全解决方案的支持。

SecurCore微处理器系列 ARM微处理器系列 SecurCore系列微处理器包含SecurCore SC100、SecurCore SC110、SecurCore SC200和SecurCore SC210四种类型,以适用于不同的应用场合。

StrongARM微处理器系列 ARM微处理器系列 Intel StrongARM SA-1100处理器是采用ARM体系结构高度集成的32位RISC微处理器。它融合了Intel公司的设计和处理技术以及ARM体系结构的电源效率,采用在软件上兼容ARMv4体系结构、同时采用具有Intel技术优点的体系结构。 Intel StrongARM处理器是便携式通讯产品和消费类电子产品的理想选择,已成功应用于多家公司的掌上电脑系列产品。

ARM微处理器系列 Xscale处理器 Xscale 处理器是基于ARMv5TE体系结构的解决方案,是一款全性能、高性价比、低功耗的处理器。它支持16位的Thumb指令和DSP指令集,已使用在数字移动电话、个人数字助理和网络产品等场合。 Xscale 处理器是Intel目前主要推广的一款ARM微处理器。

ARM微处理器的工作状态 ARM微处理器的工作状态 从编程的角度看,ARM微处理器的工作状态一般有两种,并可在两种状态之间切换: Thumb状态,此时处理器执行16位的、半字对齐的Thumb指令。 当ARM微处理器执行32位的ARM指令集时,工作在ARM状态;当ARM微处理器执行16位的Thumb指令集时,工作在Thumb状态。在程序的执行过程中,微处理器可以随时在两种工作状态之间切换,并且,处理器工作状态的转变并不影响处理器的工作模式和相应寄存器中的内容。

ARM与THUMB ARM微处理器的工作状态 THUMB指令是ARM指令的子集 可以相互调用,只要遵循一定的调用规则

状态切换方法 ARM微处理器的工作状态 ARM指令集和Thumb指令集均有切换处理器状态的指令,并可在两种工作状态之间切换,

进入Thumb状态 ARM微处理器的工作状态 当操作数寄存器的状态位(位0)为1时,可以采用执行BX指令的方法,使微处理器从ARM状态切换到Thumb状态。 当处理器处于Thumb状态时发生异常(如IRQ、FIQ、Undef、Abort、SWI等),则异常处理返回时,自动切换到Thumb状态。

切换到ARM状态 ARM微处理器的工作状态 当操作数寄存器的状态位为0时,执行BX指令时可以使微处理器从Thumb状态切换到ARM状态。 在处理器进行异常处理时,把PC指针放入异常模式链接寄存器中,并从异常向量地址开始执行程序,也可以使处理器切换到ARM状态。

处理器模式 ARM微处理器的工作模式 usr:ARM处理器正常的程序执行状态 fiq:用于高速数据传输或通道处理 irq:用于通用的中断处理 svc:操作系统使用的保护模式 abt:用于虚拟存储及存储保护 und:当出现未定义指令终止时进入该模式 sys:运行具有特权的操作系统任务

用户模式和特权模式 ARM微处理器的工作模式 除了用户模式之外的其他6种处理器模式称为特权模式 特权模式下,程序可以访问所有的系统资源,也可以任意地进行处理器模式的切换。 特权模式中,除系统模式外,其他5种模式又称为异常模式 大多数的用户程序运行在用户模式下,此时,应用程序不能够访问一些受操作系统保护的系统资源,应用程序也不能直接进行处理器模式的切换。 用户模式下,当需要进行处理器模式切换时,应用程序可以产生异常处理,在异常处理中进行处理器模式的切换。

模式切换 ARM微处理器的工作模式 处理器模式可以通过软件进行切换,也可以通过外部中断或者异常处理过程进行切换。 当应用程序发生异常中断时,处理器进入相应的异常模式。在每一种异常模式下都有一组寄存器,供相应的异常处理程序使用,这样就可以保证在进入异常模式时,用户模式下的寄存器不被破坏。 系统模式并不是通过异常进入的,它和用户模式具有完全一样的寄存器。但是系统模式属于特权模式,可以访问所有的系统资源,也可以直接进行处理器模式切换。它主要供操作系统任务使用。通常操作系统的任务需要访问所有的系统资源,同时该任务仍然使用用户模式的寄存器组,而不是使用异常模式下相应的寄存器组,这样可以保证当异常中断发生时任务状态不被破坏。

ARM微处理器的存储器格式 ARM微处理器的存储器格式 ARM体系结构所支持的最大寻址空间为4GB(232字节)

ARM体系结构的存储器格式—大端格式 ARM微处理器的存储器格式 在这种格式中,字数据的高字节存储在低地址中,而字数据的低字节则存放在高地址中

ARM体系结构的存储器格式—小端格式 ARM微处理器的存储器格式 与大端存储格式相反,在小端存储格式中,低地址中存放的是字数据的低字节,高地址存放的是字数据的高字节

指令长度及数据类型 ARM微处理器的存储器格式 ARM微处理器的指令长度可以是32位(在ARM状态下),也可以为16位(在Thumb状态下)。 ARM微处理器中支持字节(8位)、半字(16位)、字(32位)三种数据类型,其中,字需要4字节对齐(地址的低两位为0)、半字需要2字节对齐(地址的最低位为0)

非对齐的存储访问操作 ARM微处理器的存储器格式 在ARM种,如果存储单元的地址没有遵守对齐规则,则称为非对齐的存储访问操作。 非对齐的指令预取操作 非对齐的数据访问操作

非对齐的指令预取操作 ARM微处理器的存储器格式 当处理器处于ARM状态期间,如果写入到寄存器PC中的值是非字对齐的,要么指令执行的结果不可预知,要么地址值中最低两位被忽略。 当处理器处于THUMB状态期间,如果写入到寄存器PC中的值是非半字对齐的,要么指令执行的结果不可预知,要么地址值中最低位被忽略。

非对齐的数据访问操作 ARM微处理器的存储器格式 对于Load/Store操作,如果是非对齐的数据访问操作,系统定义了三种可能的结果: 执行的结果不可预知 忽略字单元地址的低两位的值,即访问地址为(address AND 0XFFFFFFFC)的字单元;忽略半字单元地址的最低位的值,即访问地址为(address AND 0XFFFFFFFE)的半字单元。 忽略字单元地址的低两位的值;忽略半字单元地址的最低位的值;由存储系统实现这种忽略。也就是说,这时该地址值原封不动地送到存储系统。 当发生非对齐地数据访问时,到底采用上述三种方法中的哪一种,是由各指令指定的。

ARM微处理器的寄存器格式 寄存器组织 ARM微处理器共有37个32位寄存器,其中31个为通用寄存器,6个为状态寄存器。但是这些寄存器不能被同时访问,具体哪些寄存器是可编程访问的,取决微处理器的工作状态及具体的运行模式。但在任何时候,通用寄存器R14~R0、程序计数器PC、一个或两个状态寄存器都是可访问的。

ARM状态下的寄存器组织 ARM微处理器的寄存器格式 通用寄存器:通用寄存器包括R0~R15,可以分为三类: 未分组寄存器R0~R7 程序计数器PC(R15)

ARM微处理器的寄存器格式 ARM状态下的寄存器组织

未分组寄存器R0~R7 ARM微处理器的寄存器格式 在所有的运行模式下,未分组寄存器都指向同一个物理寄存器,他们未被系统用作特殊的用途,因此,在中断或异常处理进行运行模式转换时,由于不同的处理器运行模式均使用相同的物理寄存器,可能会造成寄存器中数据的破坏,这一点在进行程序设计时应引起注意。

分组寄存器R8~R12 ARM微处理器的寄存器格式 每次所访问的物理寄存器与处理器当前的运行模式有关 当使用fiq模式时,访问寄存器R8_fiq~R12_fiq; 当使用除fiq模式以外的其他模式时,访问寄存器R8_usr~R12_usr。

分组寄存器R13~R14 ARM微处理器的寄存器格式 R13、R14:每个寄存器对应6个不同的物理寄存器 其中的一个是用户模式与系统模式共用,另外5个物理寄存器对应于其他5种不同的运行模式 采用以下的记号来区分不同的物理寄存器: R13_<mode> R14_<mode> mode为以下几种之一:usr、fiq、irq、svc、abt、und。

ARM微处理器的寄存器格式 堆栈指针—R13 R13在ARM指令中常用作堆栈指针,但这只是一种习惯用法,用户也可使用其他的寄存器作为堆栈指针。 在Thumb指令集中,某些指令强制性的要求使用R13作为堆栈指针。 由于处理器的每种运行模式均有自己独立的物理寄存器R13,在初始化部分,都要初始化每种模式下的R13,这样,当程序的运行进入异常模式时,可以将需要保护的寄存器放入R13所指向的堆栈,而当程序从异常模式返回时,则从对应的堆栈中恢复。

子程序连接寄存器—R14 ARM微处理器的寄存器格式 R14也称作子程序连接寄存器或连接寄存器LR。当执行BL子程序调用指令时,可以从R14中得到R15(程序计数器PC)的备份。其他情况下,R14用作通用寄存器。 在每一种运行模式下,都可用R14保存子程序的返回地址,当用BL或BLX指令调用子程序时,将PC的当前值拷贝给R14,执行完子程序后,又将R14的值拷贝回PC,即可完成子程序的调用返回。 BL SUB1 …… SUB1: STMFD SP!, {<regs>, LR} /*将R14存入堆栈*/ LDMFD SP!,{<regs>,PC}/*完成子程序返回 */

程序计数器PC(R15) ARM微处理器的寄存器格式 ARM状态下,位[1:0]为0,位[31:2]用于保存PC; Thumb状态下,位[0]为0,位[31:1]用于保存PC; R15虽然也可用作通用寄存器,但一般不这么使用,因为对R15的使用有一些特殊的限制,当违反了这些限制时,程序的执行结果是未知的。 由于ARM体系结构采用了多级流水线技术,对于ARM指令集而言,PC总是指向当前指令的下两条指令的地址,即PC的值为当前指令的地址值加8个字节。

程序状态寄存器(CPSR/SPSR) ARM微处理器的寄存器格式 寄存器R16用作CPSR(当前程序状态寄存器),CPSR可在任何运行模式下被访问,它包括条件标志位、中断禁止位、当前处理器模式标志位,以及其他一些相关的控制和状态位。 每一种运行模式下又都有一个专用的物理状态寄存器,称为SPSR(备份的程序状态寄存器),异常发生时,SPSR用于保存CPSR的值,从异常退出时则可由SPSR来恢复CPSR。 由于用户模式和系统模式不属于异常模式,他们没有SPSR,当在这两种模式下访问SPSR,结果是未知的。

Thumb状态下的寄存器组织 ARM微处理器的寄存器格式 Thumb状态下的寄存器集是ARM状态下寄存器集的一个子集 程序可以直接访问8个通用寄存器(R7~R0)、程序计数器(PC)、堆栈指针(SP)、连接寄存器(LR)和CPSR。 同样,每一种特权模式下都有一组SP、LR和SPSR。

ARM微处理器的寄存器格式 Thumb状态下的寄存器组织图

Thumb状态下的寄存器与ARM状态下的寄存器关系 Thumb状态下和ARM状态下的R0~R7是相同的。 Thumb状态下和ARM状态下的CPSR和所有的SPSR是相同的。 Thumb状态下的SP对应于ARM状态下的R13。 Thumb状态下的LR对应于ARM状态下的R14。 Thumb状态下的程序计数器对应于ARM状态下R15。

Thumb状态下的寄存器与ARM状态下的寄存器关系图

访问THUMB状态下的高位寄存器(Hi-registers) ARM微处理器的寄存器格式 访问THUMB状态下的高位寄存器(Hi-registers) 在Thumb状态下,高位寄存器R8~R15并不是标准寄存器集的一部分,但可使用汇编语言程序受限制的访问这些寄存器,将其用作快速的暂存器。 使用带特殊变量的MOV指令,数据可以在低位寄存器和高位寄存器之间进行传送;高位寄存器的值可以使用CMP和ADD指令进行比较或加上低位寄存器中的值。

程序状态寄存器 ARM微处理器的寄存器格式 ARM体系结构包含一个当前程序状态寄存器(CPSR)和五个备份的程序状态寄存器(SPSRs)。备份的程序状态寄存器用来进行异常处理,其功能包括: 保存ALU中的当前操作信息 控制允许和禁止中断 设置处理器的运行模式

ARM微处理器的寄存器格式 程序状态寄存器的每一位的安排

程序状态寄存器的条件码标志 ARM微处理器的寄存器格式 N、Z、C、V均为条件码标志位。它们的内容可被算术或逻辑运算的结果所改变,并且可以决定某条指令是否被执行 在ARM状态下,绝大多数的指令都是有条件执行的。 在Thumb状态下,仅有分支指令是有条件执行的。

影响标志位的指令 ARM微处理器的寄存器格式 含 义 N 含 义 N 当用两个补码表示的带符号数进行运算时,N=1 表示运算的结果为负数;N=0 表示运算的结果为正数或零; Z Z=1 表示运算的结果为零;Z=0表示运算的结果为非零; C 加法运算结果进位时,C=1,减法运算借位时,C=0; 移位操作的非加/减运算指令,C为移出的最后一位; 其他的非加/减运算指令,C的值通常不改变。 V 加/减法运算指令,V=1表示符号位溢出。 对于其他的非加/减运算指令,C的值通常不改变。 Q 在ARM v5及以上版本的E系列处理器中,Q标志指示DSP运算指令是否溢出。在其他版本中,Q标志位无定义。

程序状态寄存器的控制位 ARM微处理器的寄存器格式 状态寄存器的低8位(I、F、T和M[4:0])称为控制位,发生异常时这些位可以被改变。如果处理器运行特权模式,这些位也可以由程序修改。 中断禁止位I、F: I=1 禁止IRQ中断; F=1 禁止FIQ中断。 T标志位:该位反映处理器的运行状态 ARM体系结构v5及以上的版本的T系列处理器,当该位为1时,程序运行于Thumb状态,否则运行于ARM状态。 ARM体系结构v5及以上的版本的非T系列处理器,当该位为1时,执行下一条指令以引起为定义的指令异常;当该位为0时,表示运行于ARM状态。 运行模式位M[4:0]是模式位,决定处理器的运行模式

处理器运行模式及可以访问的寄存器 ARM微处理器的寄存器格式 M[4:0] 处理器模式 可访问的寄存器 0b10000 用户模式 PC,CPSR,R0-R14 0b10001 FIQ模式 PC,CPSR, SPSR_fiq,R14_fiq-R8_fiq, R7~R0 0b10010 IRQ模式 PC,CPSR, SPSR_irq,R14_irq, R13_irq, R12~R0 0b10011 管理模式 PC,CPSR, SPSR_svc,R14_svc, R13_svc, R12~R0, 0b10111 中止模式 PC,CPSR, SPSR_abt,R14_abt,R13_abt, R12~R0, 0b11011 未定义模式 PC,CPSR, SPSR_und,R14_und, R13_und, R12~R0, 0b11111 系统模式 PC,CPSR(ARM v4及以上版本), R14~R0

异常(Exceptions) ARM异常处理 当正常的程序执行流程发生暂时的停止时,称之为异常,例如处理一个外部的中断请求。在处理异常之前,当前处理器的状态必须保留,这样当异常处理完成之后,当前程序可以继续执行。处理器允许多个异常同时发生,它们将会按固定的优先级进行处理。 ARM体系结构中的异常,与8位/16位体系结构的中断有很大的相似之处,但异常与中断的概念并不完全等同。

ARM体系结构所支持的异常类型 ARM异常处理 异常类型 具体含义 复位 复位电平有效时,产生复位异常,程序跳转到复位处理程序处执行。 未定义指令 遇到不能处理的指令时,产生未定义指令异常。 软件中断 执行SWI指令产生,用于用户模式下的程序调用特权操作指令。 指令预取中止 处理器预取指令的地址不存在,或该地址不允许当前指令访问,产生指令预取中止异常。 数据中止 处理器数据访问指令的地址不存在,或该地址不允许当前指令访问时,产生数据中止异常。 IRQ 外部中断请求有效,且CPSR中的I位为0时,产生IRQ异常。 FIQ 快速中断请求引脚有效,且CPSR中的F位为0时,产生FIQ异常。

对异常的响应 ARM异常处理 当一个异常出现以后,ARM微处理器会执行以下几步操作 将下一条指令的地址存入相应连接寄存器LR,以便程序在处理异常返回时能从正确的位置重新开始执行。 将CPSR复制到相应的SPSR中。 根据异常类型,强制设置CPSR的运行模式位。 强制PC从相关的异常向量地址取下一条指令执行,从而跳转到相应的异常处理程序处。 若异常是从ARM状态进入,LR寄存器中保存的是下一条指令的地址(当前PC+4或PC+8,与异常的类型有关); 若异常是从Thumb状态进入,则在LR寄存器中保存当前PC的偏移量,这样,异常处理程序就不需要确定异常是从何种状态进入的。 例如:在软件中断异常SWI,指令 MOV PC,R14_svc总是返回到下一条指令,不管SWI是在ARM状态执行,还是在Thumb状态执行。

ARM异常处理 异常响应伪代码 处理器处于Thumb状态,则当异常向量地址加载入PC时,处理器自动切换到ARM状态。ARM微处理器对异常的响应过程用伪码可以描述为: R14_<Exception_Mode> = Return Link SPSR_<Exception_Mode> = CPSR CPSR[4:0] = Exception Mode Number CPSR[5] = 0 If <Exception_Mode> == Reset or FIQ then CPSR[6] = 1 CPSR[7] = 1 PC = Exception Vector Address 在ARM状态下执行 禁止快速中断 禁止正常中断 转入异常入口地址

从异常返回 ARM异常处理 异常处理完毕之后,ARM微处理器会执行以下几步操作从异常返回: 将连接寄存器LR的值减去相应的偏移量后送到PC中。 将SPSR复制回CPSR中。 若在进入异常处理时设置了中断禁止位,要在此清除。 可以认为应用程序总是从复位异常处理程序开始执行的,因此复位异常处理程序不需要返回。

FIQ(Fast Interrupt Request) ARM异常处理 FIQ(Fast Interrupt Request) FIQ异常是为了支持数据传输或者通道处理而设计的。 若将CPSR的F位置为1,则会禁止FIQ中断,若将CPSR的F位清零,处理器会在指令执行时检查FIQ的输入。注意只有在特权模式下才能改变F位的状态。 可由外部通过对处理器上的nFIQ引脚输入低电平产生FIQ。不管是在ARM状态还是在Thumb状态下进入FIQ模式,FIQ处理程序均可以执行以下指令从FIQ模式返回: SUBS PC,R14_fiq ,#4

IRQ(Interrupt Request) ARM异常处理 IRQ(Interrupt Request) IRQ异常属于正常的中断请求,可通过对处理器的nIRQ引脚输入低电平产生,IRQ的优先级低于FIQ,当程序执行进入FIQ异常时,IRQ可能被屏蔽。 若将CPSR的I位置为1,则会禁止IRQ中断,若将CPSR的I位清零,处理器会在指令执行完之前检查IRQ的输入。注意只有在特权模式下才能改变I位的状态。 不管是在ARM状态还是在Thumb状态下进入IRQ模式,IRQ处理程序均可以执行以下指令从IRQ模式返回: SUBS PC , R14_irq , #4

ABORT(中止) ARM异常处理 产生中止异常意味着对存储器的访问失败。ARM微处理器在存储器访问周期内检查是否发生中止异常。 中止异常包括两种类型: 指令预取中止:发生在指令预取时。 数据中止:发生在数据访问时。 当指令预取访问存储器失败时,存储器系统向ARM处理器发出存储器中止(Abort)信号,预取的指令被记为无效,但只有当处理器试图执行无效指令时,指令预取中止异常才会发生,如果指令未被执行,例如在指令流水线中发生了跳转,则预取指令中止不会发生。 若数据中止发生,系统的响应与指令的类型有关。 当确定了中止的原因后,Abort处理程序均可以执行以下指令从中止模式返回,无论是在ARM状态还是Thumb状态: SUBS PC, R14_abt, #4 ;指令预取中止 SUBS PC, R14_abt, #8 ;数据中止

Software Interruupt(软件中断) ARM异常处理 Software Interruupt(软件中断) 软件中断指令(SWI)用于进入管理模式,常用于请求执行特定的管理功能。软件中断处理程序执行以下指令可以从SWI模式返回,无论是在ARM状态还是Thumb状态: MOVS PC , R14_svc 以上指令恢复PC(从R14_svc)和CPSR(从SPSR_svc) 的值,并返回到SWI的下一条指令。

Undefined Instruction(未定义指令) ARM异常处理 Undefined Instruction(未定义指令) 当ARM处理器遇到不能处理的指令时,会产生未定义指令异常。采用这种机制,可以通过软件仿真扩展ARM或Thumb指令集。 处理器执行以下程序返回,无论是在ARM状态还是Thumb状态: MOVS PC, R14_und 以上指令恢复PC(从R14_und)和CPSR(从SPSR_und)的值,并返回到未定义指令后的下一条指令。

异常向量表(Exception Vectors) ARM异常处理 异常向量表(Exception Vectors) 地 址 异 常 进入模式 0x0000,0000 复位 管理模式 0x0000,0004 未定义指令 未定义模式 0x0000,0008 软件中断 0x0000,000C 中止(预取指令) 中止模式 0x0000,0010 中止(数据) 0x0000,0014 保留 0x0000,0018 IRQ 0x0000,001C FIQ

异常优先级(Exception Priorities) ARM异常处理 异常优先级(Exception Priorities) 优先级 异 常 1(最高) 复位 2 数据中止 3 FIQ 4 IRQ 5 预取指令中止 6(最低) 未定义指令、SWI

ARM异常处理 应用程序中的异常处理 当系统运行时,异常可能会随时发生,为保证在ARM处理器发生异常时不至于处于未知状态,在应用程序的设计中,首先要进行异常处理,采用的方式是在异常向量表中的特定位置放置一条跳转指令,跳转到异常处理程序,当ARM处理器发生异常时,程序计数器PC会被强制设置为对应的异常向量,从而跳转到异常处理程序,当异常处理完成以后,返回到主程序继续执行。 我们需要处理所有的异常,尽管我们可以简单的在某些异常处理程序处放置死循环。