stm32 怎样延时5秒
答案:2 悬赏:60 手机版
解决时间 2021-11-12 05:11
- 提问者网友:孤凫
- 2021-11-11 06:06
stm32 怎样延时5秒
最佳答案
- 五星知识达人网友:傲气稳了全场
- 2021-11-11 07:29
void SysTick_Init(uint32_t ticks)
{
SysTick->LOAD = (ticks & SYSTICK_MAXCOUNT) - 1;
NVIC_SetPriority (SysTick_IRQn, (1<<__NVIC_PRIO_BITS) - 1);
SysTick->VAL = (0x00);
SysTick->CTRL = (0 << SYSTICK_CLKSOURCE) | (1< }
这样配置systick,当函数的初始化为SysTick_Init(9000000)时,中断1次就是1s。中断5次就是5s了。
{
SysTick->LOAD = (ticks & SYSTICK_MAXCOUNT) - 1;
NVIC_SetPriority (SysTick_IRQn, (1<<__NVIC_PRIO_BITS) - 1);
SysTick->VAL = (0x00);
SysTick->CTRL = (0 << SYSTICK_CLKSOURCE) | (1<
这样配置systick,当函数的初始化为SysTick_Init(9000000)时,中断1次就是1s。中断5次就是5s了。
全部回答
- 1楼网友:几近狂妄
- 2021-11-11 07:59
楼主我给你delay_ms 和 delay_us 多谢几个delay_ms()就可以5秒了
#include
static u8 fac_us=0;//us延时倍乘数
static u16 fac_ms=0;//ms延时倍乘数
//初始化延迟函数
//SYSTICK的时钟固定为HCLK时钟的1/8
//SYSCLK:系统时钟
void delay_init(u8 SYSCLK)
{
SysTick->CTRL&=0xfffffffb;//bit2清空,选择外部时钟 HCLK/8
fac_us=SYSCLK/8;
fac_ms=(u16)fac_us*1000;
}
//延时nms
//注意nms的范围
//SysTick->LOAD为24位寄存器,所以,最大延时为:
//nms<=0xffffff*8*1000/SYSCLK
//SYSCLK单位为Hz,nms单位为ms
//对72M条件下,nms<=1864
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; //清空计数器
}
//延时nus
//nus为要延时的us数.
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; //清空计数器
}追问毫秒到秒可是1000倍的关系.不可能写1000个吧,那么用一个循环函数怎么用?谢谢追答我写的是delay_ms(u16 nms) nms<=1864那么delay_ms(1864)就是1.864秒了 或者你写5个delay_ms(1000)不就是5秒了吗 我给的函数不是死的 你要活用
#include
static u8 fac_us=0;//us延时倍乘数
static u16 fac_ms=0;//ms延时倍乘数
//初始化延迟函数
//SYSTICK的时钟固定为HCLK时钟的1/8
//SYSCLK:系统时钟
void delay_init(u8 SYSCLK)
{
SysTick->CTRL&=0xfffffffb;//bit2清空,选择外部时钟 HCLK/8
fac_us=SYSCLK/8;
fac_ms=(u16)fac_us*1000;
}
//延时nms
//注意nms的范围
//SysTick->LOAD为24位寄存器,所以,最大延时为:
//nms<=0xffffff*8*1000/SYSCLK
//SYSCLK单位为Hz,nms单位为ms
//对72M条件下,nms<=1864
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; //清空计数器
}
//延时nus
//nus为要延时的us数.
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; //清空计数器
}追问毫秒到秒可是1000倍的关系.不可能写1000个吧,那么用一个循环函数怎么用?谢谢追答我写的是delay_ms(u16 nms) nms<=1864那么delay_ms(1864)就是1.864秒了 或者你写5个delay_ms(1000)不就是5秒了吗 我给的函数不是死的 你要活用
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