sx126x_driver.lua 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433
  1. --- 模块功能:sx126x模块驱动
  2. -- 读取FLASH ID
  3. -- @author openLuat
  4. -- @module spi.testSpiFlash
  5. -- @license MIT
  6. -- @copyright openLuat
  7. -- @release 2018.03.27
  8. module(...,package.seeall)
  9. require"utils"
  10. require"pm"
  11. pm.wake("wake11")
  12. require"pins"
  13. -- require "sx126x_reg"
  14. require "Drv_spi"
  15. require "sx126x_reg"
  16. local SX126x = json.encode(sx126x_reg.SX126x_t)
  17. local SX126xCopy,result,errinfo = json.decode(SX126x)
  18. SX126x = nil
  19. local RadioPublicNetwork_t = {
  20. Previous = false,
  21. Current = false
  22. }
  23. RadioPublicNetwork = nil
  24. -- SX126xResetGPIO = pins.setup(pio.P0_13,0)
  25. OperatingMode = sx126x_reg.RadioStandbyModes_t.STDBY_RC
  26. -- 初始化SPI
  27. function SX126xIoInit()
  28. Drv_spi.SPI_GPIO_Init()
  29. end
  30. -- 复位SX126x
  31. function SX126xReset()
  32. sys.wait(10)
  33. SX126xResetGPIO(0)
  34. sys.wait(20)
  35. SX126xResetGPIO(1)
  36. sys.wait(10)
  37. end
  38. function SX126xWakeup()
  39. local command = sx126x_reg.RadioCommands.RADIO_GET_STATUS .. "00"
  40. local ret = Drv_spi.drv_spi_read_write_byte(command)
  41. log.info("SX126xWakeup",ret)
  42. end
  43. --local numbers = {10, 20, 30, 40} -- Indices: 1→10, 2→20, 3→30, 4→40
  44. function SX126xWriteCommand(command,buffer)
  45. local bufferTotal = ""
  46. for i, num in ipairs(buffer) do
  47. bufferTotal = bufferTotal .. num
  48. end
  49. Drv_spi.drv_spi_read_write_byte(command,0)
  50. sys.wait(20)
  51. local ret = Drv_spi.drv_spi_read_write_byte("1d07400000",1);
  52. log.info("SX126xWriteCommand",ret)
  53. sys.wait(20)
  54. end
  55. -- -----------------------------------------------SPI基础读写---------------------------------------------------
  56. -- 读取寄存器 完成
  57. -- function SX126xReadRegisters(address,size)
  58. -- local command = sx126x_reg.RadioCommands.RADIO_READ_REGISTER
  59. -- local sendData = command .. address .. "00"
  60. -- local receiverDataCount= size
  61. -- while size > 0 do
  62. -- sendData = sendData .. "00"
  63. -- size = size - 1
  64. -- end
  65. -- local result = Drv_spi.drv_spi_read_write_byte(sendData,receiverDataCount) --这里乘2的意思是,16进制是两位,但是转成字符串的形式就是4位了。
  66. -- log.info("SX126xReadRegisters",result)
  67. -- return result
  68. -- end
  69. function SX126xReadRegisters(address,size)
  70. local receiverData = {}
  71. Drv_spi.drv_spi_read_write_byte(sx126x_reg.RadioCommands.RADIO_READ_REGISTER,0)
  72. -- Drv_spi.drv_spi_read_write_byte(string.sub(address, 1, 2),0);
  73. -- Drv_spi.drv_spi_read_write_byte(string.sub(address, 3, 4),0);
  74. -- receiverData[0] = Drv_spi.drv_spi_read_write_byte("00",1)
  75. -- log.info("SX126xReadRegisters:",receiverData[0])
  76. Drv_spi.drv_spi_read_write_byte(string.sub(address, 1, 2),0);
  77. Drv_spi.drv_spi_read_write_byte(string.sub(address, 3, 4),0);
  78. Drv_spi.drv_spi_read_write_byte("0");
  79. log.info("SX126xReadRegisters:",string.fromHex("1d"):toHex())
  80. log.info("SX126xReadRegisters:",string.fromHex("07"):toHex())
  81. log.info("SX126xReadRegisters:",string.fromHex("40"):toHex())
  82. log.info("SX126xReadRegisters:",string.fromHex("00"):toHex())
  83. log.info("SX126xReadRegisters:",string.fromHex("00"):toHex())
  84. log.info("SX126xReadRegisters:",string.fromHex("1d07400000"):toHex())
  85. for i = 1, size do
  86. receiverData[i] = Drv_spi.drv_spi_read_write_byte("00",1)
  87. log.info("SX126xReadRegisters:",i,":",receiverData[i])
  88. end
  89. end
  90. --封装后的读寄存器
  91. function SX126xReadRegister(address)
  92. local ret = SX126xReadRegisters(address,1)
  93. return ret
  94. end
  95. -- 写入寄存器
  96. function SX126xWriteRegisters(address,buffer,size)
  97. local command = sx126x_reg.RadioCommands.RADIO_WRITE_REGISTER
  98. local sendData = command .. address .. "00"
  99. local receiverDataCount= size
  100. while size > 0 do
  101. sendData = sendData .. "00"
  102. size = size - 1
  103. end
  104. local result = Drv_spi.drv_spi_read_write_byte(sendData,receiverDataCount) --这里乘2的意思是,16进制是两位,但是转成字符串的形式就是4位了。
  105. log.info("SX126xReadRegisters",result)
  106. return result
  107. end
  108. function SX126xWriteRegister(address,value)
  109. SX126xWriteRegisters( address,value,1);
  110. end
  111. -- function SX126xReadRegisters(address,size)
  112. -- SX126xWriteCommand(sx126x_reg.RadioCommands.RADIO_SET_STANDBY)
  113. -- end
  114. function SX126xSetStandby(standbyConfig)
  115. SX126xWriteCommand(sx126x_reg.RadioCommands.RADIO_SET_STANDBY,standbyConfig)
  116. if standbyConfig[0] == sx126x_reg.RadioStandbyModes_t.STDBY_RC then
  117. OperatingMode = sx126x_reg.RadioOperatingModes_t.STDBY_RC
  118. else
  119. OperatingMode = sx126x_reg.RadioOperatingModes_t.STDBY_XOSC
  120. end
  121. end
  122. function SX126xSetRegulatorMode(mode)
  123. SX126xWriteCommand(sx126x_reg.RadioCommands.RADIO_SET_REGULATORMODE,mode)
  124. end
  125. function SX126xSetBufferBaseAddress(txBaseAddress, rxBaseAddress)
  126. local buf = {txBaseAddress,rxBaseAddress}
  127. SX126xWriteCommand(sx126x_reg.RadioCommands.RADIO_SET_BUFFERBASEADDRESS,buf)
  128. end
  129. function SX126xSetPaConfig(paDutyCycle,hpMax,deviceSel,paLut)
  130. local buf = {paDutyCycle,hpMax,deviceSel,paLut}
  131. -- log.info("SX126xSetPaConfig",buf)
  132. SX126xWriteCommand(sx126x_reg.RadioCommands.RADIO_SET_PACONFIG,buf)
  133. end
  134. function SX126xSetTxParams(power, rampTime)
  135. local buf = {power,rampTime}
  136. SX126xSetPaConfig("04","07","00","01")
  137. SX126xWriteRegister( sx126x_reg.REG_OCP, "38" );
  138. SX126xWriteCommand(sx126x_reg.RadioCommands.RADIO_SET_TXPARAMS,buf)
  139. end
  140. function SX126xSetDioIrqParams(timeout, freq, rfChain, power, preambleLen)
  141. local buf = {timeout, freq, rfChain, power, preambleLen}
  142. SX126xSetTxParams(power, sx126x_reg.RadioRampTimes_t.RADIO_RAMP_40_US)
  143. SX126xWriteCommand(sx126x_reg.RadioCommands.RADIO_SET_TX,buf)
  144. end
  145. function SX126xSetStopRxTimerOnPreambleDetect(enable)
  146. SX126xWriteCommand(sx126x_reg.RadioCommands.RADIO_SET_STOPRXTIMERONPREAMBLE,{enable})
  147. end
  148. function SX126xSetLoRaSymbNumTimeout(SymbNum)
  149. SX126xWriteCommand(sx126x_reg.RadioCommands.RADIO_SET_LORASYMBTIMEOUT,{SymbNum})
  150. end
  151. function SX126xSetPacketType(packetType)
  152. PacketType = packetType;
  153. SX126xWriteCommand( RADIO_SET_PACKETTYPE,{PacketType});
  154. end
  155. function RadioSetPublicNetwork(enable)
  156. SX126xSetPacketType(sx126x_reg.RadioPacketTypes_t.PACKET_TYPE_LORA)
  157. if enable == true then
  158. SX126xWriteRegister( sx126x_reg.REG_LR_SYNCWORD,"07");
  159. SX126xWriteRegister( sx126x_reg.REG_LR_SYNCWORD_LSB,"40");
  160. else
  161. SX126xWriteRegister( sx126x_reg.REG_LR_SYNCWORD, "07");
  162. SX126xWriteRegister( sx126x_reg.REG_LR_SYNCWORD_LSB, "41" );
  163. end
  164. end
  165. function RadioSetModem(modem)
  166. if modem == sx126x_reg.RadioModems_t.MODEM_FSK then
  167. -- 处理 FSK 调制的逻辑
  168. -- SX126xSetPacketType(sx126x_reg.RadioPacketTypes_t.PACKET_TYPE_GFSK)
  169. elseif modem == sx126x_reg.RadioModems_t.MODEM_LORA then
  170. SX126xSetPacketType(sx126x_reg.RadioPacketTypes_t.PACKET_TYPE_LORA)
  171. if RadioPublicNetwork.Current ~= RadioPublicNetwork.Previous then
  172. RadioPublicNetwork.Current = RadioPublicNetwork.Previous
  173. RadioSetPublicNetwork(RadioPublicNetwork.Current)
  174. end
  175. else
  176. -- 处理未知调制类型的逻辑
  177. print("错误:未知的调制类型")
  178. end
  179. end -- 增加了函数结束标记
  180. function SX126xSetModulationParams(modulationParams)
  181. buf = {modulationParams.Params.LoRa.SpreadingFactor, modulationParams.Params.LoRa.Bandwidth,modulationParams.Params.LoRa.CodingRate, modulationParams.Params.LoRa.CodingRate}
  182. SX126xWriteCommand( sx126x_reg.RADIO_SET_MODULATIONPARAMS);
  183. end
  184. function SX126xSetPacketParams(packetParams)
  185. buf = { packetParams.Params.LoRa.PreambleLength,
  186. packetParams.Params.LoRa.HeaderType,
  187. packetParams.Params.LoRa.PayloadLength,
  188. packetParams.Params.LoRa.CrcMode,
  189. packetParams.Params.LoRa.InvertIQ}
  190. SX126xWriteCommand(sx126x_reg.RADIO_SET_PACKETPARAMS,buf);
  191. end
  192. function RadioSetTxConfig(modem,power,fdev,bandwidth,datarate,coderate,preambleLen,fixLen,crcOn,freqHopOn,hopPeriod,iqInverted,timeout)
  193. SX126xSetStopRxTimerOnPreambleDetect(false)
  194. SX126xSetLoRaSymbNumTimeout(0)
  195. SX126xCopy.ModulationParams.PacketType = sx126x_reg.PacketType_t.PACKET_TYPE_LORA
  196. SX126xCopy.ModulationParams.Params.LoRa.SpreadingFactor = datarate
  197. SX126xCopy.ModulationParams.Params.LoRa.Bandwidth = sx126x_reg.Bandwidths[bandwidth]
  198. SX126xCopy.ModulationParams.Params.LoRa.CodingRate= coderate
  199. if ( (bandwidth == 0) and ( (datarate == 11) or (datarate == 12) ) ) or ( (bandwidth == 1) and (datarate == 12) ) then
  200. SX126xCopy.ModulationParams.Params.LoRa.LowDatarateOptimize = 0x01
  201. else
  202. SX126xCopy.ModulationParams.Params.LoRa.LowDatarateOptimize = 0x00
  203. end
  204. SX126xCopy.PacketParams.PacketType = sx126x_reg.PacketType_t.PACKET_TYPE_LORA
  205. SX126xCopy.PacketParams.Params.LoRa.PreambleLength = preambleLen
  206. SX126xCopy.PacketParams.Params.LoRa.HeaderType = fixLen
  207. SX126xCopy.PacketParams.Params.LoRa.PayloadLength = MaxPayloadLength
  208. SX126xCopy.PacketParams.Params.LoRa.CrcMode = crcOn
  209. SX126xCopy.PacketParams.Params.LoRa.InvertIQ = iqInverted
  210. SX126xSetStandby({sx126x_reg.RadioStandbyModes_t.STDBY_RC})
  211. RadioSetModem(1)
  212. SX126xSetModulationParams(SX126xCopy.ModulationParams)
  213. SX126xSetPacketParams(SX126xCopy.PacketParams)
  214. SX126xSetTxParams(power,sx126x_reg.RADIO_RAMP_40_US)
  215. end
  216. -- 初始化SX126x
  217. function SX126xInit()
  218. SX126xIoInit()
  219. SX126xReset()
  220. SX126xWakeup()
  221. -- local table = {sx126x_reg.RadioStandbyModes_t.STDBY_RC}
  222. SX126xSetStandby({sx126x_reg.RadioStandbyModes_t.STDBY_RC})
  223. local table1 = {sx126x_reg.RadioStandbyModes_t.USE_DCDC}
  224. SX126xSetRegulatorMode(table1)
  225. SX126xSetBufferBaseAddress("00","00")
  226. SX126xSetTxParams( 0, sx126x_reg.RADIO_RAMP_200_US )
  227. SX126xSetDioIrqParams( IRQ_RADIO_ALL, IRQ_RADIO_ALL, IRQ_RADIO_NONE, IRQ_RADIO_NONE )
  228. local table2 = {sx126x_reg.RadioStandbyModes_t.STDBY_RC}
  229. SX126xSetStandby(table2)
  230. end
  231. -- --测试案例1
  232. -- sys.taskInit(function ()
  233. -- sys.wait(3000)
  234. -- -- SX126xInit()
  235. -- sys.wait(3000)
  236. -- i = 0
  237. -- while true do
  238. -- -- local ret = Drv_spi.drv_spi_read_write_byte("1D0740000000",4)
  239. -- -- log.info("提取结果", ret) -- 输出: 1D0F
  240. -- log.info("计算结果", i%2)
  241. -- if i%2 == 0 then
  242. -- log.info("1")
  243. -- SX126xResetGPIO(1)
  244. -- else
  245. -- log.info("0")
  246. -- SX126xResetGPIO(0)
  247. -- end
  248. -- i = i + 1
  249. -- sys.wait(3*1000)
  250. -- end
  251. -- spi.close(spi.SPI_1)
  252. -- end)
  253. -- --测试案例:获取 local sendData = sx126x_reg.RadioCommands[RADIO_READ_REGISTER]语法是否正确
  254. -- sys.taskInit(function ()
  255. -- sys.wait(3000)
  256. -- log.info("计算结果", "测试1")
  257. -- while true do
  258. -- log.info("计算结果", sx126x_reg.RadioCommands.RADIO_READ_REGISTER)
  259. -- log.info("计算结果", "测试")
  260. -- sys.wait(3*1000)
  261. -- end
  262. -- end)
  263. -- --测试案例:测试字符拼接
  264. -- sys.taskInit(function ()
  265. -- sys.wait(3000)
  266. -- SX126xInit()
  267. -- sys.wait(3000)
  268. -- log.info("计算结果", "测试1")
  269. -- while true do
  270. -- log.info("计算结果", SX126xReadRegisters("0740",2))
  271. -- sys.wait(3*1000)
  272. -- end
  273. -- end)
  274. --测试案例:测试配置索引SX126xCopy.ModulationParams.PacketType = sx126x_reg.RadioPacketTypes_t.PACKET_TYPE_LORA
  275. -- sys.taskInit(function ()
  276. -- sys.wait(3000)
  277. -- -- SX126xInit()
  278. -- sys.wait(3000)
  279. -- log.info("计算结果", SX126xCopy.ModulationParams.PacketType)
  280. -- SX126xCopy.ModulationParams.PacketType = sx126x_reg.RadioPacketTypes_t.PACKET_TYPE_LORA
  281. -- log.info("计算结果", SX126xCopy.ModulationParams.PacketType)
  282. -- log.info("计算结果", "测试1")
  283. -- end)
  284. --测试案例:测试添加table元素。仿造C语言中的枚举
  285. -- sys.taskInit(function ()
  286. -- sys.wait(3000)
  287. -- -- SX126xInit()
  288. -- sys.wait(3000)
  289. -- SX126x.test = "nihao"
  290. -- local jsondata = json.encode(SX126x)
  291. -- log.info("testJson.encode",jsondata)
  292. -- log.info("计算结果", "测试1")
  293. -- end)
  294. -- --测试案例:拼接buffer
  295. -- sys.taskInit(function ()
  296. -- sys.wait(3000)
  297. -- SX126xWriteCommand(sx126x_reg.RadioCommands.RADIO_READ_REGISTER,numbers)
  298. -- sys.wait(3000)
  299. -- log.info("计算结果", "测试1")
  300. -- end)
  301. -- [I]-[修改前数据]
  302. -- [I]-[源数据] {"KEY6":[1,2,3],"KEY3":"VALUE3","KEY4":"VALUE4","KEY2":"VALUE2","KEY1":"VALUE1","KEY5":{"KEY5_2":"VALU5_2","KEY5_1":"VALU5_1"}}
  303. -- [I]-[源数据复制] {"KEY6":[1,2,3],"KEY3":"VALUE3","KEY4":"VALUE4","KEY2":"VALUE2","KEY1":"VALUE1","KEY5":{"KEY5_2":"VALU5_2","KEY5_1":"VALU5_1"}}
  304. -- [I]-[修改后数据]
  305. -- [I]-[源数据] {"KEY6":[1,2,3],"KEY3":"VALUE3","KEY4":"VALUE4","KEY2":"VALUE2","KEY1":"VALUE1_1","KEY5":{"KEY5_2":"VALU5_2","KEY5_1":"VALU5_1"}}
  306. -- [I]-[源数据复制] {"KEY6":[1,2,3],"KEY3":"VALUE3","KEY4":"VALUE4","KEY2":"VALUE2","KEY1":"VALUE1_1","KEY5":{"KEY5_2":"VALU5_2","KEY5_1":"VALU5_1"}}
  307. -- [I]-[计算结果] 测试1
  308. -- sys.taskInit(function ()
  309. -- sys.wait(3000)
  310. -- -- SX126xInit()
  311. -- sys.wait(3000)
  312. -- local Person = {
  313. -- name = "openLuat",
  314. -- age = 18,
  315. -- sex = "male",
  316. -- hobby = {"reading","programming"},
  317. -- }
  318. -- local torigin =
  319. -- {
  320. -- KEY1 = "VALUE1",
  321. -- KEY2 = "VALUE2",
  322. -- KEY3 = "VALUE3",
  323. -- KEY4 = "VALUE4",
  324. -- KEY5 = {KEY5_1="VALU5_1",KEY5_2="VALU5_2"},
  325. -- KEY6 = {1,2,3},
  326. -- }
  327. -- local torigin_gson = torigin
  328. -- log.info("修改前数据")
  329. -- log.info("源数据",json.encode(torigin))
  330. -- log.info("源数据复制",json.encode(torigin_gson))
  331. -- log.info("修改后数据")
  332. -- torigin_gson.KEY1 = "VALUE1_1"
  333. -- log.info("源数据",json.encode(torigin))
  334. -- log.info("源数据复制",json.encode(torigin_gson))
  335. local result = spi.setup(spi.SPI_1,0,0,8,100000,1)--初始化spi,
  336. log.info("spi1",spi.SPI_1)
  337. log.info("testSpiFlash.init",result)
  338. local s = string.fromHex("1D0740000000")
  339. sys.taskInit(function ()
  340. sys.wait(5000)
  341. while true do
  342. -- log.info("testSpiFlash.readFlashID",spi.send_recv(spi.SPI_1,s):toHex())--收发读写
  343. --下面方法和上面的等价
  344. -- spi.send(spi.SPI_1,string.char(0x1d,0x07,0x40,0x00,0x00,0x00))
  345. -- sys.wait(5)
  346. -- log.info("testSpiFlash.readFlashID",spi.recv(spi.SPI_1,8):toHex())--收数据
  347. -- local ret = Drv_spi.drv_spi_read_write_byte("1D",1)
  348. -- log.info("testSpiFlash.readFlashID",ret)
  349. -- sys.wait(20)
  350. -- local ret = Drv_spi.drv_spi_read_write_byte("07400000",1)
  351. -- log.info("testSpiFlash.readFlashID",ret)
  352. -- SX126xWriteCommand("1d",{"0740"})
  353. -- log.info("计算结果", SX126xReadRegisters("0740",1))
  354. log.info("testSpiFlash.sendCommand",spi.send(spi.SPI_1,string.char(0x1d)))--发数据
  355. log.info("testSpiFlash.sendCommand",spi.send(spi.SPI_1,string.char(0x07)))--发数据
  356. log.info("testSpiFlash.sendCommand",spi.send(spi.SPI_1,string.char(0x40)))--发数据
  357. log.info("testSpiFlash.readFlashID",spi.recv(spi.SPI_1,6):toHex())--收数据
  358. log.info("testSpiFlash.readFlashID",spi.recv(spi.SPI_1,6):toHex())--收数据
  359. sys.wait(2000)
  360. end
  361. spi.close(spi.SPI_1)
  362. end)