uart_app.lua 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. --[[
  2. @module uart_app
  3. @summary 串口应用功能模块
  4. @version 1.0
  5. @date 2025.09.07
  6. @author 孟伟
  7. @usage
  8. 本文件为串口应用功能模块,核心业务逻辑为:
  9. 1、打开uart1,波特率115200,数据位8,停止位1,无奇偶校验位;
  10. 2、uart1和pc端的串口工具相连;
  11. 3、接收"ERRDUMP_DATA_SEND_UART"消息,将手动读取到异常日志通过uart1发送到pc端串口工具;
  12. 本文件的对外接口有两个:
  13. 1、sys.subscribe("ERRDUMP_DATA_SEND_UART", dump_data_send),订阅"ERRDUMP_DATA_SEND_UART"消息,处理消息携带的数据;
  14. ]]
  15. -- 使用UART1
  16. local UART_ID = 1
  17. -- 串口接收数据缓冲区
  18. local read_buf = ""
  19. -- 末尾增加回车换行两个字符,通过uart发送出去,方便在PC端换行显示查看
  20. local function dump_data_send(data)
  21. uart.write(UART_ID, data.."\r\n")
  22. end
  23. local function concat_timeout_func()
  24. -- 如果存在尚未处理的串口缓冲区数据;
  25. -- 将数据通过publish通知其他应用功能模块处理;
  26. -- 然后清空本文件的串口缓冲区数据
  27. if read_buf:len() > 0 then
  28. log.info("uart_read", read_buf:len())
  29. read_buf = ""
  30. end
  31. end
  32. -- UART1的数据接收中断处理函数,UART1接收到数据时,会执行此函数
  33. local function read()
  34. local s
  35. while true do
  36. -- 非阻塞读取UART1接收到的数据,最长读取1024字节
  37. s = uart.read(UART_ID, 1024)
  38. -- 如果从串口没有读到数据
  39. if not s or s:len() == 0 then
  40. -- 启动50毫秒的定时器,如果50毫秒内没收到新的数据,则处理当前收到的所有数据
  41. -- 这样处理是为了防止将一大包数据拆分成多个小包来处理
  42. -- 例如pc端串口工具下发1100字节的数据,可能会产生将近20次的中断进入到read函数,才能读取完整
  43. -- 此处的50毫秒可以根据自己项目的需求做适当修改,在满足整包拼接完整的前提下,时间越短,处理越及时
  44. sys.timerStart(concat_timeout_func, 50)
  45. -- 跳出循环,退出本函数
  46. break
  47. end
  48. log.info("uart_app.read len", s:len())
  49. -- log.info("uart_app.read", s)
  50. -- 将本次从串口读到的数据拼接到串口缓冲区read_buf中
  51. read_buf = read_buf..s
  52. end
  53. end
  54. -- 初始化UART1,波特率115200,数据位8,停止位1
  55. uart.setup(UART_ID, 115200, 8, 1)
  56. -- 注册UART1的数据接收中断处理函数,UART1接收到数据时,会执行read函数
  57. uart.on(UART_ID, "receive", read)
  58. -- 订阅"ERRDUMP_DATA_SEND_UART"消息的处理函数dump_data_send
  59. -- 收到"ERRDUMP_DATA_SEND_UART"消息后,会执行函数dump_data_send
  60. sys.subscribe("ERRDUMP_DATA_SEND_UART", dump_data_send)