stm32芯片的所有片上外设都需要手动设置时钟。
三种不同的时钟源可被用来驱动系统时钟(SYSCLK):
HSI振荡器时钟
由内部8MHz的RC振荡器产生,可直接作为系统时钟或在2分频后作为PLL输入。HSI RC振荡器能够在不需要任何外部器件的条件下提供系统时钟。它的启动时间比HSE晶体振荡器短。然而,即使在校准之后它的时钟频率精度仍较差。(所以通常不用与提供SYSCLK)HSE振荡器时钟:
高速外部时钟信号,由HSE外部晶体/陶瓷谐振器(较常用)或者HSE用户外部时钟两种方式产生PLL时钟
时钟源输入,内部PLL可以用来倍频HSI RC的输出时钟或HSE晶体输出时钟,一旦PLL被激活,这些参数就不能被改动。
二级时钟源
当不被使用时,任一个时钟源都可被独立地启动或关闭,由此优化系统功耗。
LSI 时钟
40kHz低速内部RC,可以用于驱动独立看门狗和通过程序选择驱动RTC。RTC用于从停机/待机模式下自动唤醒系统
LSE 时钟
32.768kHz低速外部晶体也可用来通过程序选择驱动RTC(RTCCLK)。
配置时钟流程:
1.将RCC寄存器重新设置为默认值, RCC_DeInit
2.打开外部高速时钟晶振HSE, RCC_HSEConfig(RCC_HSE_ON);
3.等待外部高速时钟晶振工作, HSEStartUpStatus =RCC_WaitForHSEStartUp();
4.设置AHB时钟, RCC_HCLKConfig;
5.设置高速APB2时钟, RCC_PCLK2Config;
6.设置低速速APB1时钟, RCC_PCLK1Config
7.设置PLL, RCC_PLLConfig
8.打开PLL, RCC_PLLCmd(ENABLE);
9.等待PLL工作, while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
10.设置系统时钟, RCC_SYSCLKConfig
11.判断是否PLL是系统时钟, while(RCC_GetSYSCLKSource() != 0x08)
12.打开要使用的外设时钟 , RCC_APB2PeriphClockCmd()
代码如下:
/*! System Clocks Configuration */ void RCC_Configuration(void) { ErrorStatus HSEStartUpStatus; RCC_DeInit(); /* RCC寄存器恢复初始化值*/ RCC_HSEConfig(RCC_HSE_ON); /* Enable HSE 使能外部高速晶振*/ HSEStartUpStatus = RCC_WaitForHSEStartUp(); /* 等待外部高速晶振使能完成*/ if(HSEStartUpStatus == SUCCESS) { /*设置PLL时钟源及倍频系数*/ RCC_PLLConfig(RCC_PLLSource_HSE_Div1, RCC_PLLMul_16); // PLL的输入时钟 = HSE时钟频率;RCC_PLLMul_16——PLL输入时钟x 16 ;HSE =4MHZ,所以PLLCLK=64MHZ /*设置AHB时钟(HCLK)*/ RCC_HCLKConfig(RCC_SYSCLK_Div1); //RCC_SYSCLK_Div1——AHB时钟 = 系统时钟(SYSCLK) = 64MHZ(外部晶振4HMZ) /*注意此处的设置,如果使用SYSTICK做延时程序,此时SYSTICK(Cortex System timer)=HCLK/8=8MHZ*/ /*设置低速AHB时钟(PCLK1)*/ RCC_PCLK1Config(RCC_HCLK_Div2); //RCC_HCLK_Div2——APB1时钟 = HCLK/2 = 32MHZ(外部晶振4HMZ) /* 设置高速AHB时钟(PCLK2)*/ RCC_PCLK2Config(RCC_HCLK_Div1); //RCC_HCLK_Div1——APB2时钟 = HCLK = 64MHZ(外部晶振4HMZ) /*设置FLASH存储器延时时钟周期数*/ FLASH_SetLatency(FLASH_Latency_2); //FLASH_Latency_1 1延时周期 /*FLASH时序延迟几个周期,等待总线同步操作。 推荐按照单片机系统运行频率,0—24MHz时,取Latency=0; 24—48MHz时,取Latency=1; 48~72MHz时,取Latency=2*/ /*选择FLASH预取指缓存的模式*/ FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); // 预取指缓存使能 /* Enable PLL 使能PLL*/ RCC_PLLCmd(ENABLE);/* Wait till PLL is ready */ while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET) { } /* Select PLL as system clock source */ RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);/* Wait till PLL is used as system clock source */ while(RCC_GetSYSCLKSource() != 0x08) { } }//end if(HSEStartUpStatus == SUCCESS) /*开始使能程序中需要使用的外设时钟*/ // Enables or disables the High Speed APB(APB2) peripheral clock,APB2外设时钟使能 RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA | RCC_APB2Periph_GPIOB | RCC_APB2Periph_GPIOC | RCC_APB2Periph_GPIOD |RCC_APB2Periph_GPIOE, ENABLE); RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE); RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART3, ENABLE); /*!< SPI_FLASH_SPI Periph clock enable */ RCC_APB2PeriphClockCmd(RCC_APB2Periph_SPI1, ENABLE); /*!< AFIO Periph clock enable */ RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO, ENABLE); } 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
下面贴几个用到的函数官方库解释:
大概就是这些
上一篇:stm32之USART串口配置
下一篇:stm32之assert_param 函数
推荐阅读最新更新时间:2024-03-16 15:37
设计资源 培训 开发板 精华推荐
- PC产业驶入创新超车道,英特尔蓉城撬动AI新引擎
- 与产业聚力共赢,英特尔举行新质生产力技术生态大会
- “新”享5G-A万兆网络前沿体验 高通携手产业伙伴亮相第二届链博会
- 英飞凌推出符合ASIL-D标准的新型汽车制动系统和电动助力转向系统三相栅极驱动器 IC
- 南芯科技推出80V升降压转换器,持续深耕工业储能市场
- 法雷奥与罗姆联合开发新一代功率电子领域
- 贸泽电子开售能为电动汽车牵引逆变器提供可扩展性能的 英飞凌HybridPACK Drive G2模块
- 德州仪器新型 MCU 可实现边缘 AI 和先进的实时控制, 提高系统效率、安全性和可持续性
- 瑞萨推出高性能四核应用处理器, 增强工业以太网与多轴电机控制解决方案阵容
- 研华全新模块化电脑SOM-6833助力5G路测设备升级