ARM处理器的工作状态:ARM处理器有两种工作状态。在程序的执行过程中,处理器可以在两种工作状态之间切换,并且不影响相应寄存器中的内容。
ARM状态,此时处理器执行32位对齐的ARM指令;BX指令,当操作数寄存器最低位为0时,进入ARM状态。
Thumb,此时处理器执行16位对齐的Thumb指令。BX指令,当操作数寄存器最低位为1时,进入Thumb状态。
BX(Branch Exchange):BX Rn; ##其中Rn可以是R0-R15中的任意一个。指令通过将寄存器Rn的内容拷贝到程序计数器PC来完成4Gbyte的地址空间的跳转。
在进入异常中断后,ARM内核会自动切换到ARM状态,所以在异常中断处理程序入口的是ARM指令,如果需要切换到Thumb状态必须在异常中断返回前,切换到ARM工作状态。当处理器在Thumb状态下发生异常时,返回后,自动切换到Thumb状态。
ARM处理器总是从ARM工作状态开始的。
ARM处理器的7中工作模式:
USE模式:正常用户模式。
FIQ模式:快速中断模式,支持高速数据传输。
IRQ模式:普通中断模式。
SVC模式:Supervisor模式,操作系统保护模式,处理软件中断swi,reset.
ABT模式:数据,指令中止模式。
UND模式:未定义模式,支持软件仿真。
SYS模式:系统模式,运行特权操作系统任务。
除用户模式之外的6中模式称为特权模式,特权模式下,程序可以访问所有的系统资源,可以任意的进行处理器模式的切换。
用户模式下不能访问一些受操作系统保护的系统资源,不能直接进行处理器模式切换,需要由应用程序产生异常处理。
特权模式中,除系统模式之外的5种模式称为异常模式。
FIQ要比IRQ的响应快很多,首先FIQ的优先级比较高,再次ARM的FIQ会有自己更多的寄存器,由ARM自动保存。
异常处理过程:将下一条指令存入LR寄存器,CPSR赋值到SPSR,强制设置CPSR运行位,跳转到异常处理函数。
返回:将LR中的值减相应的偏移量送到PC中,将SPSR的值复制到CPSR中。
异常向量表:0x0000_0000---复位Reset,进入SVC模式。
0x0000_0004---未定义指令,进入UND模式。
0x0000_0008---软件中断,进入SVC模式。
0x0000_000C---中止指令,进入ABT模式。
0x0000_0010---中止数据,进入ABT模式。
0x0000_0014---保留
0x0000_0018---IRQ中断,进入IRQ模式。
0x0000_001C---FIQ中断,进入FIQ模式。
ARM处理器中一共有37个寄存器。分别有31个通用寄存器:R0-R15, R13_svc, R14_svc, R13_abt, R14_abt, R13_und,
R14_und, R13_irq, R14_irq, R8_frq----R14_frq。
6个状态寄存器:CPSR, SPSR_svc, SPSR_abt, SPSR_und, SPSR_irq, SPSR_fiq。
R13通常用作堆栈指针。R14通常用作子程序连接。
CPSR当前程序状态寄存器。SPSR备份程序状态寄存器。
31--28:NZCV(Negative Zero Carry Overflow)
27---8:Reserve
7----5:IFT(IRQ disable FIQ disable State bit)
4----0:Mode bits
0b10000---用户模式,0b10001---FIQ模式,0b10010---IRQ模式,0b10011---SVC模式,0b10111---ABT模式,
0b11011---UND模式,0b11111---SYS模式。
question:为什么会根据Rn的最低位来切换状态呢,最低位是1表示8位对齐而不是16位啊。难道arm本身是16位地址对齐??
arm处理器的架构发展:
arm系统一般包括:mpcore,debug and trace,smmu,GIC,AMBA bus,security扩展,
arm中最多支持16个coprocessor,CP0-CP15,其中CP8-CP15是由arm reserve的,CP0-CP7是imp defined的。
arm的coprocessor model中,coprocessor一般包括,
1) 组成coprocessor interface的primary,secondary coprocessor寄存器;
2) internal寄存器;
ARMv7以及之前的版本中,包含的coprocessor有:
1) CP15,提供memory,cache,tcm的控制,和系统中非debug功能的寄存器;也被称为系统控制协处理器
2) CP14,提供其他系统寄存器的访问,包括debug,trace;
3) CP10,CP11,用作SIMD,VFP的控制,需要同时使用。
ARM的协处理器指令包括五个:
1) CDP,协处理器数操作指令,
2) LDC,协处理器数据加载指令,
3) STC,协处理器数据存储指令,
4) MCR,ARM寄存器到协处理器寄存器的数据传送指令,
5) MRC,协处理器寄存器到ARM寄存器的数据传送指令,
命令格式:
上一篇:ARM体系架构—ARMv7-A处理器模式及寄存器
下一篇:详细解读ARM寄存器之CPSR
推荐阅读
史海拾趣
在这个故事中,我们将探讨ERP Power如何在云计算技术的推动下实现创新发展。通过引入云计算技术,ERP Power系统为企业提供了更加灵活、可扩展的信息化解决方案,帮助企业降低了IT成本并提高了系统安全性。
EIC公司一直秉持着环保责任和社会责任感。公司在生产过程中积极采用环保材料和工艺,减少废弃物排放和能源消耗。同时,EIC还积极参与社会公益活动,为社会做出了积极贡献。这些举措不仅提升了公司的社会形象,也为公司的可持续发展奠定了坚实的基础。
除了无线耳机和太阳能领域,BRIGHT公司还在健康技术领域取得了重要的突破。他们成功筹集了60万美元的资金,用于推动健康技术的持续增长和扩张。这笔资金使得BRIGHT公司能够在其成功的基础上,进一步研发和推广基于科学的认知健康解决方案。他们的产品,如40赫兹灯,无需医生处方即可普遍使用,为广大消费者提供了更加便捷和科学的健康管理方式。
随着新能源汽车市场的蓬勃发展,西安航天民芯敏锐地捕捉到了这一机遇。公司投入大量资源进行新能源汽车BMS管理芯片的研发,并成功推出了国内首款新能源汽车专用BMS管理芯片。这一创新产品填补了国内空白,为公司在新能源汽车领域赢得了先机。
随着市场竞争的加剧,铨力公司意识到单纯依靠太阳能电源产品已无法满足市场需求。于是,公司开始着手研发更为先进、高效的能源技术。经过多次试验和改进,铨力成功突破了技术瓶颈,研发出了新一代高效能、低成本的太阳能电池板。这一技术的突破不仅提升了产品的竞争力,也为公司打开了更广阔的市场空间。
当我屁颠屁颠地跟在老师后面不厌其烦询问如何编写某个程序的时候,老师总是对我说先画出你程序的 控制流程序图吧。当时觉得麻烦,也就把这经验之谈当成了一阵风吹过。现在,走上了程序开发这条路 ,才知道开发之前系统的规化一下自已的思路是 ...… 查看全部问答∨ |
前言 GR228X在线测试系统(简称GR228X测试系统或GR228X系统),是目前在线测试系统中以自动程序控制见长的典型的板测试系统。它采用高精度的测试诊断技术对印刷线路板实施快速的电子测试,是由计算机控制的组合测试系统。该类系统运行在基于Microsof ...… 查看全部问答∨ |
飞思卡尔09年最新的工控电子方面的资料打包下载,都是pdf文档,主要是关于飞思卡尔的一些产品在工业控制行业的应用以及一些相关技术的解决方案。资料很全面,很详细。 … 查看全部问答∨ |
|
atmega128 485接收发送问题,无相应 但是串口两个RXD TXD端接能个接收数据 #define FRAMING_ERROR (1<<FE1) #define PARITY_ERROR (1<<UPE1) #define DATA_OVERRUN (1<<DOR1) #define DATA_REGISTER_EMPTY (1<<UDRE1) #define RX_BUFFER_SIZE1 64 #define TX_BUFFER_SIZE1 64 #define RevEnble()&n ...… 查看全部问答∨ |
|
我用C#写了一段代码: System.IO.File.Delete("mydb.sdf"); string connString = "Data source=mydb.sdf"; SqlCeEngine engine = new SqlCeEngine(connString); engine.CreateDatabase(); string rdaOleDbConnectString = @"Pr ...… 查看全部问答∨ |
|
#define DELTA 488 // Target DCO = DELTA*(4096) ~2MHz void Set_DCO (void) // Set DCO to selected frequency //---------------------------------------------------------------------- ...… 查看全部问答∨ |