共2条
1/1 1 跳转至页
LDR,PC,PC,R2 弱弱地问一下,LDR PC,[PC,R2]的执行结果是什么?
问
如果执行LDR PC,[PC,R2]之前,PC的值为0x0000800c,R2的值为0,
那么执行LDR PC,[PC,R2]之后,PC的值应该为0x0000800c中的数据
即PC = (PC + 0) = 0xe79ff002的,
可是,为什么实际上却是0x00008014中的数据,
即PC = (PC + 8) = (0x00008014) = 0x0x00008024
????
-----------------------------------------------------
源代码如下:
MAIN LDR R0,= NumCon
LDRB R2,[R0] ; 取得跳转控制变量值
MOV R2,R2,LSL #2 ; 功能号乘上4,以便查表
LDR PC,[PC,R2] ; 查表取得对应功能子程序地址,并跳转
NOP
FUN_TAB DCD FUN_SUB0 ; 跳转表
DCD FUN_SUB1
DCD FUN_SUB2
DCD FUN_SUB3
FUN_SUB0 B MAIN
FUN_SUB1 B MAIN
FUN_SUB2 B MAIN
FUN_SUB3 B MAIN
---------------------------------------------------
反汇编:
MAIN [0xe59f002c] ldr r0,0x00008034 ; = #0x40003001
00008004 [0xe5d02000] ldrb r2,[r0,#0]
00008008 [0xe1a02102] mov r2,r2,lsl #2
0000800c [0xe79ff002] ldr pc,[pc,r2]
00008010 [0xe1a00000] nop
FUN_TAB [0x00008024] dcd 0x00008024 $...
00008018 [0x00008028] dcd 0x00008028 (...
0000801c [0x0000802c] dcd 0x0000802c ,...
00008020 [0x00008030] dcd 0x00008030 0...
FUN_SUB0 [0xeafffff5] b MAIN
FUN_SUB1 [0xeafffff4] b MAIN
FUN_SUB2 [0xeafffff3] b MAIN
FUN_SUB3 [0xeafffff2] b MAIN
答 1: 流水线取指比执行超前了2个指令 答 2: 是真的吗?好佩服你,我没想到!
那么执行LDR PC,[PC,R2]之后,PC的值应该为0x0000800c中的数据
即PC = (PC + 0) = 0xe79ff002的,
可是,为什么实际上却是0x00008014中的数据,
即PC = (PC + 8) = (0x00008014) = 0x0x00008024
????
-----------------------------------------------------
源代码如下:
MAIN LDR R0,= NumCon
LDRB R2,[R0] ; 取得跳转控制变量值
MOV R2,R2,LSL #2 ; 功能号乘上4,以便查表
LDR PC,[PC,R2] ; 查表取得对应功能子程序地址,并跳转
NOP
FUN_TAB DCD FUN_SUB0 ; 跳转表
DCD FUN_SUB1
DCD FUN_SUB2
DCD FUN_SUB3
FUN_SUB0 B MAIN
FUN_SUB1 B MAIN
FUN_SUB2 B MAIN
FUN_SUB3 B MAIN
---------------------------------------------------
反汇编:
MAIN [0xe59f002c] ldr r0,0x00008034 ; = #0x40003001
00008004 [0xe5d02000] ldrb r2,[r0,#0]
00008008 [0xe1a02102] mov r2,r2,lsl #2
0000800c [0xe79ff002] ldr pc,[pc,r2]
00008010 [0xe1a00000] nop
FUN_TAB [0x00008024] dcd 0x00008024 $...
00008018 [0x00008028] dcd 0x00008028 (...
0000801c [0x0000802c] dcd 0x0000802c ,...
00008020 [0x00008030] dcd 0x00008030 0...
FUN_SUB0 [0xeafffff5] b MAIN
FUN_SUB1 [0xeafffff4] b MAIN
FUN_SUB2 [0xeafffff3] b MAIN
FUN_SUB3 [0xeafffff2] b MAIN
答 1: 流水线取指比执行超前了2个指令 答 2: 是真的吗?好佩服你,我没想到!
共2条
1/1 1 跳转至页
回复
| 有奖活动 | |
|---|---|
| 这个春节你犒赏自己什么了?分享你的故事,有奖征集 | |
| 2026年“我要开发板活动”第三季,开始了! | |
| 硬核工程师专属补给计划——填盲盒 | |
| “我踩过的那些坑”主题活动——第002期 | |
| 【EEPW电子工程师创研计划】技术变现通道已开启~ | |
| 发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
| 【EEPW在线】E起听工程师的声音! | |
| 高校联络员开始招募啦!有惊喜!! | |
我要赚赏金打赏帖 |
|
|---|---|
| 【S32K3XX】HSE 密钥管理被打赏¥17元 | |
| 【S32K3XX】Standby RAM的初始化流程被打赏¥18元 | |
| Gravity:中英文语音合成模块V2.0及其串口控制被打赏¥24元 | |
| 全彩色度变化图的绘制被打赏¥27元 | |
| 【FreeRtos】FreeRtos任务栈的生长方向管理方式被打赏¥20元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】LVGL添加输入设备:EC11旋转编码器被打赏¥39元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】RA8D1部署FreeRTOS+LVGL被打赏¥33元 | |
| 空气质量检测器设计与实现被打赏¥24元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】LWIP进行UDP、TCP、HTTP、MQTT功能联合测试被打赏¥41元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】RA8D1部署FreeRTOS+LWIP被打赏¥36元 | |
我要赚赏金
