ARM体系结构_DAY2
程序状态寄存器(CPSR)
Mode位[4:0]:处理器模式为
USER模式不能直接切换到特权模式,在特权模式下可以直接修改mode位[4:0]为10000,切换到USER模式。
T bit位[5]:处理器状态位
T = 0,J= 0处于ARM指令集状态
T = 1,J= 0处于Thumb指令集状态
T = 1,J = 1处于ThumbEE指令集状态
中断禁止位[7:6]
I = 1 进制IRQ
F = 1 进制FIQ
条件位[31:27]
- N位 Negative result from ALU ALU运算结果为一个负数时, 此为自动置 1 否则为 0
- Z位 Zero result from ALU ALU运算结果为 0 时,此位自动置 1,否则为 0
- C位 分为加法运算和减法运算两种情况:
- 进行加法运算,如果产生进位 C位自动置一
- 进行减法运算时,如果产生借位, C位自动置 0
- V位 符号位溢出,(最高为产生变化,针对于有符号数来说) V位自动置 1
计算机系统中,所有的数据都以 二进制补码 方式存储。

异常处理
ARM 有 7 类中断源:
偏移量 异常类别
- 0x1C FIQ 快速响应中断
- 0x18 IRQ 外部中断
- 0x10 Data Abort 数据终止 当访问数据时,CPU不允许访问请求 会进入此种中断
- 0x0C Perfetch Abort
- 0x08 software interrupt
- 0x04 Undefined Instruction 指令未定义异常 CPU取出一条指令,如果不能执行,此时会 将数据交由协处理器执行。若没有协处理器或者协处理器也不能处理,就会触发此中断
- 0x00 Reset 复位中断
7种异常对应的5种模式
异常源: FIQ IRQ Reset/软中断 DataAbort/PerfetchAbort Undef
CPU模式: FIQ IRQ Supervisor(SVC) Abort Undef
异常处理过程:
当异常产生异常时,ARM core(自动执行但不包括压栈操作):
- 拷贝 CPSR(current program status register)内容到 SPSR_<mode>(saved program status register)<mode>指的是具体哪一个状态的SPSR
- 设置适当的 CPSR 位:
- 改变处理器状态进入ARM状态(处理异常时,必须在ARM状态下进行)
- 改变处理器模式进入相应的异常(特权)模式
- 设置中断禁止位,防止中断处理过程中产生中断(如果需要)
Cortex A系列处理器,不允许同一类的中断嵌套 (处理FIQ时,不响应IRQ;处理IRQ时,可嵌套FIQ)
- 保存返回地址到 lr_<mode>
- 设置 pc 为相应的异常向量
- ARM7、ARM9的异常向量表固定为0x00开始的一端内存中,cortex A系列默认为 0x00 但可以手动设置
返回时,异常处理需要(中断处理程序中手动执行):
- 从 SPSR_<mode>恢复 CPSR
- 从 lr_<mode> 恢复 PC
- Note:这些操作只能在 ARM 状态执行
异常源类型,对应处理器模式。
异常优先级
Reset ——> Data Abort ——> FIQ > IRQ ——> Prefetch Abort ——> SWI→Undefined
FIQ 比 IRQ 快? 三方面原因:
- FIQ优先级高
- FIQ在中断向量表的最高偏移地址,在编程时可以直接在FIQ后面添加中断处理程序,省去了跳转指令。
- FIQ有多个私有寄存器(r8_r14),在中断处理程序中使用这几个寄存器时可以省去压栈,弹栈操作
指令流水线
三级流水线:
PC(program count)指向正在取指的指令。
PC - 4 为正在译码的指令。
PC - 8 为正在执行的指令。


