stm32学习之:时钟频率-皇冠最新app版本

×
单片机 > 单片机程序设计 > 详情

stm32学习之:时钟频率

发布时间:2024-07-30 发布时间:
|

********************************
本学习笔记基于stm32固件库v3.0
使用芯片型号:stm32f103
开发环境:mdk
********************************
第一课 时钟频率
    stm32f103内部8m的内部震荡,经过倍频后最高可以达到72m。目前ti的m3系列芯片最高频率可以达到80m。
    在stm32固件库3.0中对时钟频率的选择进行了大大的简化,原先的一大堆操作都在后台进行。系统给出的函数为systeminit()。但在调用前还需要进行一些宏定义的设置,具体的设置在system_stm32f10x.c文件中。
文件开头就有一个这样的定义: 
//#define sysclk_freq_hse    hse_value 
//#define sysclk_freq_20mhz 20000000 
//#define sysclk_freq_36mhz 36000000 
//#define sysclk_freq_48mhz 48000000 
//#define sysclk_freq_56mhz 56000000 
#define sysclk_freq_72mhz 72000000
st 官方推荐的外接晶振是 8m,所以库函数的设置都是假定你的硬件已经接了 8m 晶振来运算的.以上东西就是默认晶振 8m 的时候,推荐的 cpu 频率选择.在这里选择了:
#define sysclk_freq_72mhz 72000000 
也就是103系列能跑到的最大值72m
然后这个 c文件继续往下看 
#elif defined sysclk_freq_72mhz 
const uint32_t systemfrequency         = sysclk_freq_72mhz;    
const uint32_t systemfrequency_sysclk = sysclk_freq_72mhz;    
const uint32_t systemfrequency_ahbclk = sysclk_freq_72mhz;    
const uint32_t systemfrequency_apb1clk = (sysclk_freq_72mhz/2);
const uint32_t systemfrequency_apb2clk = sysclk_freq_72mhz;
这就是在定义了cpu跑72m的时候,各个系统的速度了.他们分别是:硬件频率,系统时钟,ahb总线频率,apb1总线频率,apb2总线频率.再往下看,看到这个了: 
#elif defined sysclk_freq_72mhz 
static void setsysclockto72(void);
这就是定义 72m 的时候,设置时钟的函数.这个函数被 setsysclock ()函数调用,而
setsysclock ()函数则是被 systeminit()函数调用.最后 systeminit()函数,就是被你调用的了
所以设置系统时钟的流程就是: 
首先用户程序调用 systeminit()函数,这是一个库函数,然后 systeminit()函数里面,进行了一些寄存器必要的初始化后,就调用 setsysclock()函数. setsysclock()函数根据那个#define sysclk_freq_72mhz 72000000 的宏定义,知道了要调用setsysclockto72()这个函数,于是,就一堆麻烦而复杂的设置^然后,cpu跑起来了,而且速度是 72m. 虽然说的有点累赘,但大家只需要知道,用户要设置频率,程序中就做的就两个事情:

第一个: system_stm32f10x.c 中 #define sysclk_freq_72mhz 72000000 

第二个:调用systeminit()

关键字:stm32  时钟频率

『本文转载自网络,皇冠最新app版本的版权归原作者所有,如有侵权请联系删除』

热门文章 更多
stm32问题记录:这回keil编译器背锅
网站地图