本文主要是介绍rtos定时器不起作用原因之逻辑问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
在使用RTOS过程中突然发现定时器不起作用。
先分析原因,因为定时器也是一个任务,所以也有自己的任务优先级。如果当有高级任务由于自己代码逻辑BUG卡在某个循环里,那么按任务调度规则来看,那么定时器就永远得不到CPU所以导致定时器看起来,不起作用。
/* Software timer definitions. */
#define configUSE_TIMERS 1
#define configTIMER_TASK_PRIORITY 4
#define configTIMER_QUEUE_LENGTH 16
-
#define configUSE_TIMERS 1
这个宏定义用于启用FreeRTOS中的软件定时器功能。当你设置configUSE_TIMERS
为1时,FreeRTOS会在其任务调度和中断处理中包括软件定时器的支持。软件定时器允许你在没有硬件定时器可用或需要更灵活定时功能的情况下,使用软件来模拟定时器。
2. #define configTIMER_TASK_PRIORITY 4
这个宏定义设置了软件定时器任务的优先级。在FreeRTOS中,软件定时器是通过一个特殊的任务来管理的,该任务会定期检查所有软件定时器的状态,并执行任何已经到期的定时器回调函数。configTIMER_TASK_PRIORITY
定义了这个任务的优先级。在这个例子中,它被设置为4,但实际的优先级值取决于你的RTOS配置和调度策略。较高的优先级意味着该任务将比其他具有较低优先级的任务更频繁地运行。
3. #define configTIMER_QUEUE_LENGTH 16
这个宏定义设置了用于软件定时器消息传递的队列长度。在FreeRTOS中,软件定时器任务使用一个队列来与其他任务或中断服务程序进行通信。当定时器到期时,它可能会向该队列发送一条消息,以便通知其他任务或中断服务程序。configTIMER_QUEUE_LENGTH
定义了该队列的最大长度。在这个例子中,它被设置为16,这意味着队列最多可以存储16条消息。如果队列已满并且又有新的消息要发送,那么新的消息可能会被丢弃或根据队列的溢出策略进行处理。
这篇关于rtos定时器不起作用原因之逻辑问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!