ARM体系结构_DAY2的更多相关文章
- ARM体系结构简介
ARM体系结构简介 新一代的ARM9处理器,能达到两倍ARM7的处理能力,它们的区别如下: ARM微处理器的工作状态(可切换): 第一种为ARM状态,此时处理器执行32位的字对齐的ARM指令 第二种为 ...
- ARM体系结构和汇编指令
第一节 可编程器件的编程原理 1. 可编程器件的特点 1 . CPU在固定频率的时钟控制下节奏运行 2 . CPU可以通过总线读取外部存储设备中的二进制指令集,然后解码执行 3 . 这些可以被CPU解 ...
- ARM体系结构
工作模式_ufisaus USR(User) :正常程序的执行状态 FIQ(Fast interrupt) :用于高速数据传输和通道处理 IRQ(Interrupt) :通常的中断处理 SVC(Sup ...
- ARM体系结构与编程
ARM处理器的7中执行模式:usr.fiq.irq.svc.abt.und.sys. ARM处理器共37个寄存器:31个通用寄存器(未备份寄存器R0-R7,在全部模式下指的都是同一个物理寄存器:备份寄 ...
- 1.0ARM体系结构-ARM体系结构
对ARMcpu有整体而专业的认识. ARM只是设计arm核,而不生产. ARM 掌握的是标准.
- ARM体系结构总结
特殊功能寄存器与外设绑定,通用寄存器是与CPU绑定. ARM是RISC架构 常用ARM汇编指令只有二三十条 ARM是低功耗CPU ARM的架构非常适合单片机.嵌入式.尤其是物联网领域:而服务器等高性能 ...
- ARM体系结构与编程-3
ARM存储系统:ARM中用于存储管理的系统控制协处理器CP15:包括16个32位寄存器,其编号为0到15.实际上对于某些编号的寄存器可能相应有多个物理寄存器. 訪问CP15寄存器的指令:MRC.MCR ...
- ARM体系结构与编程-5
GET通经常使用于包括定义常量的源文件. 比如:GET 2440addr.inc 用AREA定义一个段.ENTRY用于指定程序的入口点,END用于告诉汇编器源文件已经结束. 比如: AREA init ...
- ARM体系结构与编程读书笔记——处理器的寄存器
ARM处理器共有37个寄存器,其中包括: 31个通用寄存器,包括程序计数器(PC)在内,寄存器都是32位: 6个状态寄存器,这些寄存器都是32位的,目前只使用了其中12位: 通用寄存器 可以分为下面3 ...
随机推荐
- web_api vs2015 新加标题无法打开
HomeController 去掉特性[Authorize]
- Spring 详解第一天
spring 框架简述: http://www.cnblogs.com/ToBeAProgrammer/p/5230065.html http://www.cnblogs.com/ToBeAProgr ...
- 代码段编辑器SnippetEditor 2.1
1.选择程序版本 2.可以创建文件夹 3.新建片段 4.给片段取名 5.双击进行编辑 6.点击保存 7.直接使用
- 让 asp.net mvc 支持 带有+ _ 等特殊字符的路由
最近配置微信 业务域名 时,需要在服务器的根目录中上传一个文本文件,而这个文本文件需要放这样的目录中: 于在就在 服务器目录中创建了对应的文件夹,并将kuPv.txt上传,但是访问时,却怎么也访问不到 ...
- scala学习笔记——特质
一个类扩展自一个或多个特质,以便使用这些特质提供的服务.特质可能会要求使用它的类支持某个特定的特性.不过和java不同,Scala特质可以给出这些特性的缺省实现. 特质的特性: 类可以实现任意数量的特 ...
- ORA-01810格式代码出现两次 的解决方案
今早做一个查询页面时,需要查询两个时间区间的跨度,使用TO_DATE函数,一开始写成了Sql代码 TO_DATE('2014-08-04 00:00:00','YYYY-MM-DD HH:mm:ss' ...
- 二维指针*(void **)的研究(uC/OS-II案例) 《转载》
uC/OS-II内存管理函数内最难理解的部分就是二维指针,本文以图文并茂的方式对二维指针进行了详细分析与讲解.看完本文,相信对C里面指针的概念又会有进一步的认识. 一.OSMemCreate( ) 函 ...
- 2016ICPC China-finals 题解
A:ans=n/3,因为8=1(mod7) B: C: D:二分+贪心,二分答案,即个数,check(mid)时贪心看能不能放成mid个; E:贪心,列出不等关系,然后写个高精度分数类; F:二分+h ...
- 改变VC生成exe图标
默认 VC 生成的 EXE 文件的图标很大众,可以根据以下办法修改 exe 的图标. 以 Visual C++ 6.0 为例: 1. 创建项目,添加代码,并且保证项目可以正常编译. 2. 为项目增加资 ...
- activiti 5.17 流程图中文乱码问题
1. 流程图中任务中的中文乱码显示问题. 解决方法:设置processEngineConfiguration中的两个字体属性,例如: <bean id="processEngine ...