完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
本文用的是标准库,先给出时钟配置代码,代码在system_stm32f10x.c里面。
首先定义最终系统频率72MHz: 如果是其他频率把72的注释掉,打开你想配置的频率。这个频率并不会影响实际的设置,而只是指明了当前频率。如果定义了SYSCLK_FREQ_72MHz,会编译以下两部分: SystemCoreClock是一个全局变量,表示当前系统时钟频率。 由上图看到实际会编译SetSysClockTo72()这个函数。 在这个函数内部,最重要的有两个寄存器设置: 此处注意,F105/107属于互联型,启动文件为 startup_stm32f10x_cl.s且必须宏定义STM32F10X_CL 在这里互联型芯片系统默认外部高速时钟是25MHz,由于一个CFGR寄存器是无法倍频到72MHz的,所以互联型芯片有两个CFGR寄存器,首先对时钟源进行分频与倍频的是CFGR2寄存器,所以先要设置CFGR2寄存器,在上图里,对外部高速时钟进行的配置是: 25/5*8=40MHz这个是PLL2CLK的频率 PLL2CLK/5=8MHz这个是PREDIV1CLK的频率 在分析时钟时我们借用CubeMx可以更加直观: 可以看到经过CFGR2寄存器对HSE操作后,我们得到了一个8MHz的时钟源,接下来只要把8X9=72MHz即可,这可以通过设置CFGR寄存器得到。 下面举个例子,假如我们外部高速时钟是8MHz,我们怎么得到72MHz的系统时钟: 首先我们可以直接用CubeMx来生成我们需要的分频与倍频: 把HSE时钟改为8MHz,把系统时钟改为72MHz,得到下面设置: 可以看到只改动了两个地方。对照代码我们做以下修改: 至此,F105时钟修改完成。 附寄存器定义: CFGR2: CFGR: |
|
|
|
只有小组成员才能发言,加入小组>>
调试STM32H750的FMC总线读写PSRAM遇到的问题求解?
1627 浏览 1 评论
X-NUCLEO-IHM08M1板文档中输出电流为15Arms,15Arms是怎么得出来的呢?
1550 浏览 1 评论
984 浏览 2 评论
STM32F030F4 HSI时钟温度测试过不去是怎么回事?
688 浏览 2 评论
ST25R3916能否对ISO15693的标签芯片进行分区域写密码?
1601 浏览 2 评论
1867浏览 9评论
STM32仿真器是选择ST-LINK还是选择J-LINK?各有什么优势啊?
650浏览 4评论
STM32F0_TIM2输出pwm2后OLED变暗或者系统重启是怎么回事?
518浏览 3评论
536浏览 3评论
stm32cubemx生成mdk-arm v4项目文件无法打开是什么原因导致的?
506浏览 3评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-24 10:23 , Processed in 1.129886 second(s), Total 75, Slave 59 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号