当前位置:首页 > 单片机 > 单片机
[导读]使用普通定时器2来产生中断,计数方式:增计数!一、编程配置部分1、首先进行中断配置,定时器中断肯定要配置的,代码如下:voidTIM2_NVIC_Configuration(void){NVIC_InitTypeDefNVIC_InitStructure;NVIC_PriorityGr

使用普通定时器2来产生中断,计数方式:增计数!

一、编程配置部分

1、首先进行中断配置,定时器中断肯定要配置的,代码如下:


voidTIM2_NVIC_Configuration(void)

{

NVIC_InitTypeDefNVIC_InitStructure;

NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0);

NVIC_InitStructure.NVIC_IRQChannel=TIM2_IRQn;

NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0;

NVIC_InitStructure.NVIC_IRQChannelSubPriority=3;

NVIC_InitStructure.NVIC_IRQChannelCmd=ENABLE;

NVIC_Init(&NVIC_InitStructure);

}

这部分就不详述了

2、定时器的配置才是重点


/*TIM_Period--1000TIM_Prescaler--71-->中断周期为1ms*/

voidTIM2_Configuration(void)

{

TIM_TimeBaseInitTypeDefTIM_TimeBaseStructure;

RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE);

TIM_DeInit(TIM2);

TIM_TimeBaseStructure.TIM_Period=1000;/*自动重装载寄存器周期的值(计数值)*/

/*累计TIM_Period个频率后产生一个更新或者中断*/

TIM_TimeBaseStructure.TIM_Prescaler=(72-1);/*时钟预分频数72M/72*/

TIM_TimeBaseStructure.TIM_ClockDivision=TIM_CKD_DIV1;/*采样分频*/

TIM_TimeBaseStructure.TIM_CounterMode=TIM_CounterMode_Up;/*向上计数模式*/

TIM_TimeBaseInit(TIM2,&TIM_TimeBaseStructure);

TIM_ClearFlag(TIM2,TIM_FLAG_Update);/*清除溢出中断标志*/

TIM_ITConfig(TIM2,TIM_IT_Update,ENABLE);

TIM_Cmd(TIM2,ENABLE);/*开启时钟*/

RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,DISABLE);/*先关闭等待使用*/

}

还是一样,找到这个结构体


TIM_TimeBaseInitTypeDef{

uint16_tTIM_ClockDivision

uint16_tTIM_CounterMode

uint16_tTIM_Period

uint16_tTIM_Prescaler

uint8_tTIM_RepetitionCounter

}

1、TIM_ClockDivision用来设置时钟分频的,它的取值可以是


#defineTIM_CKD_DIV1((uint16_t)0x0000)#defineTIM_CKD_DIV2((uint16_t)0x0100)#defineTIM_CKD_DIV4((uint16_t)0x0200)

2、TIM_CounterMode用于设置计数模式



#defineTIM_CounterMode_CenterAligned1((uint16_t)0x0020)#defineTIM_CounterMode_CenterAligned2((uint16_t)0x0040)#defineTIM_CounterMode_CenterAligned3((uint16_t)0x0060)#defineTIM_CounterMode_Down((uint16_t)0x0010)#defineTIM_CounterMode_Up((uint16_t)0x0000)

3、TIM_Period


Specifies the period value to be loaded into the active Auto-Reload Register at the next update event. This parameter must be a number between 0x0000 and 0xFFFF.

就是一个重装值而已!

4、TIM_Prescaler明显是一个时钟与分频系数

Specifies the prescaler value used to divide the TIM clock. This parameter can be a number between 0x0000 and 0xFFFF

设置范围比较广,这里有一个计算公式


5、TIM_RepetitionCounter

Specifies the repetition counter value. Each time the RCR downcounter reaches zero, an update event is generated and counting restarts from the RCR value (N)

这是在PWM里面用到的,这里可以不作设置

6、配置中断,清除中断标志位


TIM_ClearFlag(TIM2,TIM_FLAG_Update);/*清除溢出中断标志*/

TIM_ITConfig(TIM2,TIM_IT_Update,ENABLE);


至此整个TIM2就配置完毕!不难得出,最后出来的结果就是:


/*TIM_Period--1000 TIM_Prescaler--71 -->中断周期为1ms*/

7、还漏了一个初始化函数,就是将TIMx设置为默认值!


voidTIM_DeInit(TIM_TypeDef*TIMx)

