STM32定时器笔记_中断方式_10ms

1. TIM 参考资料整理

《STM32F10xxx参考手册.pdf》P.256
当发生一个更新事件时,所有的寄存器都被更新,硬件同时(依据URS位)设置更新标志位(TIMx_SR寄存器中的UIF位)。 ● 预分频器的缓冲区被置入预装载寄存器的值(TIMx_PSC寄存器的内容)。 ● 自动装载影子寄存器被重新置入预装载寄存器的值(TIMx_ARR)。
在这里插入图片描述
注:内部时钟(CK_INT)
在这里插入图片描述在这里插入图片描述
《[Reference manual]STM32F101xx, STM32F102xx, STM32F103xx, STM32F105xx and STM32F107xx advanced ARM-based 32-bit MCUs.pdf》8.2 Clocks
在这里插入图片描述

2. 10ms定时器,每10ms中断一次,在回调函数中处理。

(1) 设置时钟

STM32F103的TIM2定时器的clock为APB1
《[Datasheet]STM32F103x8_xB.pdf》P.11
在这里插入图片描述
在这里插入图片描述

(2) 设置定时器

在这里插入图片描述
在这里插入图片描述
72 000 000 / 72 / 10 000 = 100Hz,即10ms
自动生成的代码如下:

/* TIM2 init function */
void MX_TIM2_Init(void)
{
  TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  TIM_MasterConfigTypeDef sMasterConfig = {0};

  htim2.Instance = TIM2;
  htim2.Init.Prescaler = 72-1;
  htim2.Init.CounterMode = TIM_COUNTERMODE_UP;
  htim2.Init.Period = 10000-1;
  htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  htim2.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  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();
  }
  sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
  sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
  if (HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK)
  {
    Error_Handler();
  }

}

(3) 在主while(1)前,添加如下代码,开启定时器中断

HAL_TIM_Base_Start_IT(&htim2);

(4) 在程序中添加如下函数,实现10ms中断回调函数

void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{
  if(htim->Instance == TIM2)
  {

  }
}
  • 3
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个在 `stm32f10x_it.c` 中实现定时器中断的示例代码: ```c #include "stm32f10x_it.h" TIM_HandleTypeDef htim2; // 定义定时器句柄 void TIM2_IRQHandler(void) { HAL_TIM_IRQHandler(&htim2); // 调用 HAL 库中的定时器中断处理函数 } void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim) { if (htim->Instance == TIM2) // 判断是哪个定时器中断 { // 定时器中断处理代码 } } void TIM_Config(void) { TIM_ClockConfigTypeDef sClockSourceConfig = {0}; TIM_MasterConfigTypeDef sMasterConfig = {0}; htim2.Instance = TIM2; htim2.Init.Prescaler = 0; htim2.Init.CounterMode = TIM_COUNTERMODE_UP; htim2.Init.Period = 1000; // 定时器周期为 1 秒 htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; HAL_TIM_Base_Init(&htim2); sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL; HAL_TIM_ConfigClockSource(&htim2, &sClockSourceConfig); sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET; sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE; HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig); } int main(void) { HAL_Init(); TIM_Config(); // 配置定时器 HAL_TIM_Base_Start_IT(&htim2); // 启动定时器并开启定时器中断 while (1) { // 循环执行其他代码 } } ``` 在上面的代码中,我们首先定义了一个定时器句柄 `htim2`,然后在 `TIM_Config()` 函数中对定时器进行了初始化配置。在 `main()` 函数中,我们调用了 `TIM_Config()` 函数配置定时器,并通过 `HAL_TIM_Base_Start_IT(&htim2)` 启动定时器和开启定时器中断。 当定时器中断发生时,系统会自动跳转到 `TIM2_IRQHandler()` 函数中执行中断处理代码,该函数中调用了 HAL 库中的定时器中断处理函数 `HAL_TIM_IRQHandler()`。在 `HAL_TIM_PeriodElapsedCallback()` 函数中,我们可以根据 `htim->Instance` 判断是哪个定时器中断,并在其中编写定时器中断处理代码。 需要注意的是,如果你想在 `stm32f10x_it.c` 中编写定时器中断处理代码,你需要将 `HAL_TIM_PeriodElapsedCallback()` 和 `TIM2_IRQHandler()` 函数中的代码注释掉,否则会出现重复定义的错误。同时,你还需要在 `stm32f10x_it.h` 中声明你的定时器中断处理函数,例如: ```c void MyTIM2_IRQHandler(void); ``` 然后在 `stm32f10x_it.c` 中实现该函数即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值