利用通用定时器 TIM2实现LED 精确延时 1s
时间: 2023-07-07 12:40:41 浏览: 395
好的,可以通过以下步骤实现:
1. 配置 TIM2 的时钟源和预分频器,使其时钟频率为 1MHz。
2. 配置 TIM2 的计数模式为向上计数,设置自动重载值为 999(即计数器从 0 到 999,共 1000 个计数值,每个计数值的时间为 1us)。
3. 启动 TIM2 计数器。
4. 在程序中使用 TIM2 的中断服务函数,在每次计数器溢出时,将 LED 置反。
5. 在程序中使用一个变量记录已经延时的时间,当延时时间达到 1s 时停止计数器,并将 LED 熄灭。
下面是一个简单的实现示例:
```c
#include "stm32f10x.h"
volatile uint32_t delay_time = 0;
void TIM2_IRQHandler(void)
{
if (TIM2->SR & TIM_SR_UIF) {
TIM2->SR &= ~TIM_SR_UIF; // 清除中断标志位
GPIOC->ODR ^= GPIO_Pin_13; // 翻转 LED 状态
delay_time++; // 增加延时时间
}
}
void delay_ms(uint32_t ms)
{
delay_time = 0;
TIM2->CR1 |= TIM_CR1_CEN; // 启动计数器
while (delay_time < ms * 1000); // 等待延时完成
TIM2->CR1 &= ~TIM_CR1_CEN; // 停止计数器
GPIOC->BSRR = GPIO_Pin_13; // 熄灭 LED
}
int main(void)
{
RCC->APB2ENR |= RCC_APB2ENR_IOPCEN; // 使能 GPIOC 时钟
RCC->APB1ENR |= RCC_APB1ENR_TIM2EN; // 使能 TIM2 时钟
GPIOC->CRH &= ~GPIO_CRH_CNF13; // PC13 推挽输出
GPIOC->CRH |= GPIO_CRH_MODE13_0;
TIM2->PSC = 71; // 预分频器为 72-1
TIM2->ARR = 999; // 自动重载值为 1000-1
TIM2->DIER |= TIM_DIER_UIE; // 允许更新中断
NVIC_EnableIRQ(TIM2_IRQn); // 使能 TIM2 中断
while (1) {
delay_ms(1000); // 延时 1s
}
}
```
需要注意的是,上面的代码只是一个简单的示例,实际应用中要根据具体的需求进行修改和优化。
阅读全文