STM32F103延时函数

#include “delay.h”

//利用系统滴答定时,编写的延时函数

static u8 fac_us=0; //us延时倍乘数
static u16 fac_ms=0; //ms延时倍乘数

/****************************************************************************

  • 名 称: delay_init()
  • 功 能:延时函数初始化
  • 入口参数:无
  • 返回参数:无
  • 说 明:
    ***************************************************************************/
    void delay_init(void)
    {
    SysTick_CLKSourceConfig(SysTick_CLKSource_HCLK_Div8);
    //为系统定时器选择时钟为 HCLK 8分频 72MHz / 8 = 9MHz
    fac_us = SYSCLK / 8;
    //微秒的倍乘数 = 72 / 8 = 9
    //X * fac_us就相当于有X个微妙
    fac_ms = (u16)fac_us * 1000;
    //每个ms需要的systick时钟数(1ms = 1000us),所以fac_us
    1000
    //X * fac_ms就相当于有X个毫妙
    }

/****************************************************************************

  • 名 称: void delay_us(u32 nus)
  • 功 能:延时nus
  • 入口参数:要延时的微妙数
  • 返回参数:无
  • 说 明:nus的值,不要大于1864135us
    /
    /

    通过相关手册我们了解到,备份值寄存器和当前值寄存器的值最大为16M - 1
    我们的微妙级的延时函数的倍乘数为9所以16M - 1 / 9 = 1864135
    /
    void delay_us(u32 nus)
    {
    u32 midtime; //保存寄存器的状态
    SysTick->LOAD = nus * fac_us; //时间加载(相当于有nus个微妙)
    SysTick->VAL = 0x00; //清空计数器
    SysTick->CTRL |= SysTick_CTRL_ENABLE_Msk; //使能系统定时器计数
    do
    {
    midtime = SysTick->CTRL;
    }
    while((midtime & 0x01) && !(midtime & (1 << 16)));//等待时间到达
    SysTick->CTRL &= ~SysTick_CTRL_ENABLE_Msk; //关闭计数器
    SysTick->VAL = 0X00; //清空计数器
    }
    /
  • 名 称: void delay_xms(u16 nms)
  • 功 能:延时nms
  • 入口参数:要延时的毫妙数
  • 返回参数:无
  • 说 明:SysTick->LOAD为24位寄存器,所以,最大延时为: nms<=0xffffff81000/SYSCLK
    对9M条件下,nms<=1864ms
    /
    void delay_xms(u16 nms)
    {
    u32 midtime;
    SysTick->LOAD = (u32)nms
    fac_ms; //时间加载(SysTick->LOAD为24bit)
    SysTick->VAL = 0x00; //清空计数器
    SysTick->CTRL |= SysTick_CTRL_ENABLE_Msk; //开始倒数
    do
    {
    midtime = SysTick->CTRL;
    }
    while((midtime & 0x01) && !(midtime & (1 << 16)));//等待时间到达
    SysTick->CTRL &= ~SysTick_CTRL_ENABLE_Msk; //关闭计数器
    SysTick->VAL = 0X00; //清空计数器
    }
    /
    *
  • 名 称: void delay_ms(u16 nms)
  • 功 能:延时nms
  • 入口参数:要延时的毫妙数
  • 返回参数:无
  • 说 明:nms:0~65535
    ****************************************************************************/
    void delay_ms(u16 nms)
    {
    u8 repeat = nms / 540; //记录有多少个整的540ms
    u16 remain = nms % 540; //记录有多少个不够540ms
    while(repeat)
    {
    delay_xms(540);
    repeat–;
    }
    if(remain)delay_xms(remain);
    }
  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: stm32f103延时函数delay是通过循环计数实现的,具体实现方法如下: 1. 定义一个无符号整型变量i,用于计数。 2. 使用for循环,循环次数为需要延时的时间(单位为毫秒)乘以一个常数k,k的值需要根据实际情况调整。 3. 在for循环中,每次循环将i加1,直到i的值达到循环次数。 4. 延时结束后,返回函数。 下面是一个示例代码: void delay(uint32_t time) { uint32_t i; for(i=; i<time*100*k; i++); } 其中,k的值需要根据实际情况调整,一般情况下可以设置为1或2。需要注意的是,使用延时函数会占用CPU资源,因此在实际应用中应尽量避免使用延时函数,而采用定时器或其他方式实现延时。 ### 回答2: stm32f103是一款在嵌入式系统中被广泛应用的芯片,其中延时函数delay是其常用的功能之一。该功能可以用来控制程序的执行时间,确保各个模块之间的顺序和协调。 有人说stm32f103延时函数delay很不可靠,会因为硬件和软件原因导致误差很大,甚至不能达到设定的延时时间。这种看法有一定的道理,因为在工程实际应用场景中,常常会遇到各种问题,比如系统负载过重、外部干扰等,这些都可能会导致延时函数的准确性下降。 但是,延时函数delay本身并没有什么问题,关键在于如何正确使用它。以下是一些使用延时函数时需要注意的事项: 1. 程序中的其他地方不要使用while循环等长时间等待的语句,否则会影响延时函数的准确性。 2. 在开发时可以使用硬件定时器代替软件延时函数,这样可以提高延时函数的准确度。 3. 延时时间尽量不要太长,太长的延时会占用cpu资源,影响系统性能。 4. 减少外部干扰,比如加电容等方法可以有效降低外部干扰对延时函数的影响。 总之,虽然stm32f103延时函数delay存在一些问题,但只要注意使用方法及降低干扰,就能有效提高其准确性,确保程序的正常运行。 ### 回答3: 在单片机的开发过程中,延时函数是一个非常常见的功能,尤其是在做一些简单的小项目时,比如控制LED的闪烁等。而在STM32F103单片机中,为了方便用户对延时函数的调用,提供了一个名为delay的库函数。 delay函数基本原理如下:利用系统时钟的频率(SYSCLK),将需要延时的时间按照一定比例(通常为72000)映射到定时器的计数器上,然后等待定时器计数到预定的值。由于使用了硬件定时器,因此delay函数的精度非常高,能够满足大部分应用场景的需求。 下面是delay函数的代码实现: ``` void delay(int count) { int i,j; for(i=0;i<count;i++) { for(j=0;j<72000;j++); } } ``` 通过上述代码,可以实现指定延时时间的功能。其中count为需要延时的时间,具体的时间需要根据实际的需求来调整。 需要注意的是,由于delay函数中需要等待一段时间,会占用CPU的资源,因此不能将其用于长时间的延时。对于长时间的延时,可以使用定时器中断或者其他的方式来实现。同时,在使用delay函数的时候,也需要注意避免延时时间过长,导致程序的响应很慢,给用户的使用体验带来不好的影响。 在开发过程中,我们需要根据具体的应用场景,来选择合适的延时方式。当然,对于一些同步操作的任务,也可以使用操作系统提供的相关API,实现更加高效的延时操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值