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


    一、问题描述

    定义了一个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
    
    • 1
    • 2
    • 3

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

    加入了lvgl 的初始化代码(栈空间是1000 bytes)

    thread   pri  status      sp     stack size max used left tick  error
    -------- ---  ------- ---------- ----------  ------  ---------- ---
    tui        6  suspend 0x0000005c 0x000003e8    35%   0x00000002 000
    
    • 1
    • 2
    • 3

    这个时候,栈空间的最大使用量是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
    
    • 1
    • 2
    • 3

    这个时候,栈空间的最大使用量是60%。栈空间大小是0x708(1800bytes)。1800 bytes * 60% = 1080 bytes 。也就是说,在栈需要1080 bytes 的时候,程序只分配了1000 bytes 的空间,导致了出现上述的异常。

  • 相关阅读:
    MyBatis批量更新SQL
    【21天python打卡】第4天 基础语法(2)
    数组第 k 大子序列
    20、Python -- 变量作用域、局部函数
    常用的6款Go语言Web框架
    如何批量将长视频分割成短视频?详细操作步骤一目了然
    在群晖上安装Nextcloud-AIO详解
    Webrtc官方Demo公网服务器搭建
    基于51单片机锂电池电压电量检测(原理图+PCB+程序)
    Linux setleds命令教程:如何控制键盘LED灯(附实例详解和注意事项)
  • 原文地址:https://blog.csdn.net/gdut_liujiangyi/article/details/126235821