共2条
1/1 1 跳转至页
ARM,R15 学习ARM的过程中碰到一个关于R15概念的问题。
问
学习ARM的过程中碰到一个关于R15概念的问题。
<<ARM体系结果与编程>>书中这么规定:
程序计数器R15又被记做PC,它虽然可以作为一般的通用寄存器使用,但在一些指令中R15又有一些特殊的限制。
当违反了这些限制,指令执行的结果不可预料。
数据的处理过程中常用格式:
<opcode > {<cond>} {s} <Rd>,<Rn>,<shifter_operand>
其中<shifter_operand>为第2操作数
当第2操作数为<Rm>,LSL #<shift_imm> 说明:当R15用做第1个源操作数Rn或者第2个操作数Rm时,操作数既为
当前指令地址+8。
当第2操作数为<Rm>,LSL <Rs> 说明:当R15用做Rn、Rm、Rd及Rs时,会产生不可预知的结果。
//=======================================================
我想提出的问题是:
1。R15在指令中使用的限制是怎么规定的?这些限制怎么来理解呢?
2。当第2操作数为<Rm>,LSL <Rs> 如果R15用做Rn、Rm、Rd及Rs时,会产生不可预知的结果。
怎么来理解这样的一个执行过程?
答 1: r15r15是pc指针用于指向下一条命令的地址,所以一般是不用它来做工作寄存器的,编程过程中只要不用她做工作寄存器就行了,留着那么多寄存器不用偏偏要用r15这不是自找麻烦吗!
<<ARM体系结果与编程>>书中这么规定:
程序计数器R15又被记做PC,它虽然可以作为一般的通用寄存器使用,但在一些指令中R15又有一些特殊的限制。
当违反了这些限制,指令执行的结果不可预料。
数据的处理过程中常用格式:
<opcode > {<cond>} {s} <Rd>,<Rn>,<shifter_operand>
其中<shifter_operand>为第2操作数
当第2操作数为<Rm>,LSL #<shift_imm> 说明:当R15用做第1个源操作数Rn或者第2个操作数Rm时,操作数既为
当前指令地址+8。
当第2操作数为<Rm>,LSL <Rs> 说明:当R15用做Rn、Rm、Rd及Rs时,会产生不可预知的结果。
//=======================================================
我想提出的问题是:
1。R15在指令中使用的限制是怎么规定的?这些限制怎么来理解呢?
2。当第2操作数为<Rm>,LSL <Rs> 如果R15用做Rn、Rm、Rd及Rs时,会产生不可预知的结果。
怎么来理解这样的一个执行过程?
答 1: r15r15是pc指针用于指向下一条命令的地址,所以一般是不用它来做工作寄存器的,编程过程中只要不用她做工作寄存器就行了,留着那么多寄存器不用偏偏要用r15这不是自找麻烦吗!
共2条
1/1 1 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| 基于MCP23S17的输入输出功能模块控制被打赏¥20元 | |
| 【S32K3XX】SPD 软件包使用Link文件修改被打赏¥22元 | |
| Switch-Case局部变量定义问题被打赏¥23元 | |
| 基于米尔TIAM62L开发板的串口通信及应用被打赏¥20元 | |
| PCF8574功能模块及其使用被打赏¥20元 | |
| 传感器LSM6DSO及LIS3MDL的功能检测被打赏¥18元 | |
| LPS25HB气压传感器及其检测被打赏¥18元 | |
| HTS221温湿度传感器及其检测被打赏¥18元 | |
| 【S32K3XX】HSE FW 版本更新被打赏¥21元 | |
| 基于ArduinoUNO开发板的AT24C02读写测试被打赏¥16元 | |
我要赚赏金
