微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > ARM体系结构学习2

ARM体系结构学习2

时间:11-21 来源:互联网 点击:

其他5种不同的运行模式,并采用以下记号来区分不同的物理寄存器:

R13_

R14_

其中mode可为:usr,fiq,irq,svc,abt,und.

通用寄存器的特殊用途:?

寄存器R13在ARM指令中常用作堆栈指针SP,但这只是一种习惯用法,用户也可使用其他的寄存器作为堆栈指针,而在Thumb指令集中,某些指令强制性的要求使用R13作为堆栈指针.芯片中的寄存器是稳定的,不会出现问题的。

由于处理器的每种运行模式均有自己独立的物理寄存器R13,在用户应用程序的初始化部分,一般都要初始化每种模式下的R13,使其指向该运行模式的栈空间。这样,当程序的运行进入异常模式时,可以将需要保护的寄存器放入R13所指向的堆栈,而当程序从异常模式返回时,则从对应的堆栈中恢复,采用这种方式可以保证异常发生后程序的正常执行。

R14称为子程序链接寄存器LR(Link Register),当执行子程序调用指令(BL)时,R14可得到R15(程序计数器PC)的备份.

在每一种运行模式下,都可用R14保存子程序的返回地址,当用BL或BLX指令调用子程序时,将PC的当前值复制给R14,执行完子程序后,又将R14的值复制回PC,即可完成子程序的调用返回。以上的描述可用指令完成。

执行以下任意一条指令:

MOV PC, LR

BX LR

在子程序入口处使用以下指令将R14存入堆栈:

STMFD SP!,{,LR}

对应的,使用以下指令可以完成子程序返回:

LDMFD SP!,{,PC}

R14也可作为通用寄存器。

3,程序计数器PC(R15)

寄存器R15用作程序计数器(PC),永远指向取指的指令地址,在ARM状态下,位[1:0]为0,位[31:2]用于保存PC,在Thumb状态下,位[0]为0,位[31:1]用于保存PC.

由于ARM体系结构采用了多级流水线技术,对于ARM指令集而言,PC总是指向当前指令的下两条指令的地址,即PC的值为当前指令的地址值加8个字节程序状态寄存器

不同工作模式下的通用寄存器的区别:

usr/sys:R0-R15二者共用?

?

irq: R0-12,R15没有区别

R13-irq

R14??-irq

svc:?R0-12,R15没有区别

R13-svc

R14??-svc

und:同上

abt:同上?

fiq:?R0-R7,R15没有区别

R9-fiq,R10-fiq,R11-fiq,R12-fiq,R13-fiq,R14-fiq?

?7种工作模式下,寄存器使用情况

4.寄存器R16

寄存器R16用作CPSR(CurrentProgram Status Register,当前程序状态寄存器),CPSR可在任何运行模式下被访问,它包括条件标志位、中断禁止位、当前处理器模式标志位,以及其他一些相关的控制和状态位。

每一种异常运行模式下又都有一个专用的物理状态寄存器,称为SPSR(Saved Program Status Register,备份的程序状态寄存器),当异常发生时,SPSR用于保存CPSR的当前值,从异常退出时则可由SPSR来恢复CPSR。

由于用户模式和系统模式不属于异常模式,它们没有SPSR,当在这两种模式下访问SPSR,结果是未知的。?

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top