有个问题,希望大家能指点指点,谢谢先!
关于 LDR Rd,label
我在书上看到的解释是这样的:
程序相对偏移。程序相对偏移是前索引偏移形式的另一个版本。汇编器由PC寄存器计算偏移量,并将PC寄存器作为Rn生成前索引指令,不能使
用后缀"!"。
书上说的前索引偏移。 在数据传送之前,将偏移量加到Rn中,其结果作为传送数据的存储地址。
LDR Rd, [Rn, #0x0x]!
然后,我在看了这样的代码的时候:
ENTRY
INT_Entry ; INT_Entry 的符号地址为 0x2000000
LDR pc, (Vect_Table) ; 该处地址为0x2000000
LDR pc, (Vect_Table + 4) ;
LDR pc, (Vect_Table + 8) ;
nop;
LDR pc, (Vect_Table +16) ;
LDR pc, (Vect_Table +20)
LDR pc, (Vect_Table +24) ; IRQ
LDR pc, (Vect_Table +28) ;
Vect_Table ; Vect_Table 的符号地址为 0x2000020
DCD INITIAL ; reset
DCD undefvec ; Undefined Instruction
DCD swivec ; Software Interrupt
DCD pabtvec ; Prefetch Abort
DCD dabtvec ; Data Abort
DCD rsvdvec ; reserved
DCD INT_IRQ ; reserved
DCD INT_FIQ ; reserved
我这样理解 LDR pc, (Vect_Table) 这一句了: 把地址( 0x2000000 + 0x2000020 )的值 给pc寄存器。
这样好像是不对的,该怎么理解 LDR 指令的这样用法呢?
共5条
1/1 1 跳转至页
谢谢 twentyone,
LDR pc, (Vect_Table) ; 我把它理解为把 Vect_Table 的第一项的值取来给PC,(即INTIAL的地址给PC)。
其实在这段代码之后,还会把这部分中断入口代码 copy 到 0地址处(包括Vect_Table部分)。
这样的话,memory里面,岂不是有两个Vect_Tale部分了, 我就困惑了:
LDR pc, (Vect_Table) 的时候它怎么知道是根据哪个 Vect_Table 呢,是根据0x000020处的Vect_Table呢,还是根据0x2000020处的Vect_Table呢????
LDR pc, (Vect_Table) ; 我把它理解为把 Vect_Table 的第一项的值取来给PC,(即INTIAL的地址给PC)。
其实在这段代码之后,还会把这部分中断入口代码 copy 到 0地址处(包括Vect_Table部分)。
这样的话,memory里面,岂不是有两个Vect_Tale部分了, 我就困惑了:
LDR pc, (Vect_Table) 的时候它怎么知道是根据哪个 Vect_Table 呢,是根据0x000020处的Vect_Table呢,还是根据0x2000020处的Vect_Table呢????
共5条
1/1 1 跳转至页
回复
| 有奖活动 | |
|---|---|
| 硬核工程师专属补给计划——填盲盒 | |
| “我踩过的那些坑”主题活动——第002期 | |
| 【EEPW电子工程师创研计划】技术变现通道已开启~ | |
| 发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
| 【EEPW在线】E起听工程师的声音! | |
| 高校联络员开始招募啦!有惊喜!! | |
| 【工程师专属福利】每天30秒,积分轻松拿!EEPW宠粉打卡计划启动! | |
| 送您一块开发板,2025年“我要开发板活动”又开始了! | |
我要赚赏金打赏帖 |
|
|---|---|
| 在FireBeetle2ESP32-C5上实现温湿度检测和显示被打赏¥20元 | |
| 在FireBeetle2ESP32-C5上实现光照强度检测及显示被打赏¥21元 | |
| 以FireBeetle2ESP32-C5实现数据识读播报被打赏¥19元 | |
| 【STM32F103ZET6】14:实测STM32F1的串口输出任务的挂起与恢复功能被打赏¥27元 | |
| Chaos-nano在压力容器监控系统中的项目应用被打赏¥23元 | |
| 基于FireBeetle2ESP32-C5的WS2812B彩色灯带控制被打赏¥21元 | |
| SWM221CBT7显示开发板驱动TFT显示屏被打赏¥19元 | |
| SWM221CBT7显示开发板驱动OLED屏显示被打赏¥19元 | |
| SWM221CBT7显示开发板及其使用被打赏¥20元 | |
| 揭秘Chaos-nano:ArduinoProMini轻量级操作系统开发框架深度解析与实战应用被打赏¥19元 | |
我要赚赏金
