历史上的今天
今天是:2024年09月15日(星期日)
2021年09月15日 | 【STM32使用内部RC振荡器】1、时钟源的设置
2021-09-15 来源:eefocus
PLL 为锁相环倍频输出,其时钟输入源可选择为 HSI/2、 HSE 或者 HSE/2。
而HSI固定为8M,故PLL输入固定为4M。
HSE通常是外部晶振8M
以下HSI代码设置的各个时钟频率为:
HCLK = SYSCLK= PCLK2 = PLLCLK = 36M, PCLK1=HCLK/2 = 18M
1、keil设置
使用HSI配置系统时钟使用时钟初始化代码之前先一定要设置keil如图所示选项为:<晶振为8MHz>,不能设置25MHz等其它频率。

2、加入代码
在主函数中先调用以下函数
//系统时钟配置
HSI_SetSysClock(RCC_PLLMul_9);//HSI始终配置为36M
函数实现代码如下
/*
* 使用HSI时,设置系统时钟的步骤
* 1、开启HSI ,并等待 HSI 稳定
* 2、设置 AHB、APB2、APB1的预分频因子
* 3、设置PLL的时钟来源,和PLL的倍频因子,设置各种频率主要就是在这里设置
* 4、开启PLL,并等待PLL稳定
* 5、把PLLCK切换为系统时钟SYSCLK
* 6、读取时钟切换状态位,确保PLLCLK被选为系统时钟
*/
/* 设置 系统时钟:SYSCLK, AHB总线时钟:HCLK, APB2总线时钟:PCLK2, APB1总线时钟:PCLK1
* PCLK2 = HCLK = SYSCLK
* PCLK1 = HCLK/2,最高只能是36M
* 参数说明:pllmul是PLL的倍频因子,在调用的时候可以是:RCC_PLLMul_x , x:[2,3,...16]
* 举例:HSI_SetSysClock(RCC_PLLMul_9); 则设置系统时钟为:4MHZ * 9 = 36MHZ
* HSI_SetSysClock(RCC_PLLMul_16); 则设置系统时钟为:4MHZ * 16 = 64MHZ
*
* HSI作为时钟来源,经过PLL倍频作为系统时钟,这是在HSE故障的时候才使用的方法
* HSI会因为温度等原因会有漂移,不稳定,一般不会用HSI作为时钟来源,除非是迫不得已的情况
* 如果HSI要作为PLL时钟的来源的话,必须二分频之后才可以,即HSI/2,而PLL倍频因子最大只能是16
* 所以当使用HSI的时候,SYSCLK最大只能是4M*16=64M
*/
void HSI_SetSysClock(uint32_t pllmul)
{
__IO uint32_t HSIStartUpStatus = 0;
// 把RCC外设初始化成复位状态,这句是必须的
RCC_DeInit();
//使能HSI
RCC_HSICmd(ENABLE);
// 等待 HSI 就绪
HSIStartUpStatus = RCC->CR & RCC_CR_HSIRDY;
// 只有 HSI就绪之后则继续往下执行
if (HSIStartUpStatus == RCC_CR_HSIRDY)
{
//----------------------------------------------------------------------//
// 使能FLASH 预存取缓冲区
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
// SYSCLK周期与闪存访问时间的比例设置,这里统一设置成2
// 设置成2的时候,SYSCLK低于48M也可以工作,如果设置成0或者1的时候,
// 如果配置的SYSCLK超出了范围的话,则会进入硬件错误,程序就死了
// 0:0 < SYSCLK <= 24M
// 1:24< SYSCLK <= 48M
// 2:48< SYSCLK <= 72M
FLASH_SetLatency(FLASH_Latency_2);
//----------------------------------------------------------------------//
// AHB预分频因子设置为1分频,HCLK = SYSCLK
RCC_HCLKConfig(RCC_SYSCLK_Div1);
// APB2预分频因子设置为1分频,PCLK2 = HCLK
RCC_PCLK2Config(RCC_HCLK_Div1);
// APB1预分频因子设置为1分频,PCLK1 = HCLK/2
RCC_PCLK1Config(RCC_HCLK_Div2);
//-----------------设置各种频率主要就是在这里设置-------------------//
// 设置PLL时钟来源为HSE,设置PLL倍频因子
// PLLCLK = 4MHz * pllmul
RCC_PLLConfig(RCC_PLLSource_HSI_Div2, pllmul);
//------------------------------------------------------------------//
// 开启PLL
RCC_PLLCmd(ENABLE);
// 等待 PLL稳定
while (RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET)
{
}
// 当PLL稳定之后,把PLL时钟切换为系统时钟SYSCLK
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
// 读取时钟切换状态位,确保PLLCLK被选为系统时钟
while (RCC_GetSYSCLKSource() != 0x08)
{
}
}
else
{ // 如果HSI开启失败,那么程序就会来到这里,用户可在这里添加出错的代码处理
// 当HSE开启失败或者故障的时候,单片机会自动把HSI设置为系统时钟,
// HSI是内部的高速时钟,8MHZ
while (1)
{
}
}
}
史海拾趣
|
void Rs485_Do(void) interrupt 4 using 1 {& K if(RI==l)% z& {/ a- N# G0 k {* {& F* F. [$ |! E8 d, r\" E, H RI=0; RsBuq[RsPoint++]=SBUF;2 G9 ^2 y\" `( x\' [) X9 c8 a if fRsPo ...… 查看全部问答> |
|
关于自制51编程器网上的资料很多。我试验了几种,觉得聂忠强的Easy 51Pro串行编程器效果比较好。一是硬件电路简单可靠,二是软件也编得好,还可以扩充。适合初学者仿制。我前几年做了一个,用起来很灵光,很多在别的编程器上不能用的芯片在这个编程 ...… 查看全部问答> |
|
sources.cmn中一行前面加"#"号是表示注释掉吗?和#if…!endif有什么区别? 看到如下内容有点迷糊: WINCEOEM=1 WINCECPU=1 NOMIPS16CODE=1 ##WARNLEVEL=4 ##WARNISERROR=1 还有: # define to enable suspend/resume related debugging (requires clean build) #CDEFINES=$(CDEFINES) -DDEBUG_PRCM_SUSPEND_RESUME ...… 查看全部问答> |
|
51单片机=====步进式电机 BY: 飞龙 QQ: 9086074 希望认识更多的单片机开发朋友一起交流 第一次做教程不好多多见谅 BLOG: http://hi.baidu.com/alalmn 1. 烧写程序 2. ...… 查看全部问答> |
|
做过TSP(telephony service provider)的朋友请进 有几个概念问题: 1、tsp dll是驱动层还是应用层? 2、如果tsp dll是驱动层,那么可以在tsp dll中使用win32 api操作串口否? 3、wince下开发tsp的一般步骤是怎样的?… 查看全部问答> |
|
赛灵思在努力帮助设计人员提高工作效率的同时,不断改进产品、IP 以及设计工具。我们将在此报告自 2011 年 7 月起,有关旗舰 FPGA 开发环境、ISE®设计套件以及赛灵思 IP 核的当前最新更新情况。产品更新包括 ISE 设计套件三个版本(逻辑、嵌入 ...… 查看全部问答> |
|
【Atmel SAM R21创意大赛周计划】第0周 收到板子啦! 看到入围名单之后,把我高兴坏了,然后就一直盼着板子寄过来。今天一收到快递发的短信,立马就去取了! 快递包裹得很严实,迫不及待就打开了,忘记拍照了 果然,是两个板子。这次活动主题是无线通讯,所以至少要有一对板子 ...… 查看全部问答> |




