当前位置: 首页 > news >正文

STM32入门笔记(05):内部高速8Mhz时钟最大时钟可以设置 64 Mhz?如何修改system_stm32f10x.c里面的代码?

6.2 Clocks
在这里插入图片描述

在这里插入图片描述


最大系统时钟频率

当 STM32F103 系列仅使用内部高速振荡器(HSI,8 MHz)作为时钟源,并通过 PLL 放大时,最大可达 64 MHz。([forum.mikroe.com][1], [keil.com][2])

  • HSI 被内部除以 2(即 4 MHz)后输入 PLL,PLL 最多可设置到 ×16,因此最大输出时钟为 4 MHz × 16 = 64 MHz。([forum.mikroe.com][1])
  • 如果不使用 PLL,直接用 HSI 作为系统时钟,则只能运行在 8 MHz。([Medium][3])

修改步骤概览

要在 system_stm32f10x.c 中去掉外部 8 MHz 晶振(HSE),并改用 HSI/2 → PLL → 64 MHz,需要:

  1. 在预编译宏中定义新的选择:

    #define SYSCLK_USE_HSI_PLL
    
  2. SystemCoreClock 的初始值分支里添加对应项:

    #ifdef SYSCLK_USE_HSI_PLLuint32_t SystemCoreClock = 64000000;  // 64 MHz
    #elif defined SYSCLK_FREQ_72MHz#endif
    
  3. SetSysClock() 的分支调度中增加 HSI_PLL 路径:

    static void SetSysClock(void)
    {#elif defined SYSCLK_USE_HSI_PLLSetSysClockToHSI_PLL();
    #endif
    }
    
  4. 新增并实现 SetSysClockToHSI_PLL() 函数,用来配置 PLL 源为 HSI/2,倍乘因子为 16:

    static void SetSysClockToHSI_PLL(void)
    {// 1. 确保 HSI 已开启并稳定RCC->CR |= RCC_CR_HSION;while (!(RCC->CR & RCC_CR_HSIRDY)) {}// 2. 配置 PLL 源:HSI/2, 倍频 ×16RCC->CFGR &= ~(RCC_CFGR_PLLSRC | RCC_CFGR_PLLMULL);RCC->CFGR |= RCC_CFGR_PLLSRC_HSI_Div2    // PLL 时钟源 = HSI/2| RCC_CFGR_PLLMULL16;         // PLL 倍频因子 = 16// 3. 启动 PLL 并等待就绪RCC->CR |= RCC_CR_PLLON;while (!(RCC->CR & RCC_CR_PLLRDY)) {}// 4. 选择 PLL 作为系统时钟源RCC->CFGR &= ~RCC_CFGR_SW;RCC->CFGR |= RCC_CFGR_SW_PLL;while ((RCC->CFGR & RCC_CFGR_SWS) != RCC_CFGR_SWS_PLL) {}// 5. 设置总线预分频:AHB = /1, APB1 = /2, APB2 = /1RCC->CFGR &= ~(RCC_CFGR_HPRE | RCC_CFGR_PPRE1 | RCC_CFGR_PPRE2);RCC->CFGR |= RCC_CFGR_PPRE1_DIV2; // APB1 ≤36MHz// 6. 配置 Flash 延时为 2 WS (64MHz 下至少需 2 WS)FLASH->ACR &= ~FLASH_ACR_LATENCY;FLASH->ACR |= FLASH_ACR_LATENCY_2;
    }
    
    • 以上配置最终使得:SYSCLK = PLLCLK = 64 MHzHCLK = 64 MHzPCLK2 = 64 MHzPCLK1 = 32 MHz(符合 APB1 ≤ 36 MHz 要求)。([keil.com][2])

关键寄存器说明

  1. RCC->CR

    • HSION (bit0):开启内部振荡器。
    • HSIRDY (bit1):HSI 就绪标志。
    • PLLON (bit24):开启 PLL。
    • PLLRDY (bit25):PLL 就绪标志。
  2. RCC->CFGR

    • SW(bits1:0):系统时钟切换;00=HSI10=PLL
    • SWS(bits3:2):时钟源就绪标志。
    • PLLSRC(bit16):PLL 源选择;0=HSI/21=HSE
    • PLLMULL(bits21:18):PLL 倍频因子;1110 对应 ×16。
    • HPREPPRE1PPRE2:AHB/APB 预分频。
  3. FLASH->ACR

    • LATENCY(bits2:0):Flash 访问延时周期;在 48–72 MHz 下至少要 2 WS(值 010)。

以上即为使用内部 8 MHz 时钟、最大可达 64 MHz 的配置方案,并附上关键代码修改示例。


资料下载

  • STM32F103C8T6-72Mhz外部晶振改64Mhz内部高速时钟.rar

参考资料

  • [1] STM32F103C8T6标准库修改内部时钟以及去除32最小系统板上的8MHZ和32.768KHZ外部晶振
  • [2] 【Github】NordicPlayground/mbed
http://www.dtcms.com/a/191115.html

相关文章:

  • 基于OAuth2+SpringSecurity+Jwt实现身份认证和权限管理后端服务
  • 操作系统-物理结构
  • 最大子段和(就是之前总结线性dp思想)
  • “小显存”也能启动大模型
  • libmemcached库api接口讲解三
  • 可视化图解算法39: 输出二叉树的右视图
  • 前端表格滑动滚动条太费事,做个浮动滑动插件
  • synchronized关键字详解
  • 有关多线程
  • 总共76dp 空出20dp然后放一个控件的写法
  • Spring 中的 @ComponentScan注解详解
  • Android Framework学习五:APP启动过程原理及速度优化
  • Redis内存淘汰策略和过期键删除策略有哪些?
  • TAOCMS漏洞代码学习及分析
  • 微信开发者工具里面模拟操作返回、录屏、网络速度、截屏等操作
  • 企业级IP代理解决方案:负载均衡与API接口集成实践
  • 【CUDA】Sgemm单精度矩阵乘法(上)
  • 达梦数据库 【-6111: 字符串转换出错】问题处理
  • 【AI大模型】赋能【传统业务】
  • React构建组件
  • 微信小程序学习之轮播图swiper
  • 【unity游戏开发——编辑器扩展】EditorWindow自定义unity窗口拓展
  • 橙子、橘子相关(果实、叶片、疾病等)数据集大合集
  • SQL注入报错“Illegal mix of collations for operation ‘UNION‘”解决办法
  • 材料×工艺×AI:猎板PCB重构汽车电子四层板技术逻辑
  • [滑动窗口]越短越合法(可转化成越长越合法)
  • docker-compose的使用总结
  • Linux下的c/c++开发之操作Redis数据库
  • select、poll、epoll
  • MySQL库级管理:数据库管理与存储引擎剖析