共2条
1/1 1 跳转至页
LPC2114,BOOT 请问一下周工LPC2114 BOOT代码的一个问题
问
177: LDR SP, =StackUsr
0x00000090 E59FD028 LDR R13,[PC,#0x0028]
可是 在指定的位置 0x90 + 0x28 的 地址上的 值是 4000069c
-----------------------------------------------------------
225: StackFiq DCD FiqStackSpace + (FIQ_STACK_LEGTH - 1)* 4
0x000000B4 4000069C MULMI R0,R12,R6
226: StackAbt DCD AbtStackSpace + (ABT_STACK_LEGTH - 1)* 4
0x000000B8 4000069C MULMI R0,R12,R6
227: StackUnd DCD UndtStackSpace + (UND_STACK_LEGTH - 1)* 4
0x000000BC 4000069C MULMI R0,R12,R6
257: AREA MyStacks, DATA, NOINIT, ALIGN=2
0x000000C0 40004000 ANDMI R4,R0,R0
--------------------------------------------------------------
在 后面2个字长的指令 后才是想要的值 0x40004000
为什么呢??? 我用ADS, KEIL仿真器 答 1: 这个流水线技术的原因!虽然你的正在执行的指令在地址0x00000090处,但是这时PC指是指的三级流水线上的预取指指令,所以应该真实的PC值时0x00000090+0x00000008
177: LDR SP, =StackUsr
0x00000090 E59FD028 LDR R13,[PC,#0x0028]
可是 在指定的位置 0x90 + 0x28 的 地址上的 值是 4000069c
-----------------------------------------------------------
225: StackFiq DCD FiqStackSpace + (FIQ_STACK_LEGTH - 1)* 4
0x000000B4 4000069C MULMI R0,R12,R6
226: StackAbt DCD AbtStackSpace + (ABT_STACK_LEGTH - 1)* 4
0x000000B8 4000069C MULMI R0,R12,R6
227: StackUnd DCD UndtStackSpace + (UND_STACK_LEGTH - 1)* 4
0x000000BC 4000069C MULMI R0,R12,R6
257: AREA MyStacks, DATA, NOINIT, ALIGN=2
0x000000C0 40004000 ANDMI R4,R0,R0
--------------------------------------------------------------
在 后面2个字长的指令 后才是想要的值 0x40004000
为什么呢??? 我用ADS, KEIL仿真器 答 1: 这个流水线技术的原因!虽然你的正在执行的指令在地址0x00000090处,但是这时PC指是指的三级流水线上的预取指指令,所以应该真实的PC值时0x00000090+0x00000008
共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元 | |
我要赚赏金
