[STM32F0] STM32F030 启用内部晶振并配置系统时钟为48M

[复制链接]
887|10
 楼主| 黑心单片机 发表于 2023-11-30 23:21 | 显示全部楼层 |阅读模式
在文件 system_stm32f0xx.c 里的函数
static void SetSysClock(void)
{
if (HSEStatus == (uint32_t)0x01) // 存在外部时钟
{
}else{
// 这里添加配置48M代码
}
}
  1. static void SetSysClock(void)
  2. {
  3.   __IO uint32_t StartUpCounter = 0, HSEStatus = 0;

  4.   /* SYSCLK, HCLK, PCLK configuration ----------------------------------------*/
  5.   /* Enable HSE */
  6.   RCC->CR |= ((uint32_t)RCC_CR_HSEON);

  7.   /* Wait till HSE is ready and if Time out is reached exit */
  8.   do
  9.   {
  10.     HSEStatus = RCC->CR & RCC_CR_HSERDY;
  11.     StartUpCounter++;
  12.   } while ((HSEStatus == 0) && (StartUpCounter != HSE_STARTUP_TIMEOUT));

  13.   if ((RCC->CR & RCC_CR_HSERDY) != RESET)
  14.   {
  15.     HSEStatus = (uint32_t)0x01;
  16.   }
  17.   else
  18.   {
  19.     HSEStatus = (uint32_t)0x00;
  20.   }

  21.   if (HSEStatus == (uint32_t)0x01) // 存在外部时钟
  22.   {
  23.     /* Enable Prefetch Buffer and set Flash Latency */
  24.     FLASH->ACR = FLASH_ACR_PRFTBE | FLASH_ACR_LATENCY;

  25.     /* HCLK = SYSCLK */
  26.     RCC->CFGR |= (uint32_t)RCC_CFGR_HPRE_DIV1;

  27.     /* PCLK = HCLK */
  28.     RCC->CFGR |= (uint32_t)RCC_CFGR_PPRE_DIV1;

  29.     /* PLL configuration = HSE * 6 = 48 MHz */
  30.     RCC->CFGR &= (uint32_t)((uint32_t) ~(RCC_CFGR_PLLSRC | RCC_CFGR_PLLXTPRE | RCC_CFGR_PLLMULL));
  31.     RCC->CFGR |= (uint32_t)(RCC_CFGR_PLLSRC_PREDIV1 | RCC_CFGR_PLLXTPRE_PREDIV1 | RCC_CFGR_PLLMULL6);

  32.     /* Enable PLL */
  33.     RCC->CR |= RCC_CR_PLLON;

  34.     /* Wait till PLL is ready */
  35.     while ((RCC->CR & RCC_CR_PLLRDY) == 0)
  36.     {
  37.     }

  38.     /* Select PLL as system clock source */
  39.     RCC->CFGR &= (uint32_t)((uint32_t) ~(RCC_CFGR_SW));
  40.     RCC->CFGR |= (uint32_t)RCC_CFGR_SW_PLL;

  41.     /* Wait till PLL is used as system clock source */
  42.     while ((RCC->CFGR & (uint32_t)RCC_CFGR_SWS) != (uint32_t)RCC_CFGR_SWS_PLL)
  43.     {
  44.     }
  45.   }
  46.   else
  47.   {
  48.     // HSI 内部时钟做为PLL时钟源并配置PLL 48M做为系统时钟
  49.     /* Enable Prefetch Buffer and set Flash Latency */
  50.     FLASH->ACR = FLASH_ACR_PRFTBE | FLASH_ACR_LATENCY;

  51.     /* HCLK = SYSCLK */
  52.     RCC->CFGR |= (uint32_t)RCC_CFGR_HPRE_DIV1;

  53.     /* PCLK = HCLK */
  54.     RCC->CFGR |= (uint32_t)RCC_CFGR_PPRE_DIV1;

  55.     // PLL configuration = (HSI/2) * 12 = 48 MHz
  56.     RCC_PLLConfig(RCC_PLLSource_HSI_Div2, RCC_PLLMul_12); // 8M/2 * 12 = 48M

  57.     /* Enable PLL */
  58.     RCC->CR |= RCC_CR_PLLON;

  59.     /* Wait till PLL is ready */
  60.     while ((RCC->CR & RCC_CR_PLLRDY) == 0)
  61.     {
  62.     }

  63.     /* Select PLL as system clock source */
  64.     RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); // PLL 做系统时钟

  65.     /* Wait till PLL is used as system clock source */
  66.     while ((RCC->CFGR & (uint32_t)RCC_CFGR_SWS) != (uint32_t)RCC_CFGR_SWS_PLL)
  67.     {
  68.     }
  69.   }
  70. }


周半梅 发表于 2024-8-21 07:03 | 显示全部楼层

每个电容与纹波电流源的引线阻抗一样
Pulitzer 发表于 2024-8-21 08:06 | 显示全部楼层

时间片轮的设计思想
童雨竹 发表于 2024-8-21 10:02 | 显示全部楼层

大大减小与其他引线之间的容性耦合
Wordsworth 发表于 2024-8-21 11:05 | 显示全部楼层

需要在做项目的过程中经历磨难
Clyde011 发表于 2024-8-21 12:08 | 显示全部楼层

硬件设计和软件设计本来就是鱼和熊掌的关系,两者不可兼得
公羊子丹 发表于 2024-8-21 13:01 | 显示全部楼层

与电感和续流二极管相连
万图 发表于 2024-8-21 14:04 | 显示全部楼层

结构化模块化的程序设计的思想,使最基本的要求
Uriah 发表于 2024-8-21 15:07 | 显示全部楼层

确定好硬件原理图,硬件布线,最后才是软件的开发
帛灿灿 发表于 2024-8-21 17:03 | 显示全部楼层

写程序不难,但是程序怎么样才能写的好,写的快,那是需要点经验积累的
Bblythe 发表于 2024-8-21 18:06 | 显示全部楼层

在实际的项目应用当中,单片机引脚的复用相当厉害
您需要登录后才可以回帖 登录 | 注册

本版积分规则

72

主题

514

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部