OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 6245|回复: 12

这段汇编应该如何理解,会覆盖PC吗?

[复制链接]

26

主题

84

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
359
金钱
359
注册时间
2019-6-11
在线时间
52 小时
发表于 2021-8-5 23:54:57 | 显示全部楼层 |阅读模式
1金钱
大佬们,请问一下:
ldr pc, =Reset_Handler /* 复位中断 */
ldr pc, =Undefined_Handler /* 未定义指令中断 */
ldr pc, =SVC_Handler /* SVC(Supervisor)中断*/
ldr pc, =PrefAbort_Handler /* 预取终止中断 */
ldr pc, =DataAbort_Handler /* 数据终止中断 */
ldr pc, =NotUsed_Handler /* 未使用中断 */
ldr pc, =IRQ_Handler /* IRQ 中断 */
ldr pc, =FIQ_Handler /* FIQ(快速中断) */
右侧的标号地址给pc,有这么多pc吗?应该如何理解这一段话,帮忙诠释一下谢谢。

最佳答案

查看完整内容[请看2#楼]

研究明白了,首先芯片会有一个中断向量表的寄存器,默认情况下,芯片的中断向量表基地址是地址0,芯片上电,会先执行0地址,也就是ldr pc, =Reset_Handler这条语句,会发生跳转到复位中断,复位中断中会直接跳到main应用代码处,所以以下 ldr pc, =Undefined_Handler /* 未定义指令中断 */ ldr pc, =SVC_Handler /* SVC(Supervisor)中断*/ ldr pc, =PrefAbort_Handler /* 预取终止中断 */ ldr pc, =DataAbort_Handler /* 数据 ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

26

主题

84

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
359
金钱
359
注册时间
2019-6-11
在线时间
52 小时
 楼主| 发表于 2021-8-5 23:54:58 | 显示全部楼层
研究明白了,首先芯片会有一个中断向量表的寄存器,默认情况下,芯片的中断向量表基地址是地址0,芯片上电,会先执行0地址,也就是ldr pc, =Reset_Handler这条语句,会发生跳转到复位中断,复位中断中会直接跳到main应用代码处,所以以下
ldr pc, =Undefined_Handler /* 未定义指令中断 */
ldr pc, =SVC_Handler /* SVC(Supervisor)中断*/
ldr pc, =PrefAbort_Handler /* 预取终止中断 */
ldr pc, =DataAbort_Handler /* 数据终止中断 */
ldr pc, =NotUsed_Handler /* 未使用中断 */
ldr pc, =IRQ_Handler /* IRQ 中断 */
ldr pc, =FIQ_Handler /* FIQ(快速中断) */

并没有被执行。
当再运行应用代码图中发生比如Undefined_Handler中断,因为它再中断向量表中偏移是固定的,是芯片属性决定的。因为上面说了,中断向量表基地址是0,那么再加上这个Undefined_Handler再中断向量表偏移正好跳转到绝对地址0x04也就是ldr pc, =Undefined_Handler 语句处,pc被赋值没发生跳转到Undefined_Handler 异常处理函数。

这一流程下来就是原理,其实并没有覆盖写PC,而是没有执行复位以下那些代码,只有发生异常才会执行。
回复

使用道具 举报

0

主题

201

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2552
金钱
2552
注册时间
2019-12-5
在线时间
352 小时
发表于 2021-8-6 09:50:46 | 显示全部楼层
这个应该是中断向量表,如果 ldr pc, =Reset_Handler /* 复位中断 */ 执行后,PC的值就变了,不会继续执行第二条了。
回复

使用道具 举报

26

主题

84

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
359
金钱
359
注册时间
2019-6-11
在线时间
52 小时
 楼主| 发表于 2021-8-7 00:16:35 | 显示全部楼层
watsonxia 发表于 2021-8-6 09:50
这个应该是中断向量表,如果 ldr pc, =Reset_Handler /* 复位中断 */ 执行后,PC的值就变了,不会继续执行 ...

那请问,像你说的去执行复位中断了,下面的赋值有啥意义呢?
回复

使用道具 举报

3

主题

1906

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4100
金钱
4100
注册时间
2018-8-14
在线时间
695 小时
发表于 2021-8-7 12:00:57 | 显示全部楼层
lvye 发表于 2021-8-7 00:16
那请问,像你说的去执行复位中断了,下面的赋值有啥意义呢?

ldr pc==xxxxx 等同于 b xxxxx 或者 c言语的 goto xxxxx
回复

使用道具 举报

26

主题

84

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
359
金钱
359
注册时间
2019-6-11
在线时间
52 小时
 楼主| 发表于 2021-8-7 14:30:03 | 显示全部楼层
edmund1234 发表于 2021-8-7 12:00
ldr pc==xxxxx 等同于 b xxxxx 或者 c言语的 goto xxxxx

大佬这个回答是?
回复

使用道具 举报

26

主题

84

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
359
金钱
359
注册时间
2019-6-11
在线时间
52 小时
 楼主| 发表于 2021-8-7 16:44:42 | 显示全部楼层
watsonxia 发表于 2021-8-6 09:50
这个应该是中断向量表,如果 ldr pc, =Reset_Handler /* 复位中断 */ 执行后,PC的值就变了,不会继续执行 ...

大佬,我研究明白了,你其实说得对,只不过说的一半啊。哈哈非常感谢。
回复

使用道具 举报

0

主题

201

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2552
金钱
2552
注册时间
2019-12-5
在线时间
352 小时
发表于 2021-8-9 10:11:42 | 显示全部楼层
edmund1234 发表于 2021-8-7 12:00
ldr pc==xxxxx 等同于 b xxxxx 或者 c言语的 goto xxxxx

对的。
回复

使用道具 举报

0

主题

201

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2552
金钱
2552
注册时间
2019-12-5
在线时间
352 小时
发表于 2021-8-9 10:12:39 | 显示全部楼层
lvye 发表于 2021-8-7 16:44
大佬,我研究明白了,你其实说得对,只不过说的一半啊。哈哈非常感谢。

那就请把你的正确答案补充上来吧
回复

使用道具 举报

3

主题

1906

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4100
金钱
4100
注册时间
2018-8-14
在线时间
695 小时
发表于 2021-8-9 10:39:21 | 显示全部楼层
lvye 发表于 2021-8-5 23:54
研究明白了,首先芯片会有一个中断向量表的寄存器,默认情况下,芯片的中断向量表基地址是地址0,芯片上电 ...

你这叫研究的不明不白, 首先地址不一定是零, 要看什么芯片, 其次向量表的首个向量不是Reset_Handler, 而是栈的初始赋值。之后才是Reset_Handler
回复

使用道具 举报

1

主题

16

帖子

0

精华

初级会员

Rank: 2

积分
133
金钱
133
注册时间
2018-8-21
在线时间
18 小时
发表于 2021-8-10 17:21:53 | 显示全部楼层
看下反汇编就能明白
回复

使用道具 举报

26

主题

84

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
359
金钱
359
注册时间
2019-6-11
在线时间
52 小时
 楼主| 发表于 2021-8-11 23:21:43 | 显示全部楼层
edmund1234 发表于 2021-8-9 10:39
你这叫研究的不明不白, 首先地址不一定是零, 要看什么芯片, 其次向量表的首个向量不是Reset_Handler, ...

我说的不严谨。你说得对。
回复

使用道具 举报

0

主题

201

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2552
金钱
2552
注册时间
2019-12-5
在线时间
352 小时
发表于 2021-8-12 09:36:45 | 显示全部楼层
lvye 发表于 2021-8-7 16:44
大佬,我研究明白了,你其实说得对,只不过说的一半啊。哈哈非常感谢。

我说的没错,只是你没能够理解。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2024-11-25 17:55

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表