您的位置 首页 IOT

STM32单片机运用定时器中止方法完成毫秒级延时的规划

STM32单片机使用定时器中断方式实现毫秒级延时的设计-因为STM32 HAL库中仅有对HAl_Delay()毫秒级的延时,为实现精确的微秒级延时,就不得不修改Systick,但由于HAL库内部使用其作为超时判断等操作,对其修改会发生不可预期的错误,不建议修改。因此,使用通用定时器进行定时操作。

由于STM32 HAL库中仅有对HAl_Delay()毫秒级的延时,为完结准确的微秒级延时,就不得不修正SysTIck,但由于HAL库内部运用其作为超时判别等操作,对其修正会产生不行预期的过错,不主张修正。因而,运用通用守时器进行守时操作。

STM32单片机运用守时器中止方法完结毫秒级延时的规划

参阅网上例程,运用守时器中止方法完结延时,代码如下:

TIM3溢出时刻=72MHz/(71+1)/(0+1)=1Mhz=1us

计数形式:向上计数形式

使能TIM3中止

*/

__IO staTIc uint32_t usDelay=0;

void Delayms(uint32_t ms)

{

Delayus(ms*1000);

}

void Delayus(uint32_t us)

{

usDelay=us;

HAL_TIM_Base_Start_IT(&htim3);

while(usDelay);

HAL_TIM_Base_Stop_IT(&htim3);

}

//重写回调函数

void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)

{

if(htim-》Instance == TIM3)

{

if(usDelay!=0)

{

usDelay–;

}

}

}

尽管说以上程序的并没什么过错,但在实践运转中,却无法得到正确的运转。一起,在进行Debug调试时,单步履行又能够正常运转。

主要原因在于:中止间隔时刻太短,导致中止函数还没有运转完结,其中止标志位却再次置位,导致在程序卡死。

因而,封闭守时器中止,选用守时器轮询的方法完结延时,代码如下:

/*

TIM3溢出时刻=72MHz/(71+1)/(0+1)=1Mhz=1us

计数形式:向下计数形式

*/

void Delay_us(uint32_t us){

uint16_t counter=us&0xffff;

HAL_TIM_Base_Start(&htim3);

__HAL_TIM_SetCounter(&htim3,counter);

while(counter》1)

{

counter=__HAL_TIM_GetCounter(&htim3);

}

HAL_TIM_Base_Stop(&htim3);

}

void Delay_ms(uint32_t ms){

Delay_us(1000*ms);

}

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/yingyong/iot/345088.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部