low_power_dissipation.lua 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. -- netlab.luatos.com上打开TCP 有测试服务器
  2. local server_ip = "112.125.89.8"
  3. local server_port = 47523
  4. local is_udp = false --用户根据自己实际情况选择
  5. --是UDP服务器就赋值为true,是TCP服务器就赋值为flase
  6. --UDP服务器比TCP服务器功耗低
  7. --如果用户对数据的丢包率有极为苛刻的要求,最好选择TCP
  8. local Heartbeat_interval = 5 -- 发送数据的间隔时间,单位分钟
  9. -- 配置GPIO达到最低功耗
  10. gpio.setup(25, 0) -- 关闭GNSS电源
  11. gpio.setup(24, 0) -- 关闭三轴电源
  12. gpio.setup(23, 0) -- 关闭wifi电源
  13. -- 数据内容
  14. local heart_data = string.rep("1234567890", 10)
  15. local rxbuf = zbuff.create(8192)
  16. local function netCB(netc, event, param)
  17. if param ~= 0 then
  18. sys.publish("socket_disconnect")
  19. return
  20. end
  21. if event == socket.LINK then
  22. elseif event == socket.ON_LINE then
  23. -- 链接上服务器以后发送的第一包数据是 hello,luatos
  24. socket.tx(netc, "hello,luatos!")
  25. elseif event == socket.EVENT then
  26. socket.rx(netc, rxbuf)
  27. socket.wait(netc)
  28. if rxbuf:used() > 0 then
  29. log.info("收到", rxbuf:toStr(0, rxbuf:used()), "数据长度", rxbuf:used())
  30. end
  31. rxbuf:del()
  32. elseif event == socket.TX_OK then
  33. socket.wait(netc)
  34. log.info("发送完成")
  35. elseif event == socket.CLOSED then
  36. sys.publish("socket_disconnect")
  37. end
  38. end
  39. local function socketTask()
  40. local netc = socket.create(nil, netCB) --创建一个链接
  41. socket.debug(netc, true)--开启socket层的debug日志,方便寻找问题
  42. socket.config(netc, nil, is_udp, nil, 300, 5, 6) --配置TCP链接的参数,开启保活,防止长时间无数据交互服务器踢掉模块
  43. while true do
  44. --真正去链接服务器
  45. local succ, result = socket.connect(netc, server_ip, server_port)
  46. --链接成功后循环发送数据
  47. while succ do
  48. local Heartbeat_interval = Heartbeat_interval * 60 * 1000
  49. sys.wait(Heartbeat_interval)
  50. socket.tx(netc, heart_data)
  51. end
  52. --链接不成功5S重连一次
  53. if not succ then
  54. log.info("未知错误,5秒后重连")
  55. uart.write(1, "未知错误,5秒后重连")
  56. else
  57. local result, msg = sys.waitUntil("socket_disconnect")
  58. end
  59. log.info("服务器断开了,5秒后重连")
  60. uart.write(1, "服务器断开了,5秒后重连")
  61. socket.close(netc)
  62. sys.wait(5000)
  63. end
  64. end
  65. function socketDemo()
  66. --配置GPIO以达到最低功耗的目的
  67. gpio.setup(23, nil)
  68. gpio.close(33) -- 如果功耗偏高,开始尝试关闭WAKEUPPAD1
  69. gpio.close(35) -- 这里pwrkey接地才需要,不接地通过按键控制的不需要
  70. --关闭USB以后可以降低约150ua左右的功耗,如果不需要USB可以关闭
  71. pm.power(pm.USB, false)
  72. --进入低功耗长连接模式
  73. pm.power(pm.WORK_MODE, 1)
  74. sys.taskInit(socketTask)
  75. end
  76. sys.taskInit(socketDemo)