你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

基于STM32F1系列启动过程经验分享

[复制链接]
攻城狮Melo 发布时间:2023-5-14 16:42
STM32启动过程简单讲解
STM32F1采用ARM-Cortex-M3内核,对于他的启动以及复位,时钟系统,都是紧密联系的。以下内容对你对模块的操作帮助可能不太大,但对于你理解其工作模式是有帮助的,对于只想要简单使用单一模块的建议可以不看

但是如果要深入了解,那你就要听我哔哔了。我对于时钟系统也是说一下自己知道的,毕竟官方手册中文版讲的很明白了,只需要稍稍解释一下即可。


1.如何启动
ARM-CM3处理器结构为哈佛结构,哈佛结构是一种将程序指令存储和数据存储分开的存储器结构。 哈佛结构是一种并行体系结构,它的主要特点是将程序和数据存储在不同的存储空间中,即程序存储器和数据存储器是两个独立的存储器,每个存储器独立编址、独立访问。

8211f5d2bdb7407b82aeffd5bc25e534.png

数据和程序指令的存储是分开的,芯片主要获取指令来执行,指令是由ARM公司固定好的可以被芯片识别的指令,同时这个指令在我们单片机编译时由编译工具链(ToolChains)来生成。

3b696189d08b4a7cbc1ae166ebaec8f8.png


上图为各种内核支持的指令集

在我们上电的一刹那,单片机就已经触发了复位异常,芯片接着在中断向量表中查找我们的异常指令(如下图的复位异常),进行偏移位置,获取其中内容执行。

9b4a00ffdb024f358ace20458b53a9b1.png

也就是说,我们可以修改复位异常内的内容,让处理器执行我们的程序。

%]$VFYOL2ZAOB{LOSMU)HHT.png

2.启动配置
通过阅读STM32中文参考手册2.4启动配置,我们可以看到有三种启动方式,

3697c0c9ea1c4e68b44a51efd82ad4bd.png

我们通过改BOOT引脚高低电平状态来使我们的实际的物理存储地址映射到不同存储器的零地址中,BOOT引脚我们是可以在开发板上看到的,下面拿手头的开发板拍一下

865c578918c741628c28f795aa56d273.jpg
cf4c274e6c744eae81c624594bad68da.jpg

原理图如下:这里也说明了其启动方式

776db5c413014837b2ee6d2e05283a6e.png

再继续阅读,我们发现后续是映射到不同存储器的启动空间(实际上是起始的地址)。

D0J422SP%3KVWA5@Q[L1D_T.png

我们当然首选主闪存存储器,因为他是可以长期保持数据器件,拿SRAM静态随机存储器做个对比,SRAM断电后就数据就不存在了,而FLASH烧录之后就会固化到我们的存储器里,可以保持很长时间,就相当于手机上的ROM,保存我们的文件图;而SRAM就是手机的RAM,手机上能运行多少程序主要看他有多大。
在生成好的任一工程文件的启动文件(startup_stm32f103xb.s)里你都可以看到我之前提及的中断向量表配置,

c7f50fce581541a9a3ccaafbd4658162.png

启动文件开头就介绍了他的用途
1.初始化堆栈指针
2.设置PC指针值
3.设置中断向量表
4.配置系统时钟
5.调用C库函数__main,最终会跳到我们自己的main函数

之后的DCD就是分配以字节为单位的空间,我们可以看到第一个就是TOP of Stack(堆栈的指针头),第二个就复位异常中断处理,之后便是一系列分配空间,用来准备空间执行我们的程序。

c6ad5acaa605457a9420e7bfee14785f.png

这里还有很多需要我们查看的地方,有很大部分还使用了汇编语言,大家可以参考手册,并用KEIL的Help–> uVision Help进行索引查找。(不过是全英文)

3de881bc0535437a95bd5e7b0d95b711.png
————————————————
版权声明:南山笑
如有侵权请联系删除


收藏 评论0 发布时间:2023-5-14 16:42

举报

0个回答

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版