HAL库中同时实现微秒级us以及毫秒级ms延时

HAL库要实现毫秒延时很简单,直接调用HAL_Delay();延时函数就可以了。(这个函数每隔1ms就会产生一次中断)

但是,要实现微秒的话。。。貌似就没有现成的方法了。

所以我这边通过基础定时器Timer6,通过轮询的方式实现微秒级延时。(对于微秒级延时,如果通过中断方式实现会导致过于频繁的进入中断,干扰其他中断的及时响应)

首先在STM32CubeMx中打开Timer6并按如下方式配置:(timer6时钟是72M)

注意,在NVIC Settings中的中断是不需要使能的:

然后生成代码,并在tim.c中添加如下代码:(当然还得在tim.h中添加函数声明)

/* USER CODE BEGIN 1 */
void Delay_us(uint16_t us)
{
//	uint16_t counter= us & 0xffff;

  HAL_TIM_Base_Start(&htim6);
  __HAL_TIM_SetCounter(&htim6,0);       // 对上次延时产生的计数清零

  us = (us > 4)?(us-2):1;    // 对counter的改变是为了让短时长的延时更精确(通过示波器校正过,timer的时钟是72M)

  while( us > __HAL_TIM_GetCounter(&htim6) ) {};		

  HAL_TIM_Base_Stop(&htim6);
}
/* USER CODE END 1 */

这样就可以直接调用Delay_us();函数进行微秒级延时啦。

  • 3
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 9
    评论
STM32实现毫秒微秒延时可以使用 SysTick 定时器和内部时钟校准的方式。 首先,需要配置 SysTick 定时器作为断源,使其每隔一定时间(例如 1 毫秒)产生一次断。然后,在断服务函数计数器自增,用于记录经过的时间。最后,在需要延时的地方,可以通过判断计数器是否达到指定值来进行延时。 以下是一个基于 SysTick 定时器毫秒延时函数: ```c void delay_ms(uint32_t ms) { uint32_t start_time = HAL_GetTick(); while ((HAL_GetTick() - start_time) < ms); } ``` 这个函数使用了 HAL 库提供的 HAL_GetTick() 函数来获取当前的毫秒时间戳,然后在循环等待时间达到指定值。 对于微秒延时,可以使用内部时钟校准方式。在 STM32 ,内部时钟提供了一个精确的时钟源,可以用于生成微秒延时。以下是一个基于内部时钟的微秒延时函数: ```c void delay_us(uint32_t us) { uint32_t start_time = DWT->CYCCNT; uint32_t delay_cycles = us * (SystemCoreClock / 1000000); while ((DWT->CYCCNT - start_time) < delay_cycles); } ``` 这个函数使用了 DWT 寄存器提供的 CYCCNT 寄存器来记录 CPU 周期数,然后在循环等待 CPU 周期数达到指定值。需要注意的是,使用 DWT 寄存器需要先打开 DWT 和 CPU 周期计数器。 需要注意的是,以上两个函数的延时时间是近似值,可能会因为硬件和软件因素而有所偏差。对于需要更加精确的延时,可以使用硬件定时器或者外部时钟源。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值