共2条 1/1
1
跳转至
页
关于汇编指令查表功能,请看。。
问
;//功能:通过查表实现程序散转
NumCon EQU 0x40003001 ; 定义变量NumCn
AREA Example4,CODE,READONLY
ENTRY
MAIN LDR R0,= NumCon
LDRB R2,[R0] ; 取得跳转控制变量值
MOV R2,R2,LSL #2 ; 功能号乘上4,以便查表-------(1)
LDR PC,[PC,R2]; 查表取得对应功能子程序地址,并跳转
NOP -------(2)
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
END
问:如上标示的(1)(2)处,有点含糊,我没算准PC的跳转值,请指教,谢谢 答 1: 继续关注是不是太简单了还是。。。?
这个和三级流水线有关,对深入理解三级流水线有好处啊。 答 2: 裸奔肯定都累更不敢做纯A人 答 3: re 相对地址
LDR PC,[PC,R2]; 0
NOP 4
FUN_TAB DCD FUN_SUB0 8
三级流水线,取指、译码、执行,PC = 当前执行指令地址加8,所以加个NOP,不过这种依靠硬件的指令还是少用。如果将来流水线扩展了还得改程序。
直接用 FUN_TAB 得到地址也许更好些。
;//功能:通过查表实现程序散转
NumCon EQU 0x40003001 ; 定义变量NumCn
AREA Example4,CODE,READONLY
ENTRY
MAIN LDR R0,= NumCon
LDRB R2,[R0] ; 取得跳转控制变量值
MOV R2,R2,LSL #2 ; 功能号乘上4,以便查表-------(1)
LDR PC,[PC,R2]; 查表取得对应功能子程序地址,并跳转
NOP -------(2)
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
END
问:如上标示的(1)(2)处,有点含糊,我没算准PC的跳转值,请指教,谢谢 答 1: 继续关注是不是太简单了还是。。。?
这个和三级流水线有关,对深入理解三级流水线有好处啊。 答 2: 裸奔肯定都累更不敢做纯A人 答 3: re 相对地址
LDR PC,[PC,R2]; 0
NOP 4
FUN_TAB DCD FUN_SUB0 8
三级流水线,取指、译码、执行,PC = 当前执行指令地址加8,所以加个NOP,不过这种依靠硬件的指令还是少用。如果将来流水线扩展了还得改程序。
直接用 FUN_TAB 得到地址也许更好些。
共2条 1/1
1
跳转至
页
回复
有奖活动 | |
---|---|
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
【有奖活动】智能可穿戴设备AR/VR如何引领科技新潮流! | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
【有奖活动】震撼来袭!这场直播将直击工程师的心灵! |
打赏帖 | |
---|---|
如何实现基于NXPiMX.RT1021的BH1730采集被打赏5分 | |
玩转“DFRobot盖革计数器模块”准备工作认识模块知识分享被打赏30分 | |
【换取手持数字示波器】AHT10温度检测分享被打赏40分 | |
【换取手持数字示波器】ACM32F070开发板点亮LCD屏和触控按键,串口,ADC被打赏40分 | |
【换取手持数字示波器】ACM32F070LCD屏和触控按键功驱动蜂鸣器分享被打赏40分 | |
【换取手持数字示波器】国民技术PWM功能知识分享被打赏40分 | |
【换取手持数字示波器】放大器运放知识分享被打赏40分 | |
【分享评测,赢取加热台】+开关电源AC输入知识分享被打赏30分 | |
【换取手持数字示波器】N32G430点亮数码管与串口打印、ADC被打赏40分 | |
老胖子聊电路--分析一个反馈电路被打赏50分 |