Last modified by Xiaoling on 2023/04/20 18:14
Summary
-
Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -11,8 +11,7 @@ 11 11 * User wants to get data forward in gateway and forward to their server base on MQTT/HTTP, etc. (Combine ABP communication method and [[MQTT forward together>>url:https://wiki.dragino.com/index.php/MQTT_Forward_Instruction]]). 12 12 13 13 ((( 14 - 15 -The basic of this feature is the decoding of LoRaWAN ABP End Node. Requirements: 14 +The basic of this feature is the decoding of **LoRaWAN ABP End Node**. Requirements: 16 16 ))) 17 17 18 18 1. LoRaWAN End Node in ABP mode. Make sure your end node works in this mode. End node most are default set to OTAA mode ... ... @@ -19,20 +19,23 @@ 19 19 1. LoRaWAN Gateway model: [[LPS8>>url:http://www.dragino.com/products/lora-lorawan-gateway/item/148-lps8.html]], [[LG308>>url:http://www.dragino.com/products/lora-lorawan-gateway/item/140-lg308.html]], [[DLOS8>>url:http://www.dragino.com/products/lora-lorawan-gateway/item/160-dlos8.html]] ,[[LIG16>>url:http://www.dragino.com/products/lora-lorawan-gateway/item/171-lig16.html]] 20 20 1. Firmware version for below instruction:[[Since LG02_LG08~~-~~-build-v5.4.1593400722-20200629-1120>>url:http://www.dragino.com/downloads/index.php?dir=LoRa_Gateway/LPS8/Firmware/Release/]] 21 21 22 - 23 23 = 2. How it works = 24 24 25 25 26 -Video Instruction: [[https:~~/~~/youtu.be/ZBjXwmp7rwM>>url:https://youtu.be/ZBjXwmp7rwM]] 24 +**Video Instruction**: [[https:~~/~~/youtu.be/ZBjXwmp7rwM>>url:https://youtu.be/ZBjXwmp7rwM]] 27 27 28 28 Assume we have the LoRaWAN tracker LGT92 which works in ABP mode and US915 band. It has below keys: 29 29 30 -{{{AT+NWKSKEY=72 32 63 95 dd 8f e2 b2 13 66 e4 35 93 8f 55 df 28 +(% class="box infomessage" %) 29 +((( 30 +AT+NWKSKEY=72 32 63 95 dd 8f e2 b2 13 66 e4 35 93 8f 55 df 31 31 AT+APPSKEY=b3 17 f8 14 7a 43 27 8a 6a 31 c4 47 3d 55 5d 33 32 32 AT+DADDR=2602111D 33 - }}}33 +))) 34 34 35 +((( 35 35 and we have the LG308 works and US915 band and support ABP decryption. User can input these keys in LG308 so the LG308 can communicate with LGT92. 37 +))) 36 36 37 37 We need to input above keys in LG308 and enable ABP decryption. 38 38 ... ... @@ -45,7 +45,9 @@ 45 45 46 46 Now when this End Node (Dev Addr=2602111D) send a uplink packet. When this packet arrive LG308, LG308 will decode it and put the decode data on the file /var/iot/channels/2602111D . So we have this data for further process with other applications in LG308. 47 47 50 +((( 48 48 We can see the log of LG308 to know this packet arrive 52 +))) 49 49 50 50 [[image:https://wiki.dragino.com/images/thumb/1/16/ABP_DECODE_2.png/600px-ABP_DECODE_2.png||height="205" width="600"]] 51 51 ... ... @@ -54,54 +54,65 @@ 54 54 55 55 The data of End Node is stored in the file /var/iot/channels/2602111D. We can use hexdump command to check it. 56 56 57 -{{{root@dragino-1d25dc:~# hexdump /var/iot/channels/2602111D 58 -0000000 4646 4646 4646 3946 3030 3030 3030 3546 --> Got RSSI and SNR 59 -0000010 cc0c 0b63 0266 017f ff7f ff00 --> Payload 61 +(% class="box" %) 62 +((( 63 +root@dragino-1d25dc:~~# hexdump /var/iot/channels/2602111D 64 +0000000 (% class="mark" %)**4646 4646 4646 3946 3030 3030 3030 3546**(%%) ~-~-> Got RSSI and SNR 65 +0000010 (% class="mark" %)**cc0c 0b63 0266 017f ff7f ff00 **(%%) ~-~-> Payload 60 60 000001c 61 - }}}67 +))) 62 62 63 63 * RSSI: 4646 4646 4646 3946 = 0xFFFF FF9F : So RSSI = (0xFFFF FF9F - 0x100000000) = -97 64 64 * SNR: 3030 3030 3030 3546 = 0x0000 005F = 95, need to divide 10 so SNR is 9.5 65 65 * Payload: 0xcc0c 0b63 0266 017f ff7f ff00 66 66 67 - 68 -{{{Notice 1: The data file stored in LG308 for the end node is bin file. If the end node sends ASCII string to gateway, the output will as below: 69 -in LGT92, use AT+SEND=12:hello world to send ASCII string 70 -root@dragino-1d25dc:~# hexdump /var/iot/channels/2602111D 73 +(% class="box" %) 74 +((( 75 +(% class="mark" %)**Notice 1**(%%): The data file stored in LG308 for the end node is bin file. If the end node sends ASCII string to gateway, the output will as below: 76 +in LGT92, use **AT+SEND=12**:hello world to send ASCII string 77 +root@dragino-1d25dc:~~# hexdump /var/iot/channels/2602111D 71 71 0000000 4646 4646 4646 3946 3030 3030 3030 3546 72 -0000010 6865 6c6c 6f20 776f 726c 6400 79 +0000010 6865 6c6c 6f20 776f 726c 6400 ~-~-> Got ASCII code "hello world" 73 73 000001c 74 - }}}81 +))) 75 75 76 -{{{Notice 2: The upstream payload length should match the LoRaWAN length requirement (max length depends on Frequency and DR), otherwise the gateway can't decode the payload. 77 -}}} 83 +(% class="box" %) 84 +((( 85 +(% class="mark" %)**Notice 2**(%%): The upstream payload length should match the LoRaWAN length requirement (max length depends on Frequency and DR), otherwise the gateway can't decode the payload. 86 +))) 78 78 79 79 === 2.2.1 Decode Method === 80 80 81 -The decode methods: ASCII String, Decode_LHT65 doesn't affect how the sensor data is stored, they are to define how should the sensor data to be sent. 90 +The decode methods: **ASCII String, Decode_LHT65** doesn't affect how the sensor data is stored, they are to define how should the sensor data to be sent. 82 82 83 83 For example we have a LHT65 , works in ABP mode and gateway successful get the data, which are: 84 84 85 -{{{root@dragino-1baf44:~# hexdump /var/iot/channels/01826108 94 +(% class="box" %) 95 +((( 96 +root@dragino-1baf44:~~# hexdump /var/iot/channels/01826108 86 86 0000000 4646 4646 4646 4537 3030 3030 3030 3438 87 -0000010 ccd1 7fff 7fff 017f ff7f ff00 98 +0000010 ccd1 7fff 7fff 017f ff7f ff00 88 88 000001c 89 - }}}100 +))) 90 90 91 91 If we choose ASCII decoder, the MQTT process will send out with mqtt-data: 92 92 93 -{{{Sun Sep 27 04:33:16 2020 user.notice root: [IoT.MQTT]:pub_topic[-t]: dragino-1baf44/01826108/data 104 +(% class="box" %) 105 +((( 106 +Sun Sep 27 04:33:16 2020 user.notice root: [IoT.MQTT]:pub_topic[-t]: dragino-1baf44/01826108/data 94 94 Sun Sep 27 04:33:16 2020 user.notice root: [IoT.MQTT]:decoder: ASCII 95 95 Sun Sep 27 04:33:16 2020 user.notice root: [IoT.MQTT]:mqtt_data[-m]: ffffffe700000048ccd17fff7fff017fff7fff00 96 - }}}109 +))) 97 97 98 98 If we choose Decode_LHT65, the MQTT process will send out with mqtt-data 99 99 100 -{{{Sun Sep 27 04:36:45 2020 user.notice root: [IoT.MQTT]:pub_topic[-t]: dragino-1baf44/01826108/data 113 +(% class="box" %) 114 +((( 115 +Sun Sep 27 04:36:45 2020 user.notice root: [IoT.MQTT]:pub_topic[-t]: dragino-1baf44/01826108/data 101 101 Sun Sep 27 04:36:45 2020 user.notice root: [IoT.MQTT]:decoder: Dragino_LHT65 102 102 Sun Sep 27 04:36:45 2020 user.notice root: [IoT.MQTT]:mqtt_data[-m]: {"Hum_SHT":32.7,"BatV":3.281,"TempC_DS":32.9, 103 103 "EXT":"Temperature Sensor","RSSI":-24,"TempC_SHT":85.0,"SNR":8.2,"ext_sensor":0} 104 - }}}119 +))) 105 105 106 106 Above scripts are store in /etc/lora/decoder/. User can put their scripts here and select it in the UI. 107 107 ... ... @@ -134,12 +134,11 @@ 134 134 135 135 The file should use below format: 136 136 152 +(% class="mark" %)**dev_addr,imme/time,txt/hex,payload** 137 137 138 -dev_addr,imme/time,txt/hex,payload 139 - 140 140 Since fimware > Dragino-v2 lgw-5.4.1608518541 . Support more option 141 141 142 -dev_addr,imme/time,txt/hex,payload,txpw,txbw,SF,frequency,rxwindow 156 +(% class="mark" %)**dev_addr,imme/time,txt/hex,payload,txpw,txbw,SF,frequency,rxwindow** 143 143 144 144 * dev_addr: Inptu the device address 145 145 * imme/time: ... ... @@ -159,15 +159,13 @@ 159 159 * Frequency: Transmit Frequency: example: 923300000 160 160 * rxwindow: transmit on Rx1Window or Rx2Window. 161 161 162 - 163 163 Completely exmaple: 164 164 165 165 * Old version: echo 018193F4,imme,hex,0101 > /var/iot/push/test 166 166 * New version: echo 018193F4,imme,hex,0101,20,1,SF12,923300000,2 > /var/iot/push/test 167 167 181 +(% class="mark" %)**Downstream Frequency** 168 168 169 -Downstream Frequency 170 - 171 171 The LG308 will use the RX2 window info to send the downstream payload, use the default LoRaWAN settings, as below: 172 172 173 173 * EU868: 869.525Mhz, DR0(SF12BW125) ... ... @@ -179,23 +179,33 @@ 179 179 * IN865: 866.55Mhz, SF10 BW125 180 180 * RU864: 869.1Mhz, SF12 BW125 181 181 194 +(% class="mark" %)**Examples:** 182 182 183 -Examples: 196 +(% class="box" %) 197 +((( 198 +we can use echo command to create files in LG308 for downstream. 199 +root@dragino-1d25dc:~~# echo 2602111D,time,hex,12345678 > /var/iot/push/test 200 +))) 184 184 185 -{{{we can use echo command to create files in LG308 for downstream. 186 -root@dragino-1d25dc:~# echo 2602111D,time,hex,12345678 > /var/iot/push/test 202 +(% class="box" %) 203 +((( 204 +1) From logread -f of gateway, we can see it has been added as pedning. 205 +lora_pkt_fwd[4286]: INFO~~ [DNLK]Looking file : test 206 +lora_pkt_fwd[4286]: INFO~~ [DNLK]devaddr:2602111D, txmode:time, pdfm:hex, size:4, payload1:4Vx,payload_hex:77C1BB90 207 +lora_pkt_fwd[4286]: INFO~~ [DNLK] DNLINK PENDING!(1 elems). 208 +))) 187 187 188 -1) From logread -f of gateway, we can see it has been added as pedning. 189 -lora_pkt_fwd[4286]: INFO~ [DNLK]Looking file : test 190 -lora_pkt_fwd[4286]: INFO~ [DNLK]devaddr:2602111D, txmode:time, pdfm:hex, size:4, payload1:4Vx,payload_hex:77C1BB90 191 -lora_pkt_fwd[4286]: INFO~ [DNLK] DNLINK PENDING!(1 elems). 192 - 193 -2) When there is an upstrea from end node, this downstream will be sent and shows: 210 +(% class="box" %) 211 +((( 212 +2) When there is an upstrea from end node, this downstream will be sent and shows: 194 194 lora_pkt_fwd[4286]: INFO: tx_start_delay=1497 (1497.000000) - (1497, bw_delay=0.000000, notch_delay=0.000000) 195 195 lora_pkt_fwd[4286]: [LGWSEND]lgw_send done: count_us=3537314420, freq=923300000, size=17 215 +))) 196 196 197 -3) and the end node will got: 198 -[5764825]***** UpLinkCounter= 98 ***** 217 +(% class="box" %) 218 +((( 219 +3) and the end node will got: 220 +[5764825]~*~*~*~** UpLinkCounter= 98 ~*~*~*~** 199 199 [5764827]TX on freq 905300000 Hz at DR 0 200 200 Update Interval: 60000 ms 201 201 [5765202]txDone ... ... @@ -205,11 +205,13 @@ 205 205 [5767501]rxDone 206 206 Rssi= -41 207 207 Receive data 208 -2:12345678 209 - }}}230 +2:12345678 ~-~-> Hex 231 +))) 210 210 211 -{{{4) If we use the command "echo 2602111D,time,txt,12345678 > /var/iot/push/test" for downstream, the end node will got: 212 -[5955877]***** UpLinkCounter= 102 ***** 233 +(% class="box" %) 234 +((( 235 +4) If we use the command "echo 2602111D,time,txt,12345678 > /var/iot/push/test" for downstream, the end node will got: 236 +[5955877]~*~*~*~** UpLinkCounter= 102 ~*~*~*~** 213 213 [5955879]TX on freq 904100000 Hz at DR 0 214 214 Update Interval: 60000 ms 215 215 [5956254]txDone ... ... @@ -219,47 +219,50 @@ 219 219 [5958595]rxDone 220 220 Rssi= -37 221 221 Receive data 222 -2:3132333435363738 --> ASCII string "12345678" 223 - }}}246 +2:3132333435363738 ~-~-> ASCII string "12345678" 247 +))) 224 224 225 225 = 3. Example 1: Communicate with LT-22222-L = 226 226 227 227 Script can be download from: [[Example Script 1>>url:http://www.dragino.com/downloads/index.php?dir=LoRa_Gateway/LPS8/Firmware/customized_script/&file=talk_to_lt-22222-l_v0.1.sh]] 228 228 229 -{{{#!/bin/sh 253 +(% class="box" %) 254 +((( 255 +#!/bin/sh 230 230 # This scripts shows how to use LPS8/LG308/DLOS8 to communicate with two LoRaWAN End Nodes, without the use of internet or LoRaWAN server 231 231 # 232 -# Hardware Prepare: 233 -# 1. LT-22222-L x 2, both are configured to work in 234 -# 235 -# b) ABP Mode ; 258 +# Hardware Prepare: 259 +# 1. LT-22222-L x 2, both are configured to work in 260 +# a) Class C ; 261 +# b) ABP Mode ; 236 236 # c) AT+Mod=1 237 -# 2. LPS8, 238 -# a) Firmware version > 239 -# b) Input the LT-22222-L keys in LPS so LPS8 can talk with them. 240 -# c) Lorawan server choose built-in 241 -# d) in Custom page, select custom script to point to this script. (put this script in /etc/iot/scripts directory) 242 -# 243 -# How it works? 244 -# a) Devices 1 sends a uplink payload to LPS8. LPS8 will get the DI1 and DI2 info from the payload 245 -# b) LPS8 will send a message to Device 2 to set the Device2 DO1 = Device1 DI1, and Device DO2 = Device DI2. 246 -# c) Device2 will change DO1 and DO2 to according to the message from LPS8, and send back a message to LPS8 with the its DO1 247 -# and DO2 value. LPS8 will ask Device1 to change its DO1 to same as Device 2, and change the DO2 to the same as Device 2. 248 -# ( The purpose of this step is to show that the Device2 has already do the change there). 249 -# 250 -# For example: If current status of Device1 and Device2 leds shows: 251 -# Device1: DI1: ON, DI2: ON , DO1: OFF, DO2: OFF 252 -# Device2: DI1: OFF, DI2: OFF , DO1: OFF, DO2: OFF 263 +# 2. LPS8, 264 +# a) Firmware version > 265 +# b) Input the LT-22222-L keys in LPS so LPS8 can talk with them. 266 +# c) Lorawan server choose built-in 267 +# d) in Custom page, select custom script to point to this script. (put this script in /etc/iot/scripts directory) 253 253 # 254 -# Step2 will cause below change: 255 -# Device1: DI1: ON, DI2: ON , DO1: OFF, DO2: OFF 256 -# Device2: DI1: OFF, DI2: OFF , DO1: ON, DO2: ON 257 -# 258 -# Step3 will cause below change: 259 -# Device1: DI1: ON, DI2: ON , DO1: ON, DO2: ON 260 -# Device2: DI1: OFF, DI2: OFF , DO1: ON, DO2: ON 261 -# So if a person is in the Device 1 location, he can check if the DO LED match DI LEDs on Device 1 to confirm 262 -# whether the Device 2 has been changed.}}} 269 +# How it works? 270 +# a) Devices 1 sends a uplink payload to LPS8. LPS8 will get the DI1 and DI2 info from the payload 271 +# b) LPS8 will send a message to Device 2 to set the Device2 DO1 = Device1 DI1, and Device DO2 = Device DI2. 272 +# c) Device2 will change DO1 and DO2 to according to the message from LPS8, and send back a message to LPS8 with the its DO1 273 +# and DO2 value. LPS8 will ask Device1 to change its DO1 to same as Device 2, and change the DO2 to the same as Device 2. 274 +# ( The purpose of this step is to show that the Device2 has already do the change there). 275 +# 276 +# For example: If current status of Device1 and Device2 leds shows: 277 +# Device1: DI1: ON, DI2: ON , DO1: OFF, DO2: OFF 278 +# Device2: DI1: OFF, DI2: OFF , DO1: OFF, DO2: OFF 279 +# 280 +# Step2 will cause below change: 281 +# Device1: DI1: ON, DI2: ON , DO1: OFF, DO2: OFF 282 +# Device2: DI1: OFF, DI2: OFF , DO1: ON, DO2: ON 283 +# 284 +# Step3 will cause below change: 285 +# Device1: DI1: ON, DI2: ON , DO1: ON, DO2: ON 286 +# Device2: DI1: OFF, DI2: OFF , DO1: ON, DO2: ON 287 +# So if a person is in the Device 1 location, he can check if the DO LED match DI LEDs on Device 1 to confirm 288 +# whether the Device 2 has been changed. 289 +))) 263 263 264 264 ~1. Input keys 265 265 ... ... @@ -298,7 +298,7 @@ 298 298 Full instruction video inlcude how to write scripts to fit server needed is here: 299 299 300 300 301 -Video Instruction: [[https:~~/~~/youtu.be/-nevW6U2TsE>>url:https://youtu.be/-nevW6U2TsE]] 328 +(% class="mark" %)**Video Instruction**: [[https:~~/~~/youtu.be/-nevW6U2TsE>>url:https://youtu.be/-nevW6U2TsE]] 302 302 303 303 304 304 Note: Firmware version must be higher than lgw-5.4.1607519907