共2条
1/1 1 跳转至页
那么原处于译码状态的指令(指令2不是被丢弃了吗?)
问
例子:
地址 指令 说明
0x00001000 指令1 被执行(执行后有中断)
0x00001004 指令2 被译码
0x00001008 指令3 被取指(pc=00001008)
0x0000100c 指令4
中断时LR中保存下一条指令的地址当前PC+4(即0000100c)
退出中断时将LR中的值减去偏移量后移入PC
即PC(00001008)=0000100c-4
那么原处于译码状态的指令(指令2不是被丢弃了吗?)
答 1: 是的,执行完当前正在执行的指令马上转移,顾不上后面的LR中保存下一条指令的地址当前PC+4 ?
LR 中是保存的 PC 值,而PC值为当前执行指令的前两个指令,也就是取指地址。
地址 指令 说明
0x00001000 指令1 被执行(执行后有中断)
0x00001004 指令2 被译码
0x00001008 指令3 被取指(pc=00001008)
0x0000100c 指令4
中断时LR中保存下一条指令的地址当前PC+4(即0000100c)
退出中断时将LR中的值减去偏移量后移入PC
即PC(00001008)=0000100c-4
那么原处于译码状态的指令(指令2不是被丢弃了吗?)
答 1: 是的,执行完当前正在执行的指令马上转移,顾不上后面的LR中保存下一条指令的地址当前PC+4 ?
LR 中是保存的 PC 值,而PC值为当前执行指令的前两个指令,也就是取指地址。
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
vscode+cmake搭建雅特力AT32L021开发环境被打赏30分 | |
【换取逻辑分析仪】自制底板并驱动ArduinoNanoRP2040ConnectLCD扩展板被打赏47分 | |
【分享评测,赢取加热台】RISC-V GCC 内嵌汇编使用被打赏38分 | |
【换取逻辑分析仪】-基于ADI单片机MAX78000的简易MP3音乐播放器被打赏48分 | |
我想要一部加热台+树莓派PICO驱动AHT10被打赏38分 | |
【换取逻辑分析仪】-硬件SPI驱动OLED屏幕被打赏36分 | |
换逻辑分析仪+上下拉与多路选择器被打赏29分 | |
Let'sdo第3期任务合集被打赏50分 | |
换逻辑分析仪+Verilog三态门被打赏27分 | |
换逻辑分析仪+Verilog多输出门被打赏24分 |