STM32 hal库使用笔记(三)定时器—输入捕获和计数脉冲

这篇具有很好参考价值的文章主要介绍了STM32 hal库使用笔记(三)定时器—输入捕获和计数脉冲。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一、简介

1.定时器简介

2.输入捕获简介

3.原理介绍

二、HAL库配置

1.时钟树的设置

2.定时器时钟源选择

2.1 计数脉冲(代码对应3.1)

2.2 输入捕获(对应代码3.2)

 三、代码编写


实验目的:利用定时器输入捕获实现LED翻转;按键充当外部时钟源,实现LED翻转

实验平台:正点原子精英板

一、简介

1.定时器简介

参考:STM32 hal库使用笔记(二)中断—定时器中断_乱码小伙的博客-CSDN博客

2.输入捕获简介

    IC(Input Capture)输入捕获 输入捕获模式下,当通道输入引脚出现指定电平跳变时,当前CNT的值将被锁存到CCR中,可用于测量PWM波形的频率、占空比、脉冲间隔、电平持续时间等参数。

3.原理介绍

    以下纯属个人理解,欢迎大家交流和指正,可能会有不准确的地方。

    输入捕获,大部分利用的是内部时钟作为时钟源,设置PSC的值来决定计数器的计数频率(即发生一次脉冲的时间),再配合设置的ARR的值可以得出定时器的周期/频率。当使能输入捕获以后,配合输入捕获回调函数,记录输入脉冲的次数(包括上升沿/下降沿/双边沿)。那么周期*脉冲次数可以得出脉冲源的频率/周期。

   计数脉冲我的理解是原理上简单很多,主要是将芯片上某个引脚复用为定时器的通道从而作为定时器的时钟源,每输入一次脉冲(高/低/双边),CNT的值加一,从而可以计算脉冲的数值,同样也可以开启定时中断,设置ARR的值,当达到预设值会触发中断,从而完成中断回调函数中的操作。不过这样的话,无法软件得出脉冲的工作周期/频率,因为定时器的触发中断的周期无法软件计算。

    本次实验只是简单测试原理。

二、HAL库配置

1.时钟树的设置

参考:STM32 hal库使用笔记(一)GPIO的使用—流水灯_乱码小伙的博客-CSDN博客

2.定时器时钟源选择
2.1 计数脉冲(代码对应3.1)

    利用按键即PA0作为时钟源,输入脉冲,并开启对应中断引脚。

stm32输入脉冲计数,STM32的hal库使用,stm32,笔记,嵌入式硬件

 配置参数:

由于只是简单测试,测试原理:输入5次上升沿,LED灯点亮。由于按键一端接的是高电平,所以触发极性选择:上升沿。开启自动重装。LED灯的配置省略。

stm32输入脉冲计数,STM32的hal库使用,stm32,笔记,嵌入式硬件

PA0的配置,下拉输入。

stm32输入脉冲计数,STM32的hal库使用,stm32,笔记,嵌入式硬件

配置完成后生成代码即可。

2.2 输入捕获(对应代码3.2)

   主要是利用按键输入上升沿,检验输入捕获回调函数是否能够使用。打开NVIC对应中断,配置优先级(默认就行,反正只有一个中断)。

stm32输入脉冲计数,STM32的hal库使用,stm32,笔记,嵌入式硬件

 三、代码编写

3.1

   使用HAL库后,定时器初始化,参数配置,公共服务函数等都已经完成,用户只需要打开中断,配置回调函数即可。

void MX_TIM2_Init(void)
{
  TIM_SlaveConfigTypeDef sSlaveConfig = {0};
  TIM_MasterConfigTypeDef sMasterConfig = {0};

  htim2.Instance = TIM2;
  htim2.Init.Prescaler = 0;
  htim2.Init.CounterMode = TIM_COUNTERMODE_UP;
  htim2.Init.Period = 1;//按键有抖动,所以次数设置为1,能实现即可,后面会出文章继续补充,本次只是检测原理
  htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  htim2.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE;
  if (HAL_TIM_Base_Init(&htim2) != HAL_OK)
  {
    Error_Handler();
  }
  sSlaveConfig.SlaveMode = TIM_SLAVEMODE_EXTERNAL1;
  sSlaveConfig.InputTrigger = TIM_TS_TI1FP1;
  sSlaveConfig.TriggerPolarity = TIM_TRIGGERPOLARITY_RISING;
  sSlaveConfig.TriggerFilter = 0;
  if (HAL_TIM_SlaveConfigSynchro(&htim2, &sSlaveConfig) != HAL_OK)
  {
    Error_Handler();
  }
  sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  if (HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK)
  {
    Error_Handler();
  }
  HAL_TIM_Base_Start_IT(&htim2);//用户添加,使能中断
}

 tim.c的用户编码区添加中断更新回调函数

    特别主要的是:我配置完成后上电会自动进入一次回调函数,百度后的说法是中断使能等参数配置时顺序的问题,暂未实验成功,所以代码中软件屏蔽掉了。大家如果有解决办法,希望分享。

 void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
 {
     static unsigned i;
     i++;
     if (htim->Instance == TIM2)
    {
        HAL_GPIO_TogglePin(LED0_GPIO_Port, LED0_Pin);
        HAL_GPIO_TogglePin(LED1_GPIO_Port, LED1_Pin);
    }
    if(i==1)
    {
        HAL_GPIO_TogglePin(LED0_GPIO_Port, LED0_Pin);
        HAL_GPIO_TogglePin(LED1_GPIO_Port, LED1_Pin);
    }    
 }

 实验效果:

