STM32精确延迟1us和1ms的函数

延迟1us:

void delay_us(u32 i)
{
    u32 temp;
    SysTick->LOAD=9*i;         //设置重装数值, 72MHZ时
    SysTick->CTRL=0X01;         //使能,减到零是无动作,采用外部时钟源
    SysTick->VAL=0;                //清零计数器
    do
    {
        temp=SysTick->CTRL;           //读取当前倒计数值
    }
    while((temp&0x01)&&(!(temp&(1<<16))));     //等待时间到达
    SysTick->CTRL=0;    //关闭计数器
    SysTick->VAL=0;        //清空计数器
}

延迟1ms:

void delay_ms(u32 i)
{
    u32 temp;
    SysTick->LOAD=9000*i;      //设置重装数值, 72MHZ时
    SysTick->CTRL=0X01;        //使能,减到零是无动作,采用外部时钟源
    SysTick->VAL=0;            //清零计数器
    do
    {
        temp=SysTick->CTRL;       //读取当前倒计数值
    }
    while((temp&0x01)&&(!(temp&(1<<16))));    //等待时间到达
    SysTick->CTRL=0;    //关闭计数器
    SysTick->VAL=0;        //清空计数器
}

注意:以上两函数中间的参数u32 i不能超过1800,举例,想定时一分钟,可以通过for循环让delay_ms(1000)走60次,而不能使用delay_ms(60000),不然程序就出错了。

转载自:https://www.cnblogs.com/jiwangbujiu/p/5463751.html

  • 7
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
好的,对于STM32F4系列,您可以使用其内部的TIM定时器模块来实现精确定时1us1ms的功能。下面是使用HAL库编写的示例代码: 1. 精确定时1us ```c /* 定时器配置 */ TIM_HandleTypeDef htim; void TIM_Config(void) { TIM_ClockConfigTypeDef sClockSourceConfig = {0}; TIM_MasterConfigTypeDef sMasterConfig = {0}; htim.Instance = TIM2; htim.Init.Prescaler = (SystemCoreClock / 1000000) - 1; // 设置时钟预分频,将系统时钟分频为1MHz htim.Init.CounterMode = TIM_COUNTERMODE_UP; htim.Init.Period = 0xFFFFFFFF; // 设置计数器自动重载值为最大值 htim.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; HAL_TIM_Base_Init(&htim); sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL; HAL_TIM_ConfigClockSource(&htim, &sClockSourceConfig); sMasterConfig.MasterOutputTrigger = TIM_TRGO_UPDATE; sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE; HAL_TIMEx_MasterConfigSynchronization(&htim, &sMasterConfig); HAL_TIM_Base_Start(&htim); // 启动定时器 } /* 等待1us */ void Delay_1us(void) { uint32_t start = __HAL_TIM_GET_COUNTER(&htim); while((__HAL_TIM_GET_COUNTER(&htim) - start) < 1); } ``` 在上述代码中,我们使用了TIM2定时器模块,将时钟预分频设置为SystemCoreClock / 1000000,即1MHz,这样每计数1次就是1us。然后将计数器自动重载值设置为0xFFFFFFFF,这样定时器可以一直计数,不会因为计数溢出而停止。最后启动定时器,就可以开始计时了。在Delay_1us函数中,我们使用了__HAL_TIM_GET_COUNTER(&htim)来获取当前计数器的值,然后进行等待。 2. 精确定时1ms ```c /* 定时器配置 */ TIM_HandleTypeDef htim; void TIM_Config(void) { TIM_ClockConfigTypeDef sClockSourceConfig = {0}; TIM_MasterConfigTypeDef sMasterConfig = {0}; htim.Instance = TIM2; htim.Init.Prescaler = (SystemCoreClock / 1000) - 1; // 设置时钟预分频,将系统时钟分频为1kHz htim.Init.CounterMode = TIM_COUNTERMODE_UP; htim.Init.Period = 1000 - 1; // 设置计数器自动重载值为999,这样每计数1000次就是1ms htim.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1; HAL_TIM_Base_Init(&htim); sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL; HAL_TIM_ConfigClockSource(&htim, &sClockSourceConfig); sMasterConfig.MasterOutputTrigger = TIM_TRGO_UPDATE; sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE; HAL_TIMEx_MasterConfigSynchronization(&htim, &sMasterConfig); HAL_TIM_Base_Start(&htim); // 启动定时器 } /* 等待1ms */ void Delay_1ms(void) { uint32_t start = __HAL_TIM_GET_COUNTER(&htim); while((__HAL_TIM_GET_COUNTER(&htim) - start) < 1000); } ``` 在上述代码中,我们使用了同样的TIM2定时器模块,将时钟预分频设置为SystemCoreClock / 1000,即1kHz,这样每计数1000次就是1ms。然后将计数器自动重载值设置为999,这样定时器可以在每计数1000次时自动重载,并触发定时器中断或事件。最后启动定时器,就可以开始计时了。在Delay_1ms函数中,我们同样使用了__HAL_TIM_GET_COUNTER(&htim)来获取当前计数器的值,然后进行等待。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值