STM32hal库实现微秒延迟

毫秒延时实现原理

系统时钟源

许多人初次使用hal库,不知道HAL_Delay的实现原理。

大致来说,它的实现步骤如下:
1.用变量获得系统时钟源计数器的值

2.获得要延迟时间的参数值

3.比较两者大小,若时钟计数器的值大于要实现延迟的值,就会困在循环里;反之,跳出循环,延时完成。

具体代码如下,需认真观看。

HAL_TickFreqTypeDef HAL_GetTickFreq(void)
{
  return uwTickFreq;
}
__weak void HAL_Delay(uint32_t Delay)
{
  uint32_t tickstart = HAL_GetTick();
  uint32_t wait = Delay;

  /* Add a freq to guarantee minimum wait */
  if (wait < HAL_MAX_DELAY)
  {
    wait += (uint32_t)(uwTickFreq);
  }

  while ((HAL_GetTick() - tickstart) < wait)
  {
  }
}

通过定时器实现微秒延迟

配置定时器

 这里ARR设置为最大值65535,PSC为72-1,通过调整PSC来使得计数器的值每增加一,时间过去一微秒.公式:freq=CLK/(PSC+1)。

在TIM.c中定义函数

 

__weak uint16_t HAL_GetTick_us(void)
{
  return __HAL_TIM_GetCounter (&htim6 );//获取定时器6计数器的值
}
__weak void HAL_Delay_us(uint16_t Delay)
{
  uint16_t tickstart = HAL_GetTick_us();//计数器初始值
  uint16_t wait = Delay;//需要延时的值
	HAL_TIM_Base_Start (&htim6); //打开定时器
  while ((HAL_GetTick_us() - tickstart) < wait)//等待
  {
  }
	HAL_TIM_Base_Stop(&htim6); //关闭定时器
	 __HAL_TIM_SetCounter (&htim6,0 );//定时器计数器清零,往往可以省略,会自动清零
}

在main.c中声明后可以使用

 以上是全部内容,欢迎来我的主页观看交流其它内容,以后会持续更新。

版权声明:本文为CSDN博主「支无朱」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/m0_65565606/article/details/122883740

生成海报
点赞 0

支无朱

我还没有学会写个人说明!

暂无评论

发表评论

相关推荐

stm32——4、中断exti

这里是基于正点原子开发板的学习记录。 首先你要加入固件库 stm32f10x_exti.h 和 stm32f10x_exti.c 1、STM32中每个io口都可以作为外部中断的中断输入口。 2、STM32F103的中断控制器支持19个外部中断/

STM32的GPIO端口

GPIO:General Purpose Input & Output STM32芯片最拥有GPIOA、GPIOB…GPIOG等7组端口,每组端口最多拥有Pin0、Pin1…Pin15共16个引脚。 STM32的每个

STM32外部中断控制LED灯

EXTI简介 EXTI是外部中断控制器,管理了控制器的20个中断/事件。每个中断/事件都对应一个边沿检测器,可以实现输入信号的上升沿检测和下降沿检测。EXTI可以实现对每个中断/事件进行单独配置。 EXTI功能框