STM32F103外部晶振由8M变为12M

来源:互联网 发布:c语言怎么定义数组 编辑:程序博客网 时间:2024/05/17 22:34

STM32官方提供的库文件中,HSE(外部高速时钟)默认为8MHz,最高主频为8*9=72MHz,如果将HSE变为12MHz,不修改库文件的话,最高主频则变为12*9=108MHz,最典型的问题就是USART可以通信,但是接收到的数据与发送的不一致,并且找不到啥原因,害的我瞎折腾了一整天,下面列举需要修改的地方。

1、修改stm32f10x.h中的HSE_VALUE,原本的代码如下:

#if !defined  HSE_VALUE   #ifdef STM32F10X_CL       #define HSE_VALUE    ((uint32_t)25000000) /*!< Value of the External oscillator in Hz */   #else     #define HSE_VALUE    ((uint32_t)8000000) /*!< Value of the External oscillator in Hz */   #endif /* STM32F10X_CL */  #endif /* HSE_VALUE */ 
修改后的如下:

#if !defined  HSE_VALUE   #ifdef STM32F10X_CL       #define HSE_VALUE    ((uint32_t)25000000) /*!< Value of the External oscillator in Hz */   #else     #define HSE_VALUE    ((uint32_t)12000000) /*!< Value of the External oscillator in Hz */   #endif /* STM32F10X_CL */  #endif /* HSE_VALUE */  
2、修改system_stm32f10x.c中的时钟配置,先找到void SystemInit(void)---》SetSysClock()---》SetSysClockTo72(),将9倍频改为6倍频,12*6=72MHz,原本代码如下:

#ifdef STM32F10X_CL      /* Configure PLLs ------------------------------------------------------*/      /* PLL2 configuration: PLL2CLK = (HSE / 5) * 8 = 40 MHz */      /* PREDIV1 configuration: PREDIV1CLK = PLL2 / 5 = 8 MHz */                RCC->CFGR2 &= (uint32_t)~(RCC_CFGR2_PREDIV2 | RCC_CFGR2_PLL2MUL |                                RCC_CFGR2_PREDIV1 | RCC_CFGR2_PREDIV1SRC);      RCC->CFGR2 |= (uint32_t)(RCC_CFGR2_PREDIV2_DIV5 | RCC_CFGR2_PLL2MUL8 |                               RCC_CFGR2_PREDIV1SRC_PLL2 | RCC_CFGR2_PREDIV1_DIV5);          /* Enable PLL2 */      RCC->CR |= RCC_CR_PLL2ON;      /* Wait till PLL2 is ready */      while((RCC->CR & RCC_CR_PLL2RDY) == 0)      {      }                 /* PLL configuration: PLLCLK = PREDIV1 * 9 = 72 MHz */       RCC->CFGR &= (uint32_t)~(RCC_CFGR_PLLXTPRE | RCC_CFGR_PLLSRC | RCC_CFGR_PLLMULL);      RCC->CFGR |= (uint32_t)(RCC_CFGR_PLLXTPRE_PREDIV1 | RCC_CFGR_PLLSRC_PREDIV1 |                               RCC_CFGR_PLLMULL9);   #else          /*  PLL configuration: PLLCLK = <span style="color:#ff0000;">HSE * 9 = 72 MHz</span> */      RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_PLLSRC | RCC_CFGR_PLLXTPRE |                                          RCC_CFGR_PLLMULL));      RCC->CFGR |= (uint32_t)(RCC_CFGR_PLLSRC_HSE | RCC_CFGR_PLLMULL9);  #endif /* STM32F10X_CL */  
修改后的如下:
#ifdef STM32F10X_CL      /* Configure PLLs ------------------------------------------------------*/      /* PLL2 configuration: PLL2CLK = (HSE / 5) * 8 = 40 MHz */      /* PREDIV1 configuration: PREDIV1CLK = PLL2 / 5 = 8 MHz */                RCC->CFGR2 &= (uint32_t)~(RCC_CFGR2_PREDIV2 | RCC_CFGR2_PLL2MUL |                                RCC_CFGR2_PREDIV1 | RCC_CFGR2_PREDIV1SRC);      RCC->CFGR2 |= (uint32_t)(RCC_CFGR2_PREDIV2_DIV5 | RCC_CFGR2_PLL2MUL8 |                               RCC_CFGR2_PREDIV1SRC_PLL2 | RCC_CFGR2_PREDIV1_DIV5);          /* Enable PLL2 */      RCC->CR |= RCC_CR_PLL2ON;      /* Wait till PLL2 is ready */      while((RCC->CR & RCC_CR_PLL2RDY) == 0)      {      }                 /* PLL configuration: PLLCLK = PREDIV1 * 9 = 72 MHz */       RCC->CFGR &= (uint32_t)~(RCC_CFGR_PLLXTPRE | RCC_CFGR_PLLSRC | RCC_CFGR_PLLMULL);      RCC->CFGR |= (uint32_t)(RCC_CFGR_PLLXTPRE_PREDIV1 | RCC_CFGR_PLLSRC_PREDIV1 |                               RCC_CFGR_PLLMULL9);    #else          /*  PLL configuration: PLLCLK = <span style="color:#ff0000;">HSE * 6 = 72 MHz</span> */      RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_PLLSRC | RCC_CFGR_PLLXTPRE |                                          RCC_CFGR_PLLMULL));      RCC->CFGR |= (uint32_t)(RCC_CFGR_PLLSRC_HSE | RCC_CFGR_PLLMULL6);  #endif /* STM32F10X_CL */