void delay_us(u32 nus) { u32 temp; SysTick->LOAD=nus*fac_us; //时间加载 SysTick->VAL=0x00; //清空计数器 SysTick->CTRL|=SysTick_CTRL_ENABLE_Msk ; //开始倒数 do { temp=SysTick->CTRL; }while((temp&0x01)&&!(temp&(1<<16))); //等待时间到达 SysTick->CTRL&=~SysTick_CTRL_ENABLE_Msk; //关闭计数器 SysTick->VAL =0X00; //清空计数器 }
时间: 2024-03-28 15:39:19 浏览: 177
这段代码是用来实现微秒级延时的函数。它会使用 SysTick 定时器来实现延时,具体实现步骤如下:
1. 将要延时的微秒数乘以一个系数 fac_us,得到对应的 SysTick 计数值。
2. 将计数器值加载到 SysTick 的 LOAD 寄存器中,清空计数器值。
3. 开始倒数,等待计数器值减为 0。
4. 关闭计数器,清空计数器值。
这里需要注意的是,SysTick 定时器的时钟源是系统时钟,而 fac_us 系数的计算方法要根据系统时钟的频率来确定。因此,这段代码的可移植性可能会受到一定的限制。
相关问题
#include "Delay.h" static u8 fac_us=0;//us static u16 fac_ms=0;//ms void Delay_Rough(int time) { int i,j; for(i=0;i<time;i++) for(j=0;j<time;j++) ; } void Delay_Init(u8 SYSCLK) { SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8); //选择外部时钟,HCLK/8 fac_us=SYSCLK/8; fac_ms=(u16)fac_us*1000; } void delay_ms(u16 nms) { u32 temp; SysTick->LOAD=(u32)nms*fac_ms; //时间加载(SysTick->LOAD?24bit) SysTick->VAL =0x00; //清空计数器 SysTick->CTRL=0x01 ; //开始倒数 do { temp=SysTick->CTRL; } while(temp&0x01&&!(temp&(1<<16)));//等待时间到达 SysTick->CTRL=0x00; //关闭计数器 SysTick->VAL =0X00; //清空计数器 } void delay_us(u32 nus) { u32 temp; SysTick->LOAD=nus*fac_us; //时间加载 SysTick->VAL=0x00; //清空计数器 SysTick->CTRL=0x01 ; //开始倒数计数 do { temp=SysTick->CTRL; } while(temp&0x01&&!(temp&(1<<16)));//时间加载 SysTick->CTRL=0x00; //关闭计数器 SysTick->VAL =0X00; //清空计数器 }
这是一个基于STM32的延时函数库,包括了毫秒级和微秒级的延时函数。其中,Delay_Rough函数是一个粗略的延时函数,用于产生较长时间的延时,如数码管显示等。Delay_Init函数用于初始化延时函数库,包括设置SysTick的时钟源以及计算fac_us和fac_ms的值。delay_ms函数用于产生指定毫秒级的延时,delay_us函数用于产生指定微秒级的延时。这些函数的实现都是基于SysTick定时器来实现的,具有较高的精度和稳定性。
#include "stm32f10x.h" #include "delay.h" static u8 fac_us=0;//usÑÓʱ±¶³ËÊý static u16 fac_ms=0;//msÑÓʱ±¶³ËÊý void DelayInit() { SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8); //Ñ¡ÔñÍⲿʱÖÓ HCLK/8 fac_us=SystemCoreClock/8000000; //ΪϵͳʱÖÓµÄ1/8 fac_ms=(u16)fac_us*1000;//·ÇucosÏÂ,´ú±íÿ¸ömsÐèÒªµÄsystickʱÖÓÊý } void DelayUs(unsigned long nus) { u32 temp; SysTick->LOAD=nus*fac_us; //ʱ¼ä¼ÓÔØ SysTick->VAL=0x00; //Çå¿Õ¼ÆÊýÆ÷ SysTick->CTRL|=SysTick_CTRL_ENABLE_Msk ; //¿ªÊ¼µ¹Êý do { temp=SysTick->CTRL; } while(temp&0x01&&!(temp&(1<<16)));//µÈ´ýʱ¼äµ½´ï SysTick->CTRL&=~SysTick_CTRL_ENABLE_Msk; //¹Ø±Õ¼ÆÊýÆ÷ SysTick->VAL =0X00; //Çå¿Õ¼ÆÊýÆ÷ } void DelayMs(unsigned int nms) { u32 temp; SysTick->LOAD=(u32)nms*fac_ms;//ʱ¼ä¼ÓÔØ(SysTick->LOADΪ24bit) SysTick->VAL =0x00; //Çå¿Õ¼ÆÊýÆ÷ SysTick->CTRL|=SysTick_CTRL_ENABLE_Msk ; //¿ªÊ¼µ¹Êý do { temp=SysTick->CTRL; } while(temp&0x01&&!(temp&(1<<16)));//µÈ´ýʱ¼äµ½´ï SysTick->CTRL&=~SysTick_CTRL_ENABLE_Msk; //¹Ø±Õ¼ÆÊýÆ÷ SysTick->VAL =0X00; //Çå¿Õ¼ÆÊýÆ÷ } void DelayS(unsigned int ns)//ÑÓʱÃë { unsigned char i; for(i=0;i<ns;i++) { DelayMs(1000); } }
这段代码是一个基于SysTick定时器的延时函数,可以实现微秒级、毫秒级和秒级的延时。其中,SysTick是STM32的一个系统定时器,用于提供一个固定的时钟来进行定时操作。
在代码中,DelayInit()函数用于初始化SysTick定时器,并计算出us和ms所需的SysTick时钟周期数。DelayUs()函数实现微秒级延时,DelayMs()函数实现毫秒级延时,DelayS()函数实现秒级延时。
需要注意的是,这些延时函数都是阻塞的,即在延时期间程序无法执行其他任务。在实际使用中,应根据具体情况选择合适的延时方式,避免阻塞影响程序的实时性能。
阅读全文