STM32使用外部晶振并设置主频为48M

本文详细介绍了STM32微控制器的时钟初始化过程,包括复位配置、内部高速时钟启用、PLL设置及系统时钟切换。通过具体代码示例,展示了如何配置STM32以满足特定的时钟需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

因为项目上对时钟要求不高,只需要用到一个9600波特率的串口和一些普通IO口,下面是简单的使用方法。

void MYRCC_DeInit(void)
{
    RCC->APB1RSTR = 0x00000000;//复位结束
    RCC->APB2RSTR = 0x00000000;

    RCC->AHBENR = 0x00000014;  //睡眠模式闪存和SRAM时钟使能.其他关闭.
    RCC->APB2ENR = 0x00000000; //外设时钟关闭.
    RCC->APB1ENR = 0x00000000;
    RCC->CR |= 0x00000001;     //使能内部高速时钟HSION
    RCC->CFGR &= 0xF8FF0000;   //复位SW[1:0],HPRE[3:0],PPRE1[2:0],PPRE2[2:0],ADCPRE[1:0],MCO[2:0]
    RCC->CR &= 0xFEF6FFFF;     //复位HSEON,CSSON,PLLON
    RCC->CR &= 0xFFFBFFFF;     //复位HSEBYP
    RCC->CFGR &= 0xFF80FFFF;   //复位PLLSRC, PLLXTPRE, PLLMUL[3:0] and USBPRE
    RCC->CIR = 0x00000000;     //关闭所有中断
    //配置向量表
#ifdef  VECT_TAB_RAM
    NVIC_SetVectorTable(0x20000000, 0x0);
#else
    NVIC_SetVectorTable(0x08000000, 0x0);
#endif
}



void Stm32_Clock_Init(u8 PLL)
{
    unsigned char temp = 0;
    MYRCC_DeInit();		  //复位并配置向量表
    RCC->CR |= 0x00000001; //内部高速时钟使能HSION
    while(!(RCC->CR >> 1)); //等待内部时钟就绪
    RCC->CFGR = 0X00000400; //APB1=DIV2;APB2=DIV1;AHB=DIV1;
    PLL -= 2; //抵消2个单位
    RCC->CFGR |= PLL << 18; //设置PLL值 2~16
    RCC->CFGR |= 0 << 16;	 //PLLSRC ON  HSI经2分频后作为PLL输入时钟
    FLASH->ACR |= 0x32;	 //FLASH 2个延时周期

    RCC->CR |= 0x01000000; //PLLON
    while(!(RCC->CR >> 25)); //等待PLL锁定
    RCC->CFGR |= 0x00000002; //PLL作为系统时钟
    while(temp != 0x02)   //等待PLL作为系统时钟设置成功
    {
        temp = RCC->CFGR >> 2;
        temp &= 0x03;
    }
}


int main(void)
{
    int i;
    Stm32_Clock_Init(12);
    delay_init();	    	 //延时函数初始化
    NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2); //设置NVIC中断分组2:2位抢占优先级,2位响应优先级
    uart_init(9600);	 //串口初始化为115200
    LED_Init();			     //LED端口初始化
    TIM3_Int_Init(49, 48 - 1); //10Khz的计数频率,计数到5000为500ms

    while(1)
    {
        printf("hello\r\n");
        delay_ms(1000);
    }
}

为了保证系统时钟的delay函数正常,还需要在system_stm32f10x.c中注释掉原有的时钟#define SYSCLK_FREQ_72MHz 72000000并改为#define SYSCLK_FREQ_48MHz 48000000
在这里插入图片描述

STM32F1系列微控制器使用HAL (Hardware Abstraction Layer) 或 CMSIS (Cross-Tool Interface for Software Independence in Microcontrollers System Interface Standard) 等标准库编写程序时,设置64MHz外部晶振作为CPU主频通常需要以下步骤: 1. **配置时钟系统**: - 首先,启用时钟树,包括HSE(高速外部时钟源)和HSI(内部高速时钟源)。对于64MHz晶体,HSE通常是首选。 - 使用`HAL_RCC_OscConfig()`函数配置时钟源,选择HSE,将其分频至SYSCLK (系统时钟)。 2. **配置SYSCLK**: - 通过`HAL_RCC_ClockConfig()`函数将SYSCLK配置成64MHz,通常会使用`RCC_SYSCLKSource_HSI_DIV1`或`RCC_SYSCLKSource_HSE`选项。 3. **启用分频器**: - 如果SYSCLK仍低于目标频率,可能还需要使用PLL (预分频器和锁相环)。例如,可以使用`HAL_RCC_PLLConfig()`函数配置PLL,然后调用`HAL_RCC_PLLEnable()`和`HAL_RCC_SYSCLKSource_PLLSAI1`来使能切换到锁定的频率。 4. **等待时钟稳定**: - 在设置完时钟后,确保给时钟系统一些时间来稳定,这通常通过`HAL_Delay()`函数完成,直到`HAL_RCC_GetSysClockFreq()`返回期望的频率值。 5. **检查频率是否正确**: - 最后,使用`HAL_RCC_GetSysClockFreq()`获取当前的SYSCLK频率确认它接近或等于64MHz。 以下是伪代码示例: ```c // Enable HSE HAL_RCC_OscConfig(RCC_OscInitStruct); // Configure SYSCLK with HSE at 64 MHz HAL_RCC_ClockConfig(&RCC或多钟配置结构体, FLASH_LATENCY_5); // If needed, configure PLL and set SYSCLK to 64 MHz HAL_RCC_PLLConfig(RCC_PLLInitTypeDef); HAL_RCC_PLLEnable(); HAL_RCC_SYSCLKSource_PLLSAI1; // Wait for clock to stabilize while (HAL_RCC_GetSysClockFreq() < 64000000) { HAL_Delay(10); } // Check the actual frequency uint32_t systemClock = HAL_RCC_GetSysClockFreq(); printf("System Clock Frequency: %u MHz\n", systemClock / 1000000);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值