Ⅰ STM32延时问题
void delayus(u32 x)
{
u32 i,j;
for(i=0;i<x;i++)
for(j=0;j<10;j++);
}
印象里这样大约是1us(没中断的情况下)。你可以采用定时器来测量函数大致的延时时间。
设置并,清计数器
开启定时器
进入函数
出函数后关闭定时器,读取计数器。观察用时。
__ASM("NOP");为1个机器周期,1/72M
Ⅱ stm32 怎样延时5秒
楼主我给你delay_ms 和 delay_us 多谢几个delay_ms()就可以5秒了
#include <stm32f10x_lib.h>
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; //清空计数器
}
Ⅲ 怎么用stm32定时器产生5秒延时
使用一个定时器或打开滴答时钟,不过5秒比较长,建议使用滴答时钟。你设置好滴答定时器,在再定时中断里面不断的使得一个变量自增,你在等待处只需判断这个变量是否超过5秒,就完成了延时。
Ⅳ STM32如何设置10ns的延时
stm32的时钟频率,如果是103这个级别的,大概最高就是时钟为72Mhz,那么就是一个时钟周期为 1/72 000 000 约为 13ns,,那么要实现10ns准确延时,理论上是无法实现的,你可以用汇编实现一次空转,大概就是10ns的几倍的样子。。。
如果真要10ns,可以用更快的stm32,比如stm32f407系列。
Ⅳ stm32中Delay()函数延时的时间是怎么计算的
单片机编程过程中经常用到延时函数,最常用的莫过于微秒级延时delay_us(
)和毫秒级delay_ms(
)。1.普通延时法这个比较简单,让单片机做一些无关紧要的工作来打发时间,经常用循环来实现,不过要做的比较精准还是要下一番功夫。下面的代码是在网上搜到的,经测试延时比较精准。//粗延时函数,微秒
void delay_us(u16 time)
{
u16 i=0;
while(time--)
{
i=10; //自己定义
while(i--) ;
}
}
//毫秒级的延时
void delay_ms(u16 time)
{
u16 i=0;
while(time--)
{
i=12000; //自己定义
while(i--) ;
}
}2.SysTick 定时器延时CM3 内核的处理器,内部包含了一个SysTick
定时器,SysTick 是一个24 位的倒计数定时器,当计到0 时,将从RELOAD
寄存器中自动重装载定时初值。只要不把它在SysTick
控制及状态寄存器中的使能位清除,就永不停息。SysTick 在STM32
的参考手册里面介绍的很简单,其详细介绍,请参阅《Cortex-M3 权威指南》。
这里面也有两种方式实现:a.中断方式
如下,定义延时时间time_delay,SysTick_Config()定义中断时间段,在中断中递减time_delay,从而实现延时。
volatile unsigned long time_delay; //
延时时间,注意定义为全局变量
//延时n_ms
void delay_ms(volatile unsigned long nms)
{
//SYSTICK分频--1ms的系统时钟中断
if (SysTick_Config(SystemFrequency/1000))
{
while (1);
}
time_delay=nms;//读取定时时间
while(time_delay);
SysTick->CTRL=0x00; //关闭计数器
SysTick->VAL =0X00; //清空计数器
}
//延时nus
void delay_us(volatile unsigned long nus)
{
//SYSTICK分频--1us的系统时钟中断
if (SysTick_Config(SystemFrequency/1000000))
{
while (1);
}
time_delay=nus;//读取定时时间
while(time_delay);
SysTick->CTRL=0x00; //关闭计数器
SysTick->VAL =0X00; //清空计数器
} //在中断中将time_delay递减。实现延时void
SysTick_Handler(void)
{
if(time_delay)
time_delay--;