打印
[应用相关]

rt-thread + lvgl :线程调用lv_task_handler() 之后,无法休眠

[复制链接]
605|0
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
tpgf|  楼主 | 2023-11-15 10:18 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
一、问题描述
定义了一个tui 线程用于处理lvgl 相关调度。如果在线程处理函数中,调用了lv_task_handler() ,出现两个问题:

在线程处理函数中调用 rt_thread_mdelay 线程不能休眠;程序只花了几微秒,就执行完了休眠10ms 的处理。
无法输入Finsh 命令查看线程信息。
如果没调用lv_task_handler(),调用rt_thread_mdelay ,线程正常休眠。Finsh 命令也能正常交互。

二、问题分析
2.1 mcu 心跳频率被修改?
一开始,我怀疑的是lv_task_handler() 修改了mcu 的心跳频率,如果心跳频率很高,例如1us 心跳一次,但是rt-thread 不知道心跳频率被改了,还是以为1ms 心跳一次,会出现类似的问题。

查看了lv_task_handler() 的源码,没发现修改mcu 的处理。

2.2 当前线程有其他唤醒源?
当前线程只是个简单的demo 程序,没有其他处理逻辑,不存在被唤醒的情况。线程中调用rt_thread_mdelay 进入休眠,并没有设置等待事件或者信号量。

三、问题解决
尝试将tui 线程的栈空间加大200个word,重新运行,运行结果符合预期。下面列一下三种情况下,tui 线程栈空间的使用情况,方便理解。

完全不加入lvgl 相关代码(栈空间是1000 bytes)
thread   pri  status      sp     stack size max used left tick  error
-------- ---  ------- ---------- ----------  ------  ---------- ---
tui        6  suspend 0x00000058 0x000003e8    08%   0x00000005 000


这个时候,栈空间最大的使用量是8%。

加入了lvgl 的初始化代码(栈空间是1000 bytes)
thread   pri  status      sp     stack size max used left tick  error
-------- ---  ------- ---------- ----------  ------  ---------- ---
tui        6  suspend 0x0000005c 0x000003e8    35%   0x00000002 000


这个时候,栈空间的最大使用量是35%。

加入了lvgl 的初始化代码+ lv_task_handler(栈空间是1800 bytes)
thread   pri  status      sp     stack size max used left tick  error
-------- ---  ------- ---------- ----------  ------  ---------- ---
tui        6  suspend 0x0000005c 0x00000708    60%   0x00000001 000


这个时候,栈空间的最大使用量是60%。栈空间大小是0x708(1800bytes)。1800 bytes * 60% = 1080 bytes 。也就是说,在栈需要1080 bytes 的时候,程序只分配了1000 bytes 的空间,导致了出现上述的异常。
————————————————
版权声明:本文为CSDN博主「gdut_llkkyy」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/gdut_liujiangyi/article/details/126235821

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

1867

主题

15482

帖子

11

粉丝