在stm32中利用systick来延时,这阻塞了CPU吗? 执行到延时程序的时候,CPU就一直停在那里等待时间到达么?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在stm32中利用systick来延时,这阻塞了CPU吗? 执行到延时程序的时候,CPU就一直停在那里等待时间到达么?相关的知识,希望对你有一定的参考价值。
从现象上来说,确实是阻塞了CPU,延时的目的就是让CPU停住一段时间。
systick嘀嗒定时器在延时的时候,一直判断标志位,用while语句,这样cpu就一直停在这里了,知道标志位置位,再跳出等待,这样就实现精准延时了。
还有问题,欢迎追问。追问
THX..懂了。。大哥,再问个串口的问题。。波特率计算公式=Fpclk2/(16*usartdiv)。。我想问问为什么要除以16啊?
追答哈哈,这个是st内部的设计了吧。可以理解为芯片设计的时候,将主频16分频之后作为uart的波特率发生器。由于Fpclk是你在配置时钟的时候就定下来了,所以对于便一起来说Fpclk是一个确定的数,那么uart的时钟也就确定下来了。
不知道我这样说你能不能理解,如果还有问题,请继续追问。
STM32 HAL库 us延时
//利用已有的SysTick配置,读取计数判断延迟 void delay_us(uint32_t udelay) { uint32_t startval,tickn,delays,wait; startval = SysTick->VAL; tickn = HAL_GetTick(); //sysc = 72000; //SystemCoreClock / (1000U / uwTickFreq); delays =udelay * 72; //sysc / 1000 * udelay; if(delays > startval) { while(HAL_GetTick() == tickn) { } wait = 72000 + startval - delays; while(wait < SysTick->VAL) { } } else { wait = startval - delays; while(wait < SysTick->VAL && HAL_GetTick() == tickn) { } } }
以上是关于在stm32中利用systick来延时,这阻塞了CPU吗? 执行到延时程序的时候,CPU就一直停在那里等待时间到达么?的主要内容,如果未能解决你的问题,请参考以下文章