"); //-->
ARM处理器共有37个寄存器。其中包括:
**31个通用寄存器,包括程序计数器(PC)在内。这些寄存器都是32位寄存器。
**6个状态寄存器。这些寄存器都是32位寄存器。
ARM处理器共有7种不同的处理器模式,每一种模式中都有一组相应的寄存器组。在任何时刻,可见的寄存器包括15个通用寄存器(R0-R14),一个或两个状态寄存器及程序计数器(PC)。在所有的寄存器中,有些是各模式公用一个物理寄存器,有一些寄存器各模式拥有自己独立的物理寄存器。
****************************************************
通用寄存器
***************************************************8
通用寄存器分为以下三类:备份寄存器、未备份寄存器、程序计数器PC
未备份寄存器
未备份寄存器包括R0-R7。对于每一个未备份寄存器来说,所有处理器模式下都是使用同一个物理寄存器。未备份寄存器没有被系统用于特别的用途,任何可采用通用寄存器的场合都可以使用未备份寄存器。
备份寄存器
对于R8-R12备份寄存器来说,每个寄存器对应两个不同的物理寄存器。系统为将备份寄存器用于任何的特殊用途,但是当中断处理非常简单,仅仅使用R8-R14寄存器时,FIQ处理程序可以不必执行保存和恢复中断现场的指令,从而可以使中断处理非常迅速。
对于R13,R14备份寄存器来说,每个寄存器对应六个不同的物理寄存器,其中的一个是系统模式和用户模式共用的;另外的五个对应于其他的五种处理器模式。采用下面的记号来区分各个物理寄存器:
R13_<MODE>
其中MODE可以是下面几种模式之一:usr,svc,abt,und,irq,fiq
程序计数器PC
可以作为一般的通用寄存器使用,但有一些指令在使用R15时有一些限制。由于ARM采用了流水线处理器机制,当正确读取了PC的值时,该值为当前指令地址值加上8个字节。也就是说,对于ARM指令集来说,PC指向当前指令的下两条指令的地址。由于ARM指令是字对齐的,PC值的第0位和第一位总为0。
需要注意的是,当使用str/stm保存R15时,保存的可能是当前指令地址值加8个字节,也可能保存的是当前指令地址值加12个字节。到底哪种方式取决于芯片的具体设计。对于用户来说,尽量避免使用STR/STM指令来保存R15的值。
当成功的向R15写入一个数值时,程序将跳转到该地址执行。由于ARM指令是字对齐的,写入R15的值应满足bits[1:0]为0b00,具体要求arm个版本有所不同:
**对于arm3以及更低的版本,写入R15的地址值bits[1:0]被忽略,即写入r15的地址值将与0xFFFF FFFC做与操作。
**对于ARM4以及更高的版本,程序必须保证写入R15的地址值bits[1:0]为0b00,否则将产生不可预知的后果。
来自INTERNET
专栏文章内容及配图由作者撰写发布,仅供工程师学习之用,如有侵权或者其他违规问题,请联系本站处理。 联系我们
相关推荐
NEC Electronics SM+软件安装演示视频
高频电源高次谐波分析
NEC Electronics Applilet 软件安装演示视频
元核电协议目标为6.6GW的人工智能数据中心
LA4500 音响IC电路
全方位数据仓库解决方案 [转帖]
深圳AI工业赛道添新力!深圳市诚世凯科技有限公司获200万天使轮融资
信息技术应用创新专业人员(ITP)人才培养专项座谈会成功举办
嵌入式Web Server架构
嵌入式Linux上的Web Server设计
NEC Electronics C编译器软件安装演示视频
IP视频压缩协议H.263 [转帖]
LA4480 音响IC电路
英飞凌XENSIV第四代磁传感器支持最高达到ASIL B级要求的汽车功能安全应用
Microsoft 以智能零售自动化为目标,采用智能人工智能
鹏鲲量子科技算法驱动决策:AI技术如何革新传统代运营模式
TETRA数字无线集群系统应用 [转帖]
NEC Electronics 汇编器与PM+软件安装演示视频
LLVision发布 Leion Hey2 AR 翻译眼镜
NEC Electronics DEMO 演示视频
LA4476 音响IC电路
程序设计中的一些感悟
嵌入式uc/fs文件系统
LA4498 音响IC电路
嵌入式操作系统 uCOS-II 2.52 版源码
LMDS技术应用前景 [转帖]
嵌入式Linux上的Web Server设计(PDF)
财经观察:缺核心技术,印度新能源电池计划放缓
LA4497 音响IC电路
羽乐科技荣获新金融联盟“卓越价值贡献奖”,以数据智能赋能金融业高质量发展