共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 跳转至页
回复
有奖活动 | |
---|---|
【EEPW电子工程师创研计划】技术变现通道已开启~ | |
发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
【EEPW在线】E起听工程师的声音! | |
“我踩过的那些坑”主题活动——第001期 | |
高校联络员开始招募啦!有惊喜!! | |
【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
送您一块开发板,2025年“我要开发板活动”又开始了! | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
【我踩过的那些坑】结构堵孔导致的喇叭无声问题被打赏50分 | |
【我踩过的那些坑】分享一下调试一款AD芯片的遇到的“坑”被打赏50分 | |
电流检测模块MAX4080S被打赏10分 | |
【我踩过的那些坑】calloc和malloc错误使用导致跑飞问题排查被打赏50分 | |
多组DCTODC电源方案被打赏50分 | |
【我踩过的那些坑】STM32cubeMX软件的使用过程中的“坑”被打赏50分 | |
新手必看!C语言精华知识:表驱动法被打赏50分 | |
【我踩过的那些坑】杜绑线问题被打赏50分 | |
【我踩过的那些坑】STM32的硬件通讯调试过程的“坑”被打赏50分 | |
【我踩过的那些坑】晶振使用的问题被打赏100分 |