OpenEdv-开源电子网

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

程序首地址

[复制链接]

90

主题

534

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1059
金钱
1059
注册时间
2017-4-12
在线时间
280 小时
发表于 2019-2-14 11:09:42 | 显示全部楼层 |阅读模式
1金钱
为什么程序从0x8000000 开始跑呢, 为什么不是0x00?

如图

如图

最佳答案

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

CPU只知道0x00000000放的资料是Vector Table. 这是Cortex M CPU的运行方式, 可以参考The Definitive Guide to ARM Cortex-M3, 为了迎合Cortex M的运行方式, STM32把Flash的内容映射到0x00000000, 给CPU读Vector Table. 0x8000000的功用是可以简单理解为程序(只是不全然是). Flash除了前面是Vector Table之外, 其他地方可以放代码或资料, 应该没有特别的限制.
穷不可怕,可怕的是穷的是我~~~
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

3

主题

259

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2317
金钱
2317
注册时间
2016-12-2
在线时间
354 小时
发表于 2019-2-14 11:09:43 | 显示全部楼层
烈日灼心 发表于 2019-2-14 14:50
CPU 从0x00最开始就注册中断? 程序的位置是0x8000000 是这样理解么?

CPU只知道0x00000000放的资料是Vector Table.
这是Cortex M CPU的运行方式, 可以参考The Definitive Guide to ARM Cortex-M3,

为了迎合Cortex M的运行方式, STM32把Flash的内容映射到0x00000000, 给CPU读Vector Table.
0x8000000的功用是可以简单理解为程序(只是不全然是).

Flash除了前面是Vector Table之外, 其他地方可以放代码或资料, 应该没有特别的限制.
回复

使用道具 举报

31

主题

2183

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
14424
金钱
14424
注册时间
2018-8-3
在线时间
1157 小时
发表于 2019-2-14 12:31:32 | 显示全部楼层
看下中文参考手册 有比较详细讲解的
啊哈~加油!!
回复

使用道具 举报

90

主题

534

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1059
金钱
1059
注册时间
2017-4-12
在线时间
280 小时
 楼主| 发表于 2019-2-14 13:11:54 | 显示全部楼层
翼行园子 发表于 2019-2-14 12:31
看下中文参考手册 有比较详细讲解的

  。。
穷不可怕,可怕的是穷的是我~~~
回复

使用道具 举报

70

主题

6761

帖子

0

精华

论坛大神

Rank: 7Rank: 7Rank: 7

积分
13118
金钱
13118
注册时间
2012-11-26
在线时间
3813 小时
发表于 2019-2-14 13:13:13 | 显示全部楼层
没有为什么,ST就是这么设计的
学无止境
回复

使用道具 举报

90

主题

534

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1059
金钱
1059
注册时间
2017-4-12
在线时间
280 小时
 楼主| 发表于 2019-2-14 13:45:49 | 显示全部楼层
jermy_z 发表于 2019-2-14 13:13
没有为什么,ST就是这么设计的

那之前的0x00到0x8000000 干嘛了?
穷不可怕,可怕的是穷的是我~~~
回复

使用道具 举报

90

主题

534

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1059
金钱
1059
注册时间
2017-4-12
在线时间
280 小时
 楼主| 发表于 2019-2-14 13:53:16 | 显示全部楼层
jermy_z 发表于 2019-2-14 13:13
没有为什么,ST就是这么设计的

网上查了一下,说是映射到0x00了 都可以访问中断向量、
穷不可怕,可怕的是穷的是我~~~
回复

使用道具 举报

32

主题

883

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4036
金钱
4036
注册时间
2015-11-14
在线时间
545 小时
发表于 2019-2-14 14:23:08 | 显示全部楼层
0x08000000是Flash的首地址
回复

使用道具 举报

3

主题

259

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2317
金钱
2317
注册时间
2016-12-2
在线时间
354 小时
发表于 2019-2-14 14:47:27 | 显示全部楼层
本帖最后由 sammy902583 于 2019-2-14 14:49 编辑

的确
0x08000000是Flash的首地址

程序不是从这边开始跑, Flash首位置放置的是Vector Table的内容, 会影射到内存0x00000000的地方.
CPU一开始会运行Reset Exception, 所以会去Vector Table抓Reset vector(也就是内存0x00000004)的内容, 得到CPU真正开始跑程序的位置.
回复

使用道具 举报

90

主题

534

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1059
金钱
1059
注册时间
2017-4-12
在线时间
280 小时
 楼主| 发表于 2019-2-14 14:50:46 | 显示全部楼层
sammy902583 发表于 2019-2-14 14:47
的确
0x08000000是Flash的首地址

CPU 从0x00最开始就注册中断? 程序的位置是0x8000000 是这样理解么?
穷不可怕,可怕的是穷的是我~~~
回复

使用道具 举报

3

主题

1907

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
4106
金钱
4106
注册时间
2018-8-14
在线时间
696 小时
发表于 2019-2-14 16:44:29 | 显示全部楼层
这是历史问题, st的cpu历史久远, 在flash还不能用作programming rom的年代, rom是放在地址0x0000的, 因为要区分开rom与flash, 所以flash就被定义为0x80000000去, 而用影射到地址0的放法把falsh作为programming rom
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-9 18:20

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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