定时器计算脉冲数

3.2

同理,用户只需使能中断和使能输入捕获即可。

void MX_TIM2_Init(void)
{
  TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  TIM_MasterConfigTypeDef sMasterConfig = {0};
  TIM_IC_InitTypeDef sConfigIC = {0};

  htim2.Instance = TIM2;
  htim2.Init.Prescaler = 7200;
  htim2.Init.CounterMode = TIM_COUNTERMODE_UP;
  htim2.Init.Period = 5000;
  htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  htim2.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_ENABLE;
  if (HAL_TIM_Base_Init(&htim2) != HAL_OK)
  {
    Error_Handler();
  }
  sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  if (HAL_TIM_ConfigClockSource(&htim2, &sClockSourceConfig) != HAL_OK)
  {
    Error_Handler();
  }
  if (HAL_TIM_IC_Init(&htim2) != HAL_OK)
  {
    Error_Handler();
  }
  sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  if (HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK)
  {
    Error_Handler();
  }
  sConfigIC.ICPolarity = TIM_INPUTCHANNELPOLARITY_RISING;
  sConfigIC.ICSelection = TIM_ICSELECTION_DIRECTTI;
  sConfigIC.ICPrescaler = TIM_ICPSC_DIV1;
  sConfigIC.ICFilter = 0;
  if (HAL_TIM_IC_ConfigChannel(&htim2, &sConfigIC, TIM_CHANNEL_1) != HAL_OK)
  {
    Error_Handler();
  }
      HAL_TIM_IC_Start_IT(&htim2, TIM_CHANNEL_1);       /* 用户添加,使能输入捕获 */
    __HAL_TIM_ENABLE_IT(&htim2, TIM_IT_UPDATE);         /* 用户添加,使能更新中断 */

}

在tim.c中添加中断更新回调函数和输入捕获回调函数即可:

 void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
 {
     if (htim->Instance == TIM2)
    {
        HAL_GPIO_TogglePin(LED0_GPIO_Port, LED0_Pin);
    }   
 }
 void HAL_TIM_IC_CaptureCallback(TIM_HandleTypeDef *htim)
 {
     if (htim->Instance == TIM2)
    {
        HAL_GPIO_TogglePin(LED1_GPIO_Port, LED1_Pin);
        TIM_RESET_CAPTUREPOLARITY(&htim2, TIM_CHANNEL_1);                      /* 一定要先清除原来的设置 */
        TIM_SET_CAPTUREPOLARITY(&htim2, TIM_CHANNEL_1, TIM_ICPOLARITY_RISING); /* 配置TIM5通道1上升沿捕获 */
    }  
 
 }

实验效果:LED0定时闪烁,每收到一次上升沿会使得LED1翻转

定时器输入捕获

欢迎大家交流和指正!!!不胜欣喜!文章来源地址https://www.toymoban.com/news/detail-759886.html

