STM32F103使用內部晶振的配置及64M主頻異常的解決方法

STM32F103使用內部晶振的配置及64M主頻異常的解決方法

 

爲了節省空間與成本,將STM32F103芯片外接晶振去除,使用內部HSI時鐘,配置方法如下:

  1. void RCC_Configuration(void)
  2. {
  3.     /* Enable Prefetch Buffer */
  4.     FLASH->ACR |= FLASH_ACR_PRFTBE;
  5.     /* Flash 2 wait state */
  6.     FLASH->ACR &= (uint32_t)((uint32_t)~FLASH_ACR_LATENCY);
  7.     FLASH->ACR |= (uint32_t)FLASH_ACR_LATENCY_2;
  8.  
  9.     RCC_DeInit(); //set RCC to initialization
  10.  
  11.     RCC_HSICmd(ENABLE);//Enable HSI  
  12.     while(RCC_GetFlagStatus(RCC_FLAG_HSIRDY) == RESET);//wait HSI enable
  13.  
  14.     //FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
  15.     //FLASH_SetLatency(FLASH_Latency_2);
  16.  
  17.     RCC_HCLKConfig(RCC_SYSCLK_Div1);
  18.     RCC_PCLK1Config(RCC_HCLK_Div2);
  19.     RCC_PCLK2Config(RCC_HCLK_Div1);
  20.  
  21.     // Set PLL clock source and frequency doubling coefficient
  22.     RCC_PLLConfig(RCC_PLLSource_HSI_Div2, RCC_PLLMul_9);
  23.     RCC_PLLCmd(ENABLE);
  24.     // Waiting for the specified RCC flag bit settings to succeed 
  25.     // and waiting for the PLL initialization to succeed
  26.     while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);
  27.  
  28.     //  Setting PLL as System Clock Source
  29.     RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
  30.     //Waiting for PLL to be successfully used as clock source for system clock
  31.     //  0x00:HSI 
  32.     //  0x04:HSE
  33.     //  0x08:PLL
  34.     while(RCC_GetSYSCLKSource() != 0x08);
  35.  
  36. }

使用時,屏蔽原來的時鐘初始化函數,替換即可。芯片內置HSI時鐘頻率是8M,但是使用時必須二分頻,所以得到初始時鐘頻率爲4M。使用PLL倍頻時,最大可以到16倍,這樣可以得到的系統時鐘頻率最大爲64M

特別說明:

/* Enable Prefetch Buffer */
FLASH->ACR |= FLASH_ACR_PRFTBE;
/* Flash 2 wait state */
FLASH->ACR &= (uint32_t)((uint32_t)~FLASH_ACR_LATENCY);
FLASH->ACR |= (uint32_t)FLASH_ACR_LATENCY_2;

這段不是必須,如果使用時鐘頻率在36M以下,即 RCC_PLLConfig(RCC_PLLSource_HSI_Div2, RCC_PLLMul_9);  倍頻在9倍以下時,可以省略;但是倍頻在10-16倍時,經測試,沒有這段函數系統不工作,原因暫時還不明白,後續弄懂之後再進行補充。

// 使能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);

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章