STM32----TIM6和TIM7

基本定时器TIM6和TIM7

对于STM32来说有8个TIM定时器,TIM1和TIM8为高级定时器、TIM2~5为通用定时器,TIM6和TIM7位基本定时器。他们都是十六位的定时器。
今天说的是TIM6和TIM7基本定时器,它的功能最简单。有两个寄存器一个是TIMx_CNT(小跑),另一个是TIMx_ARR(目标)。工作时每来一个时钟脉冲小跑就加一,直到小跑中的数值和目标中的数值相等,将小跑中的数值清零,进入中断函数进行相应的处理。可以看到这个过程中比较重要的就是这个时钟脉冲,脉冲来的快慢对计数有相当大的影响。
考虑时钟源相关的知识:通常情况下配置AHB=72MHz,APB1的预分频器的分频系数为2,刚好PCLK1=36MHz,此时TIMxCLK = (AHB/2)*2=72MHz。对于该TIMxCLK时钟是TIM2~7的公共时钟源,TIM1和TIM8则是在APB2.
而对于上面所说的技术脉冲并不是这个TIMxCLK,而是TIMxCLK经过PSC预分频器之后的。对于PSC预分频器中的分频参数是需要我们手动配置的参数的范围为1-65535.
在这里插入图片描述
通过上面的基本定时器的工作过程和时钟源的相关内容,在基本定时器中主要配置两个参数,一个是PSC预分频器的分频系数,另一个就是TIMxARR的值,该值作为定时器计数的上限值,决定了每次进入中断的时间。由这两个值就可计算出进入一次中断时间t
用 于 计 数 的 时 钟 频 率 = T I M x C L K P S C 分 频 系 数 + 1 用于计数的时钟频率={\frac{TIMxCLK}{PSC分频系数+1}} =PSC+1TIMxCLK
进 入 一 次 中 断 的 时 间 t = 1 T I M x C L K P S C 分 频 系 数 + 1 ∗ T I M x A R R 进入一次中断的时间t=\frac{1}{\frac{TIMxCLK}{PSC分频系数+1}}*TIMxARR t=PSC+1TIMxCLK1TIMxARR
具体的代码:

void TIM6_Config(void)//配置TIM6每隔一秒进入一次中断
{
	TIM_TimeBaseInitTypeDef tim_s;
	
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM6,ENABLE);
	
	tim_s.TIM_Prescaler = 7199;
	tim_s.TIM_Period = 9999;
	TIM_TimeBaseInit(TIM6,&tim_s);
	TIM_ITConfig(TIM6,TIM_IT_Update,ENABLE);
	TIM_Cmd(TIM6,ENABLE);
}
void TIM7_Config(void)//配置TIM7每隔1ms进入一次中断
{
	TIM_TimeBaseInitTypeDef tim_s;
	
	RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM7,ENABLE);
	
	tim_s.TIM_Prescaler = 71;
	tim_s.TIM_Period = 999;
	TIM_TimeBaseInit(TIM7,&tim_s);
	TIM_ITConfig(TIM7,TIM_IT_Update,ENABLE);
	TIM_Cmd(TIM7,ENABLE);
}

在中断中完成相应的定时任务:

void TIM6_IRQHandler(void)
{
	if(TIM_GetITStatus(TIM6,TIM_IT_Update)!=RESET)
	{
		GPIO_WriteBit(GPIOA,GPIO_Pin_8,(BitAction)(1-GPIO_ReadOutputDataBit(GPIOA,GPIO_Pin_8)));
		TIM_ClearITPendingBit(TIM6,TIM_IT_Update);
	}
}
void TIM7_IRQHandler(void)
{
	if(TIM_GetITStatus(TIM7,TIM_IT_Update) != RESET)
	{
		tim7_count++;
		if(tim7_count == 500)
		{
			tim7_count = 0;
			GPIO_WriteBit(GPIOD,GPIO_Pin_2,(BitAction)(1-GPIO_ReadOutputDataBit(GPIOD,GPIO_Pin_2)));
		}
		TIM_ClearITPendingBit(TIM7,TIM_IT_Update);
	}
}

STM32库开发实战指南

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用 STM32-HAL 库读取编码器时,如果出现读取到负数的情况,可能会导致程序卡死的问题。这是因为 HAL 库默认使用的是 32 位定时器计数器,而编码器的计数器是一个 16 位的有符号整型,当计数器值达到 32767(0x7FFF)时,会变为负数,这会导致 HAL 库出现异常。 为了解决这个问题,可以使用以下两种方法之一: 1. 使用 16 位定时器计数器 可以通过修改定时器的初始化配置,将其设置为 16 位计数器模式。这样可以保证计数器值始终为 16 位有符号整型,不会出现负数的情况。例如,对于 TIM2 定时器,可以使用以下代码进行初始化: ```c TIM_HandleTypeDef htim2; // ... htim2.Instance = TIM2; htim2.Init.Prescaler = 0; htim2.Init.CounterMode = TIM_COUNTERMODE_UP; htim2.Init.Period = 65535; // 设置为 16 位计数器模式 htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; htim2.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE; if (HAL_TIM_Base_Init(&htim2) != HAL_OK) { // 初始化失败 } if (HAL_TIM_Base_Start_IT(&htim2) != HAL_OK) { // 启动失败 } ``` 2. 处理负数值 如果无法使用 16 位定时器计数器,可以在程序中对读取到的负数值进行处理。例如,可以将计数器值加上一个足够大的值,使其变为正数。具体的处理方法可以根据实际情况进行调整。以下是一个示例代码: ```c int16_t count = 0; uint32_t offset = 0x10000; // 偏移量为 65536 while (1) { count = __HAL_TIM_GET_COUNTER(&htim2); if (count < 0) { count += offset; } // ... } ``` 以上两种方法都可以解决读取编码器时出现负数导致程序卡死的问题,具体选择哪种方法应根据实际情况进行判断。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值