mobile_test.lua 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. --[[
  2. @module mobile_test
  3. @summary Air780EPM mobile功能测试模块
  4. @version 1.0
  5. @date 2025.10.21
  6. @author 拓毅恒
  7. @usage
  8. 本文件为 Air780EPM 开发板演示移动网络功能的代码示例,核心业务逻辑包括:
  9. 1. SIM卡管理和选择(自动选卡功能)
  10. 2. 基站数据查询(订阅式和轮询式两种方式)
  11. 3. 频段(Band)测试和修改
  12. 4. 移动网络信息获取(IMEI、IMSI、信号强度等)
  13. 5. SIM卡状态监控
  14. ]]
  15. -- 对于双卡的设备, 可以设置为自动选sim卡
  16. -- 但是SIM1所在管脚就强制复用为SIM功能, 占用4个IO口(gpio4/5/6/23),不可以再复用为GPIO
  17. -- mobile.simid(2)
  18. mobile.simid(2,true)--优先用SIM0
  19. -- 设置默认APN
  20. -- 注意:APN 必须在入网前就设置好;在国内公网卡基本上都不需要设置APN, 专网卡才需要设置
  21. mobile.apn(0,1,"","","",nil,0)
  22. -- 基站数据的查询
  23. -- 订阅式, 模块本身会周期性查询基站信息,但通常不包含临近小区
  24. local function sub_cell_info_task()
  25. log.info("cell", json.encode(mobile.getCellInfo()))
  26. end
  27. sys.subscribe("CELL_INFO_UPDATE", sub_cell_info_task)
  28. -- 轮询式, 包含临近小区信息,这是手动搜索,和上面的自动搜索冲突,开启一个就行
  29. local function get_cell_info_task()
  30. sys.wait(5000)
  31. mobile.config(mobile.CONF_SIM_WC_MODE, 2)
  32. while 1 do
  33. mobile.reqCellInfo(10)
  34. sys.wait(11000)
  35. log.info("cell", json.encode(mobile.getCellInfo()))
  36. mobile.config(mobile.CONF_SIM_WC_MODE, 2)
  37. end
  38. end
  39. -- 获取sim卡的状态
  40. local function get_sim_status_task(status, value)
  41. log.info("sim status", status)
  42. if status == 'RDY' then
  43. log.info("sim", "sim OK", value)
  44. end
  45. if status == 'NORDY' then
  46. log.info("sim", "NO sim", value)
  47. end
  48. if status == 'GET_NUMBER' then
  49. log.info("number", mobile.number(0))
  50. end
  51. if status == "SIM_WC" then
  52. log.info("sim", "write counter", value)
  53. end
  54. end
  55. sys.subscribe("SIM_IND", get_sim_status_task)
  56. -- SIM 卡热插拔功能,通过gpio中断通过上下边沿电平触发中断
  57. -- 设置防抖,使用wakeup2脚,常量为gpio.WAKEUP2
  58. -- 自己设计其他gpio热插拔只需要替换对应的gpio即可
  59. gpio.debounce(gpio.WAKEUP2,500)
  60. -- 设置中断触发,拔卡进入飞行模式,插卡进出飞行模式,val值为上升沿或者下降沿触发0/1
  61. local function sim_hot_plug(val)
  62. if val==0 then
  63. log.info("插卡")
  64. mobile.flymode(0,true)
  65. mobile.flymode(0,false)
  66. else
  67. log.info("拔卡")
  68. mobile.flymode(0,true)
  69. end
  70. end
  71. gpio.setup(gpio.WAKEUP2,sim_hot_plug)
  72. -- 定义测试band和移动网络信息的函数
  73. local function mobileinfo_task()
  74. -- 开启SIM暂时脱离后自动恢复,30秒搜索一次周围小区信息
  75. mobile.setAuto(10000,30000, 5) -- 此函数仅需要配置一次
  76. log.info("************开始测试band************")
  77. local band = zbuff.create(40)
  78. local band1 = zbuff.create(40)
  79. mobile.getBand(band)
  80. log.info("当前使用的band:")
  81. for i=0,band:used()-1 do
  82. log.info("band", band[i])
  83. end
  84. band1[0] = 38
  85. band1[1] = 39
  86. band1[2] = 40
  87. mobile.setBand(band1, 3) --改成使用38,39,40
  88. band1:clear()
  89. mobile.getBand(band1)
  90. log.info("修改后使用的band:")
  91. for i=0,band1:used()-1 do
  92. log.info("band", band1[i])
  93. end
  94. mobile.setBand(band, band:used()) --改回原先使用的band,也可以下载的时候选择清除fs
  95. mobile.getBand(band1)
  96. log.info("修改回默认使用的band:")
  97. for i=0,band1:used()-1 do
  98. log.info("band", band1[i])
  99. end
  100. log.info("************band测试完毕************")
  101. log.info("status", mobile.status())
  102. sys.wait(2000)
  103. while 1 do
  104. log.info("imei", mobile.imei())
  105. log.info("imsi", mobile.imsi())
  106. log.info("apn", mobile.apn()) -- 获取当前APN
  107. log.info("status", mobile.status())
  108. log.info("iccid", mobile.iccid())
  109. log.info("csq", mobile.csq()) -- 4G模块的CSQ并不能完全代表强度
  110. log.info("rssi", mobile.rssi()) -- 需要综合rssi/rsrq/rsrp/snr一起判断
  111. log.info("rsrq", mobile.rsrq())
  112. log.info("rsrp", mobile.rsrp())
  113. log.info("snr", mobile.snr())
  114. log.info("simid", mobile.simid()) -- 这里是获取当前SIM卡槽
  115. log.info("apn", mobile.apn(0,1))
  116. -- sys内存
  117. log.info("lua", rtos.meminfo())
  118. log.info("sys", rtos.meminfo("sys"))
  119. sys.wait(15000)
  120. end
  121. end
  122. -- 轮询式查找小区, 包含临近小区信息,与上面订阅式搜索冲突,开启一个就行
  123. -- sys.taskInit(get_cell_info_task)
  124. -- 启动测试任务
  125. sys.taskInit(mobileinfo_task)