到了这里,关于STM32 hal库使用笔记(三)定时器—输入捕获和计数脉冲的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • 基于HAL库的STM32单定时器多路输入捕获测量PWM的频率和占空比实现(状态机方式实现)

    基于HAL库的STM32单定时器多路输入捕获测量PWM的频率和占空比实现(状态机方式实现)

    目录  写在前面 先回顾下定时器的单路捕获PWM 多路捕获PWM的频率和占空比(状态机实现) 我的思路: 状态图 配置 给出示例代码 测试效果         先有了这篇文章实现了单定时器的多通道测量频率,以外部时钟的方式可测量任意频率的方波),奈何不能多路测试PWM波的频率,

    2024年02月12日
    浏览(9)
  • STM32笔记——定时器输入捕获功能(测量PWM的频率和占空比)

    STM32笔记——定时器输入捕获功能(测量PWM的频率和占空比)

    目录 一、概述 二、输入捕获功能 2.1 输入捕获简介 2.2 输入捕获通道  三、输入捕获功能测量PWM波的频率和占空比 3.1 测量频率的方法 3.2 测量过程         主要介绍通用定时器的输入捕获功能,输入信号由GPIO口进入输入捕获通道,之后输入部分对相应的TIx输入信号采样,并

    2024年02月06日
    浏览(29)
  • STM32定时器(输入捕获)

    STM32定时器(输入捕获)

     上一章讲了输出比较的内容,输出比较就是定时器自增,同时和CCR比较,按照自己设置的比较要求,输出REF高低电平,这一章我们讲下面结构图输出比较左边部分,也就是 输入捕获 首先,介绍一下输入捕获 IC(input capture)输入捕获,输入捕获模式下,当通道输入引脚出现

    2024年02月09日
    浏览(10)
  • STM32定时器-输入捕获

    STM32定时器-输入捕获

    输入捕获工作过程 一句话总结工作过程:通过检测TIMx_CHx上的边沿信号,在边沿信号发生跳变(比如上升沿/下降沿)的时候,将当前定时器的值(TIMx_CNT)存放到对应的捕获/比较寄存器(TIMxCCRx)里面,完成一次捕获。 步骤1:设置输入捕获滤波器(通道1为例) 输入捕获1滤

    2024年02月15日
    浏览(10)
  • stm32---定时器输入捕获

    stm32---定时器输入捕获

            在定时器中断实验章节中我们介绍了通用定时器具有多种功能,输入捕获就是其中一种。 STM32F1除了基本定时器TIM6和TIM7,其他定时器都具有输入捕获功能 。输入捕获可以对输入的信号的上升沿,下降沿或者双边沿进行捕获,通常用于测量输入信号的脉宽、测量

    2024年01月19日
    浏览(12)
  • stm32 定时器输入捕获实验

    stm32 定时器输入捕获实验

    目录 一,简介 二,配置过程  一,设置输入捕获滤波器​ 二,设置输入极性 三,设置输入捕获映射通道  四,设置输入捕获分频器  五,设置中断  ​三,寄存器 四,库函数 五,一般步骤   六,软件部分 输入捕获模式可以用来测量脉冲宽度或者测量频率 原理图 如图  

    2024年01月21日
    浏览(8)
  • STM32 定时器输入捕获3——捕获超长高电平

            第一章:https://blog.csdn.net/m0_73671341/article/details/134773615?spm=1001.2014.3001.5501         第二章:https://blog.csdn.net/m0_73671341/article/details/134938332?spm=1001.2014.3001.5501         从第一章的定时器捕获我们可以知道,即使把定时器捕获时长设置到最大也只有65.536ms,而第二章就

    2024年01月18日
    浏览(10)
  • STM32 定时器输入捕获2——捕获高电平时长

    STM32 定时器输入捕获2——捕获高电平时长

            由上图我们可以知道,高电平时间=t2-t1。在代码中,可以记录此时t1的时间然后再记录t2的时间,t2-t1,就是我们所想要的答案。         但是,还有更简单一点点的,当到达t1的时候,我们把定时器清零,然后直接读出t2,就是这个高电平的时间。 1.当TIM3的TIM_F

    2024年01月18日
    浏览(11)
  • STM32标准库通用定时器输入捕获

    STM32标准库通用定时器输入捕获

    输入捕获为STM32定时器的一个功能,可以用来测量输入信号的频率和占空比。 具体原理:当输入信号经过比较捕获通道时,STM32会依据通道的极性设置决定是否触发捕获中断TIM_IT_CCx。此时定时器会将当前计数值TIMx-CNT的值保存在TIMx-CCRx中,通过计算两次捕获中断的时间差便可

    2024年03月11日
    浏览(9)
  • STM32学习笔记(六)丨TIM定时器及其应用(输入捕获丨测量PWM波形的频率和占空比)

    STM32学习笔记(六)丨TIM定时器及其应用(输入捕获丨测量PWM波形的频率和占空比)

    ​  本次课程采用单片机型号为STM32F103C8T6。 ​  课程链接:江科大自化协 STM32入门教程   往期笔记链接:   STM32学习笔记(一)丨建立工程丨GPIO 通用输入输出   STM32学习笔记(二)丨STM32程序调试丨OLED的使用   STM32学习笔记(三)丨中断系统丨EXTI外部中断

    2023年04月19日
    浏览(12)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包