US-延时的实现方法1-大块切糕

参考:

https://blog.csdn.net/qq_22252423/article/details/76468161

核心思想是我做一个TIM他的CNT其实是在0--7200之前跑的

但是我暴力设置CNT为一个数字A--然后让他跑到B的时候停止

大块切糕 就是如此

拿出若干个等分吧。

void delay_us(uint16_t us)
{
    uint16_t differ=0xffff-us-5;
    /*为防止因中断打断延时,造成计数错误.
     如从0xfffE开始延时1us,但由于中断打断
    (此时计数器仍在计数),本因计数至0xffff)
    便停止计数,但由于错过计数值,并重载arr值,
    导致实际延时(0xffff+1)us
    */

    HAL_TIM_Base_Start(&htim14);

    __HAL_TIM_SetCounter(&htim14,differ);

    while(differ<0xffff-5)
    {
        differ=__HAL_TIM_GetCounter(&htim14);
    }

    HAL_TIM_Base_Stop(&htim14);
}

他只需要MX-INIT此后直接调用即可。定时器一直都在。只是函数内操作开关

 

 

 

 

 

 

 

 

这种方式比较STM32不能扩展

 

案例 看TIM6做OS

HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority)
  uint32_t              uwTimclock = 0;
  uint32_t              uwPrescalerValue = 0;
 
  uwTimclock = HAL_RCC_GetPCLK1Freq();
    /* Compute the prescaler value to have TIM6 counter clock equal to 1MHz */
  uwPrescalerValue = (uint32_t) ((uwTimclock / 1000000) - 1);
  
  /* Initialize TIM6 */
  htim6.Instance = TIM6;

  htim6.Init.Period = (1000000 / 1000) - 1;
  htim6.Init.Prescaler = uwPrescalerValue;
  htim6.Init.ClockDivision = 0;
  htim6.Init.CounterMode = TIM_COUNTERMODE_UP;

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值