STM32F407定时器延时功能

本文详细介绍了如何在STM32中使用定时器TIM12进行延时,基于APB1和APB2总线的时钟频率168MHz和84MHz设置预分频值,提供配置代码示例和延时函数实现。

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

使用定时器tim12用于延时函数计时。

摘自中文参考手册,各个定时器所在的总线APB1,APB2

使用定时器12作为延时定时器。查看时钟树时钟频率APB2总线,168Mhz,APB1总线84Mhz,以此为依据设置定时器的预分频值。

配置代码如下

#include "delay.h"

TIM_HandleTypeDef htim9;


void delay_init(void)
{

{

  /* USER CODE BEGIN TIM12_Init 0 */

  /* USER CODE END TIM12_Init 0 */

  TIM_ClockConfigTypeDef sClockSourceConfig = {0};
  TIM_SlaveConfigTypeDef sSlaveConfig = {0};

  /* USER CODE BEGIN TIM12_Init 1 */
__HAL_RCC_TIM12_CLK_ENABLE();
  /* USER CODE END TIM12_Init 1 */
  htim12.Instance = TIM12;
  htim12.Init.Prescaler = 84-1; // 设置预分频器,使得计数频率为1MHz
  htim12.Init.CounterMode = TIM_COUNTERMODE_UP;
  htim12.Init.Period = 30000;
  htim12.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
  htim12.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
  if (HAL_TIM_Base_Init(&htim12) != HAL_OK)
  {
    Error_Handler();
  }
  sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
  if (HAL_TIM_ConfigClockSource(&htim12, &sClockSourceConfig) != HAL_OK)
  {
    Error_Handler();
  }
  sSlaveConfig.SlaveMode = TIM_SLAVEMODE_RESET;
  sSlaveConfig.InputTrigger = TIM_TS_ITR0;
  if (HAL_TIM_SlaveConfigSynchro(&htim12, &sSlaveConfig) != HAL_OK)
  {
    Error_Handler();
  }
  /* USER CODE BEGIN TIM12_Init 2 */

  /* USER CODE END TIM12_Init 2 */

}
}


void delay_us(uint16_t us)
{
    __HAL_TIM_SET_COUNTER(&htim12, 0); // 将TIM12的计数器值设置为0
    __HAL_TIM_ENABLE(&htim12);//(&htim12); // 启动定时器

    while (__HAL_TIM_GET_COUNTER(&htim12) < us) {
        // 等待计数器达到指定的延时时间
    }

    __HAL_TIM_DISABLE(&htim12);//HAL_TIM_Base_Stop(&htim12); // 停止定时器
}
void delay_ms(uint32_t ms)
{
    while (ms > 0) {
        delay_us(1000);
        ms--;
    }
}

### STM32F407 高级定时器实现延时功能 对于 STM32F407 而言,利用其内置的高级定时器可以有效地创建精确的延迟。这种方法不仅提高了时间精度,还减轻了处理器负担,使得应用程序能够更高效地执行其他任务。 #### 使用 TIM1 实现毫秒级别延时 TIM1 是一个 16 位自动重装载、向上/向下计数的定时器,在此示例中将被配置为产生固定周期中断来完成延时操作[^1]。 ```c #include "stm32f4xx_hal.h" TIM_HandleTypeDef htim1; void SystemClock_Config(void); static void MX_GPIO_Init(void); static void MX_TIM1_Init(void); int main(void) { HAL_Init(); SystemClock_Config(); MX_GPIO_Init(); MX_TIM1_Init(); uint32_t count = 0; while (1) { // Start the timer to generate a delay of approximately 1 second. __HAL_TIM_SET_COUNTER(&htim1, 0); // Reset counter value while (__HAL_TIM_GET_COUNTER(&htim1) < 8400) {} // Wait until counter reaches desired value HAL_GPIO_TogglePin(GPIOA, GPIO_PIN_5); // Toggle LED on PA5 after each delay period ends } } // Timer initialization function static void MX_TIM1_Init(void) { TIM_ClockConfigTypeDef sClockSourceConfig = {0}; TIM_MasterConfigTypeDef sMasterConfig = {0}; htim1.Instance = TIM1; htim1.Init.Prescaler = 84 - 1; // Set prescaler based on system clock frequency divided by target tick rate htim1.Init.CounterMode = TIM_COUNTERMODE_UP; htim1.Init.Period = 65535; htim1.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; htim1.Init.RepetitionCounter = 0; if (HAL_TIM_Base_Init(&htim1) != HAL_OK) { Error_Handler(); } sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL; if (HAL_TIM_ConfigClockSource(&htim1, &sClockSourceConfig) != HAL_OK) { Error_Handler(); } sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET; sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE; if (HAL_TIMEx_MasterConfigSynchronization(&htim1, &sMasterConfig) != HAL_OK) { Error_Handler(); } /* Enable the timer */ HAL_TIM_Base_Start(&htim1); } ``` 上述代码展示了如何通过设置 `Prescaler` 和等待特定数量的计数值达到预期的延时时长。这里假设系统时钟频率为 84 MHz,则每增加一次 Prescaler 将使输入频率降低相应的倍数;而当 Counter 达到设定的最大值(即 Period)之后会触发溢出事件并重新从零开始计算。因此可以通过调整这两个参数轻松改变实际产生的延长时间。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值