共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 跳转至页
回复
打赏帖 | |
---|---|
宏定义和const关键字定义被打赏5分 | |
【功率监测与控制系统DIY活动成果贴】DIY功率计与LabVIEW数据采集被打赏100分 | |
【Freertos】任务管理被打赏10分 | |
分享博世的两种不同的喷射系统模式被打赏5分 | |
汽车+开路实验与短路实验被打赏10分 | |
多点式电子控制汽油喷射系统知识分享被打赏10分 | |
分享机械控制式汽油喷射系统被打赏5分 | |
【分享开发笔记,赚取电动螺丝刀】解决基于CH341制作无线模块时芯片发热问题被打赏31分 | |
【分享开发笔记,赚取电动螺丝刀】使用STM32F103ZE主控调试RS485通讯的避坑经验被打赏36分 | |
【分享开发笔记,赚取电动螺丝刀】移植xprintf模块被打赏27分 |