灵动微MM32F013x芯片学习-TIM14定时器

本文详细介绍了在STM32中使用TIM14作为定时器时遇到的时钟频率问题。作者指出手册未明确说明TIM14的时钟源,实际上它经过APB2分频后再倍频。当APB2分频系数为1时,无倍频,否则倍频为2。通过代码示例展示了正确的初始化和中断服务函数配置,以实现50ms周期的定时中断。强调了在设置定时器时钟源时需注意的细节。

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

这里只把TIM14作为一个定时器使用,设定一个时间,定时中断。

整个操作还是比较简单,只是关于TIM14的时钟频率问题,掉到了坑里。由于灵动微的手册中并没有详细描述各个外设模块的时钟源,而在APB2ENR寄存器中看到使能位,导致误以为其时钟为PCLK2是TIM14的时钟。而实际TIM14的时钟源如下图,

TIM14的时钟经过APB2分频后,又经过了一个倍频模块。此模块的倍频系数为1或2。当APB2的分频系数为1时,不倍频。当APB2的分频系数不为1,则倍频为2倍。这点大家要格外注意!!!下面上代码:

void TIM14_init(void)
{
    RCC->APB2ENR |= RCC_APB2ENR_TIM14;//enable clock

    TIM14->PSC = 71;// 71+1,set prescaler
    TIM14->ARR = 50000;//set period
    TIM14->DIER |= TIM_DIER_UIEN;//enable update interrupt

    
    TIM14->CR1 |= TIM_CR1_CEN;//counter enable
    
    NVIC_SetPriority(TIM14_IRQn,1);//CMSIS标准函数
    NVIC_EnableIRQ(TIM14_IRQn);//CMSIS标准函数
}

void TIM14_IRQHandler(void)
{
    if(TIM14->SR & TIM_SR_UIF)
    {
        TIM14->SR &= ~TIM_SR_UIF;

        LED_TOGGLE;
    }
}

一个是初始化函数,一个是中断服务函数。我的APB2分频为1,APB2时钟频率为72M,所以上面的设定周期为50ms。

中断服务函数的名字来源于启动文件startup.s(唯一的汇编文件,mcu工作执行的第一段程序),这里的函数是弱声明函数,如果用户定义了,编译器会使用用户定义的函数进行链接。若用户没有定义,则使用这里默认的函数进行链接,这个操作很好很方便。

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值