rtos_app.lua 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. --[[
  2. @module rtos_app
  3. @summary rtos应用模块
  4. @version 1.0
  5. @date 2025.12.2
  6. @author 王城钧
  7. @usage
  8. 本文件为rtos应用模块,核心业务逻辑为:
  9. 1、对rtos核心库的各项功能进行测试,包括系统信息查询、内存信息获取、内存自动回收配置以及性能测试
  10. 本文件没有对外接口,直接在其他功能模块中require "rtos_app"就可以加载运行;
  11. ]]
  12. -- 1. 系统信息查询测试
  13. -- 读取版本号及数字版本号, 2025.11.1之后的固件支持
  14. -- 如果不是数字固件,luatos_version_num 会是0
  15. -- 如果是不支持的固件, luatos_version_num 会是nil
  16. local luatos_version, luatos_version_num = rtos.version(true)
  17. log.info("固件信息", "版本:", luatos_version, luatos_version_num )
  18. log.info("编译信息", "日期:", rtos.buildDate(), "BSP:", rtos.bsp())
  19. log.info("完整描述", rtos.firmware())
  20. -- 2. 内存信息测试
  21. local total_lua, used_lua, max_used_lua = rtos.meminfo("lua")
  22. local total_sys, used_sys, max_used_sys = rtos.meminfo("sys")
  23. log.info("内存信息",
  24. "Lua - 总:", total_lua, "已用:", used_lua, "峰值:", max_used_lua,
  25. "系统 - 总:", total_sys, "已用:", used_sys, "峰值:", max_used_sys)
  26. -- 3. 定时器测试
  27. -- rtos.timer_start()和rtos.timer_stop()两个接口,仅仅给sys核心库使用
  28. -- 如果要使用定时器,直接使用sys核心库提供的定时器接口即可
  29. -- 用户脚本中不要直接使用rtos.timer_start()和rtos.timer_stop()两个接口
  30. -- 否则和sys核心库中的定时器功能出现冲突而导致系统异常的问题
  31. -- 4. 内存自动回收配置
  32. rtos.autoCollectMem(200, 75, 85) -- 配置较宽松的自动回收
  33. -- 5. 空函数测试(性能测试用)
  34. local function test_nop()
  35. local start = mcu.ticks()
  36. for i = 1, 1000 do
  37. rtos.nop()
  38. end
  39. local duration = mcu.ticks() - start
  40. log.info("性能测试", "1000次nop耗时:", duration, "毫秒")
  41. end
  42. -- 10秒后执行空函数测试
  43. sys.timerStart(test_nop, 10000)
  44. -- 6. 重启测试(注释掉防止意外重启)
  45. -- local function reboot()
  46. -- log.info("系统", "准备重启...")
  47. -- rtos.reboot()
  48. -- end
  49. -- sys.timerStart(reboot, 30000)
  50. log.info("RTOS测试", "所有测试已启动")