共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 跳转至页
回复
我要赚赏金打赏帖 |
|
|---|---|
| 基于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元 | |
我要赚赏金
