stm32_HSI

stm32启动时使用的是外部8M晶振,在system_stm32f10x.c文件中有定义,且使用的函数为void SystemInit (void)
使用外部晶振HSE时的代码如下
void SystemInit (void)
{
//  /* Reset the RCC clock configuration to the default reset state(for debug purpose) */
//  /* Set HSION bit */
//  RCC->CR |= (uint32_t)0x00000001;


//  /* Reset SW, HPRE, PPRE1, PPRE2, ADCPRE and MCO bits */
//#ifndef STM32F10X_CL
//  RCC->CFGR &= (uint32_t)0xF8FF0000;
//#else
//  RCC->CFGR &= (uint32_t)0xF0FF0000;
//#endif /* STM32F10X_CL */   
//  
//  /* Reset HSEON, CSSON and PLLON bits */
//  RCC->CR &= (uint32_t)0xFEF6FFFF;


//  /* Reset HSEBYP bit */
//  RCC->CR &= (uint32_t)0xFFFBFFFF;


//  /* Reset PLLSRC, PLLXTPRE, PLLMUL and USBPRE/OTGFSPRE bits */
//  RCC->CFGR &= (uint32_t)0xFF80FFFF;


//#ifdef STM32F10X_CL
//  /* Reset PLL2ON and PLL3ON bits */
//  RCC->CR &= (uint32_t)0xEBFFFFFF;


//  /* Disable all interrupts and clear pending bits  */
//  RCC->CIR = 0x00FF0000;


//  /* Reset CFGR2 register */
//  RCC->CFGR2 = 0x00000000;
//#elif defined (STM32F10X_LD_VL) || defined (STM32F10X_MD_VL) || (defined STM32F10X_HD_VL)
//  /* Disable all interrupts and clear pending bits  */
//  RCC->CIR = 0x009F0000;


//  /* Reset CFGR2 register */
//  RCC->CFGR2 = 0x00000000;      
//#else
//  /* Disable all interrupts and clear pending bits  */
//  RCC->CIR = 0x009F0000;
//#endif /* STM32F10X_CL */
//    
//#if defined (STM32F10X_HD) || (defined STM32F10X_XL) || (defined STM32F10X_HD_VL)
//  #ifdef DATA_IN_ExtSRAM
//    SystemInit_ExtMemCtl(); 
//  #endif /* DATA_IN_ExtSRAM */
//#endif 


//  /* Configure the System clock frequency, HCLK, PCLK2 and PCLK1 prescalers */
//  /* Configure the Flash Latency cycles and enable prefetch buffer */
//  SetSysClock();


//#ifdef VECT_TAB_SRAM
//  SCB->VTOR = SRAM_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal SRAM. */
//#else
//  SCB->VTOR = FLASH_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal FLASH. */
//#endif 
}






现在改为使用内部晶振
void SystemInit (void)
{
RCC->CR |= (uint32_t)0x00000001; 


/*选择HSI为PLL的时钟源HSI必须2分频给PLL*/
RCC->CFGR |= (uint32_t)RCC_CFGR_PLLSRC_HSI_Div2; 
 
/*PLLCLK=8/2*13=52MHz   设置倍频得到时钟源PLL的频率*/
RCC->CFGR |= (uint32_t)RCC_CFGR_PLLMULL4;          //四倍频


/* PLL不分频输出  */
RCC->CFGR |= (uint32_t)RCC_CFGR_HPRE_DIV1;
 
/* 使能 PLL时钟 */
RCC->CR |= RCC_CR_PLLON;


/* 等待PLL时钟就绪*/
while((RCC->CR & RCC_CR_PLLRDY) == 0);


/* 选择PLL为系统时钟的时钟源 */
RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_SW));
RCC->CFGR |= (uint32_t)RCC_CFGR_SW_PLL;    


/* 等到PLL成为系统时钟的时钟源*/
while ((RCC->CFGR & (uint32_t)RCC_CFGR_SWS) != (uint32_t)0x08);
}
倍频备注:倍频可以从6M到45M,通过修改RCC_CFGR_PLLMULL4,此处与数据手册说法有一点不符合,但是通过示波器实际测出是可以的。计算公式system_clk=6M/2*倍频数
至于为何是6M,怀疑可能是内部RC晶振有点问题或者配置问题待解决


使用内部RC晶振时,delay函数不能用,计时不准确
### STM32时钟初始化代码与教程 STM32微控制器的时钟初始化是一个重要的配置过程,它决定了系统的运行速度和其他外设的工作频率。通常情况下,可以通过STM32CubeMX工具自动生成初始化代码[^1]。 #### 使用STM32CubeMX生成时钟初始化代码 通过STM32CubeMX图形化界面可以轻松完成时钟树的配置并生成相应的初始化代码。以下是具体的实现方法: - 打开STM32CubeMX软件后,选择目标MCU型号,并创建一个新的项目[^2]。 - 进入到Clock Configuration选项卡,在这里可以根据需求调整PLL设置以及各种时钟源的选择(HSI, HSE, LSI, LSE等)。同时还可以设定AHB/APB总线分频器来满足不同外设的速度要求[^1]。 一旦完成了这些参数的定义之后,点击GENERATE CODE按钮即可让STM32CubeMX为你生产完整的HAL库或者LL API形式下的启动文件夹结构及其内部含有的RCC(Reset and Clock Control)部分相关函数调用片段用于执行实际硬件上的操作。 #### 示例代码展示 下面给出了一段基于STM32 HAL库的简单时钟初始化例子: ```c void SystemClock_Config(void){ RCC_OscInitTypeDef RCC_OscInitStruct = {0}; RCC_ClkInitTypeDef RCC_ClkInitStruct = {0}; /** Configure the main internal regulator output voltage */ __HAL_RCC_PWR_CLK_ENABLE(); __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1); /** Initializes the CPU, AHB and APB busses clocks */ RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE; RCC_OscInitStruct.HSEState = RCC_HSE_ON; RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON; RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE; RCC_OscInitStruct.PLL.PLLM = 8; RCC_OscInitStruct.PLL.PLLN = 336; RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2; RCC_OscInitStruct.PLL.PLLQ = 7; if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK) { Error_Handler(); } /** Initializes the CPU, AHB and APB buses clocks */ RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK | RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2; RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK; RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1; RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4; RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2; if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_5) != HAL_OK) { Error_Handler(); } } ``` 此代码展示了如何启用外部高速晶体振荡器(HSE),并通过锁相环(PLL)倍频得到更高的系统时钟(SYSCLK)[^1]。此外还设置了闪存等待状态数以适应新的工作频率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值