FreeRtos延时函数delay_us()

时钟72MHZ,递减一次需要10^6/72MHZ 微秒,注意!!!是微秒,

若要延迟1微秒,时钟就需要递减72MHZ/10^6次,又因为fac_us为72MHZ/10^6,所以延时n us

即令ticks=n us*fac_us

 函数内部tcnt 的值是累加的 ,每运行一次函数,tcnt就会加一次定时器计次个数(told-tnow)

tnow>told 是因为,定时器减到零,又从reload开始减。

这个函数就是记录,运行while内部运行一次所需的时间,然后相加,知道大于等于我们设定的时间

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
FreeRTOS 中,延时函数应该使用 vTaskDelay() 函数来实现,而不是使用 delay_us() 函数。因为在 FreeRTOS 中,任务的调度是由操作系统来完成的,所以在任务中使用延时函数可以让任务挂起一段时间,让其他任务有机会被调度执行。 如果你需要在任务中实现微秒级别的延时,可以使用 FreeRTOS 的 Tick 定时器来实现。具体方法如下: 1. 获取当前系统 Tick 值 ```c uint32_t current_tick = xTaskGetTickCount(); ``` 2. 计算延时 Tick 数 ```c uint32_t delay_tick = (uint32_t)(delay_us * (configTICK_RATE_HZ / 1000000)); ``` 其中,delay_us 是需要延时的微秒数,configTICK_RATE_HZ 是 FreeRTOS 配置文件中定义的系统 Tick 频率,一般默认为 1000。 3. 等待延时时间到达 ```c vTaskDelayUntil(&current_tick, delay_tick); ``` 其中,vTaskDelayUntil() 函数会挂起任务,直到当前系统 Tick 值达到指定的延时 Tick 数为止。 完整的代码示例: ```c #include "FreeRTOS.h" #include "task.h" void task_delay_us(uint32_t delay_us) { uint32_t current_tick = xTaskGetTickCount(); uint32_t delay_tick = (uint32_t)(delay_us * (configTICK_RATE_HZ / 1000000)); vTaskDelayUntil(&current_tick, delay_tick); } void task1(void *pvParameters) { while (1) { // 延时 100 微秒 task_delay_us(100); // 执行任务代码 } } void task2(void *pvParameters) { while (1) { // 延时 200 微秒 task_delay_us(200); // 执行任务代码 } } int main() { // 创建任务 xTaskCreate(task1, "task1", configMINIMAL_STACK_SIZE, NULL, 1, NULL); xTaskCreate(task2, "task2", configMINIMAL_STACK_SIZE, NULL, 1, NULL); // 启动调度器 vTaskStartScheduler(); return 0; } ``` 在上面的例子中,我们创建了两个任务 task1 和 task2,它们分别每隔 100 微秒和 200 微秒执行一次。通过使用 vTaskDelayUntil() 函数,可以保证任务的延时精度达到微秒级别。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值