{

/*Checktheparameters*/

assert_param(IS_TIM_ALL_PERIPH(TIMx));

switch(*(uint32_t*)&TIMx)

{

caseTIM1_BASE:

RCC_APB2PeriphResetCmd(RCC_APB2Periph_TIM1,ENABLE);

RCC_APB2PeriphResetCmd(RCC_APB2Periph_TIM1,DISABLE);

break;

caseTIM2_BASE:

RCC_APB1PeriphResetCmd(RCC_APB1Periph_TIM2,ENABLE);

RCC_APB1PeriphResetCmd(RCC_APB1Periph_TIM2,DISABLE);

break;

caseTIM3_BASE:

RCC_APB1PeriphResetCmd(RCC_APB1Periph_TIM3,ENABLE);

RCC_APB1PeriphResetCmd(RCC_APB1Periph_TIM3,DISABLE);

break;

caseTIM4_BASE:

RCC_APB1PeriphResetCmd(RCC_APB1Periph_TIM4,ENABLE);

RCC_APB1PeriphResetCmd(RCC_APB1Periph_TIM4,DISABLE);

break;

caseTIM5_BASE:

RCC_APB1PeriphResetCmd(RCC_APB1Periph_TIM5,ENABLE);

RCC_APB1PeriphResetCmd(RCC_APB1Periph_TIM5,DISABLE);

break;

caseTIM6_BASE:

RCC_APB1PeriphResetCmd(RCC_APB1Periph_TIM6,ENABLE);

RCC_APB1PeriphResetCmd(RCC_APB1Periph_TIM6,DISABLE);

break;

caseTIM7_BASE:

RCC_APB1PeriphResetCmd(RCC_APB1Periph_TIM7,ENABLE);

RCC_APB1PeriphResetCmd(RCC_APB1Periph_TIM7,DISABLE);

break;

caseTIM8_BASE:

RCC_APB2PeriphResetCmd(RCC_APB2Periph_TIM8,ENABLE);

RCC_APB2PeriphResetCmd(RCC_APB2Periph_TIM8,DISABLE);

break;

default:

break;

}

}


可以看到这里设置了各种定时器的默认值,我们只需要传入一个参数就能自动的找到相应的分支进行初始化,非常明朗!


二、毫无疑问,我们既然产生了中断,那么我们的中断函数怎么实现呢?在哪里实现呢?接着看我们在 it.c 文件中实现的中断函数!


voidTIM2_IRQHandler(void)

{

if(TIM_GetITStatus(TIM2,TIM_IT_Update)!=RESET)

{

TIM_ClearITPendingBit(TIM2,TIM_FLAG_Update);

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

单片机定时器通过晶振频率来产生精准的计数脉冲,从而实现微秒级别的时间控制。 单片机定时器依托于一个稳定的计数器,该计数器与单片机上的晶振部件相连。晶振经过12分频后,为单片机提供稳定且精准的1MHZ脉冲。由于晶振的频率极...

关键字: 单片机 定时器

编码器‌是一种传感器,主要用于测量旋转运动的角度、角速度和位移等参数。常见的编码器类型包括增量式编码器和绝对值编码器,前者通过检测脉冲的增加或减少来测量旋转方向和距离,后者则直接输出当前的绝对位置信息‌。

关键字: 编码器‌ 定时器

一款语音控制的番茄时间定时器,内置Seeed Studio XIAO ESP32S3感测和圆形显示。用免提时间管理保持高效!

关键字: 定时器 ESP32S3 语音控制

【2025年3月20日, 德国慕尼黑讯】全球功率系统和物联网领域的半导体领导者英飞凌科技股份公司(FSE代码:IFX / OTCQX代码: IFNNY)近日宣布,其旗下ModusToolboxTM开发平台中的AIROC™...

关键字: MCU 物联网 定时器

众所周知,说到延时,很多人都会想到用软件件来实现,比如定时器之类的。今天就来说说用硬件来实现定时的方式,虽说没有那么准,但是有些场合还是用得到的。

关键字: CD4060 定时器

如果定时器的重装值和分频设置不正确,会导致PWM输出的频率和占空比不准确,从而产生误差‌1。

关键字: 定时器 分频

SysTick定时器的工作原理主要基于一个递减计数器的机制。以下是对SysTick定时器工作原理的详细解释:

关键字: SysTick 定时器

单片机定时器是一种用于计时和定时操作的功能模块。它通常用于生成延时、计数事件以及产生精确的时间间隔信号。

关键字: 定时器 时钟源

在现代嵌入式系统设计中,51单片机作为一种经典的微控制器,凭借其丰富的功能和广泛的应用领域,仍然受到工程师们的青睐。定时器中断是51单片机中一个非常实用的功能,它可以在特定的时间间隔内自动触发中断,执行预设的操作,从而提...

关键字: 51单片机 定时器

Holtek新推出BS67F2432具备触控按键、高精准度HIRC与LCD驱动器Flash MCU。主要特色为内建高精准度4MHz HIRC振荡电路、8路触控按键及最大支持4COM×15SEG LCD驱动器。适用于触控接...

关键字: MCU LCD驱动器 定时器
关闭