Changes for page End Device AT Commands and Downlink Command
Last modified by kai on 2024/09/06 10:00
Summary
-
Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -9,37 +9,37 @@ 9 9 10 10 Dragino LoRaWAN End Node support two types of AT Commands and Downlink Commands: 11 11 12 -* **Common Commands:** They should be available for each sensor, such as: change uplink interval, reset device. 13 -* **Sensor Related Commands:** Only for special sensor, such as control relay, poll RS485 device. 12 +* (% style="color:blue" %)**Common Commands:** (%%) They should be available for each sensor, such as: change uplink interval, reset device. 13 +* (% style="color:blue" %)**Sensor Related Commands:** (%%) Only for special sensor, such as control relay, poll RS485 device. 14 14 15 15 ((( 16 16 **This page shows the common commands since Dragino LoRaWAN stack DR-LWS-005. Make sure the end node support stack higher than DR-LWS-005 before checking this page.** 17 - 18 18 ))) 19 19 19 + 20 20 = 2. How to use AT Commands or Downlink command = 21 21 22 22 23 -* ForAT Command,See Devices User Manual forDevice. The user manual can be found in each product page of [[Dragino Official Website>>url:http://www.dragino.com/]]24 -* ForLoRaWAN Downlink: The gateway transfer downlink command in HEX format. This page shows theHEX format downlinkcodefor eachcommand. but some servers use base64 as downlink code. Below are reference for how to use downlink command:23 +* **AT Command** : See Devices User Manual for how to connect to device via USB TTL adapter and use. The user manual can be found in each product page of [[Dragino Official Website>>url:http://www.dragino.com/]] 24 +* **LoRaWAN Downlink Command**: The gateway transfer downlink command in HEX format. This page shows the Downlink Command In HEX format. Please note some LoRaWAN servers use base64 as downlink code so user need to convert HEX to Base64 and use. Below are references for how to use downlink command: 25 25 ** Use HEX format to send a downlink: [[TTN v3>>Notes for TTN]] 26 -** Use Base64 format to send a downlink: [[Chirpstack>>Notes for ChirpStack]] 26 +** Use Base64 format to send a downlink: [[Chirpstack>>Notes for ChirpStack]], [[How to Convert>>http://wiki.dragino.com/xwiki/bin/view/Main/Notes%20for%20ChirpStack/#H4.1ConvertHEXtoBase64]]? 27 27 ** See use note for more serves [[Servers Note>>doc:Main.WebHome]](IoT LoRaWAN Server) 28 28 29 +(% style="display:none" %) (%%) 29 29 30 - 31 31 = 3. Support End Node and firmware version = 32 32 33 33 34 -(% border="1" style="background-color:# ffffcc;color:green;width:966px" %)35 -|=(% colspan="3" style="width: 963px;" %)((( 34 +(% border="1" style="background-color:#F2F2F2; width:966px" %) 35 +|=(% colspan="3" style="width: 963px;background-color:#D9E2F3" %)((( 36 36 Dragino STM32 base hardware Firmware / LoRaWAN stack list 37 37 ))) 38 -|(% style="width:187px" %)((( 38 +|(% style="width:187px;color:#0070C0" %)((( 39 39 **Model** 40 -)))|(% style="width:330px" %)((( 40 +)))|(% style="width:330px;color:#0070C0" %)((( 41 41 **Description** 42 -)))|(% style="width:445px" %)((( 42 +)))|(% style="width:445px;color:#0070C0" %)((( 43 43 **Firmware Version <~-~-> Stack Version** 44 44 ))) 45 45 |(% style="width:187px" %)((( ... ... @@ -102,20 +102,18 @@ 102 102 ))) 103 103 ))) 104 104 105 +(% style="display:none" %) (%%) 105 105 106 106 = 4. System Management Commands = 107 107 108 - 109 109 == 4.1 Change Uplink Interval == 110 110 111 111 112 112 Feature: Change LoRaWAN End Node Transmit Interval. 113 113 114 -(% class="box infomessage" %) 115 -((( 116 -**AT Command: AT+TDC** 117 -))) 118 118 115 +(% style="color:blue" %)**AT Command: AT+TDC** 116 + 119 119 (% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %) 120 120 |=(% colspan="3" style="width: 724px;" %)AT+TDC 121 121 |(% style="width:165px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:329px" %)**Response** ... ... @@ -128,35 +128,35 @@ 128 128 Set transmit interval to 60000ms = 60 seconds 129 129 ))) 130 130 131 -{{info}} 132 -**Downlink Command: 0x01** 133 -{{/info}} 134 - 135 135 ((( 130 + 131 + 132 +(% style="color:blue" %)**Downlink Command: 0x01** 133 + 136 136 Format: Command Code (0x01) followed by 3 bytes time value. 137 137 ))) 138 138 139 139 ((( 140 -If the downlink payload=0100003C, it means set the END Node ’s Transmit Interval to 0x00003C=60(S), while type code is 01.138 +If the downlink payload=0100003C, it means set the END Node's Transmit Interval to 0x00003C=60(S), while type code is 01. 141 141 ))) 142 142 143 -* **Example 1**: Downlink Payload:** 0100001E** ~/~/ Set Transmit Interval (TDC) = 30 seconds 144 -* **Example 2**: Downlink Payload:** 0100003C** ~/~/ Set Transmit Interval (TDC) = 60 seconds 141 +* **Example 1**: Downlink Payload:** 0100001E** ~/~/ Set Transmit Interval (TDC) = 30 seconds 142 +* **Example 2**: Downlink Payload:** 0100003C** ~/~/ Set Transmit Interval (TDC) = 60 seconds 145 145 144 +(% style="display:none" %) (%%) 146 146 147 - 148 148 == 4.2 Reboot End Node == 149 149 148 + 150 150 Feature: Reboot End Node to perform a new OTAA or ABP Join. 151 151 152 -{{info}} 153 -**AT Command: ATZ** 154 -{{/info}} 155 155 156 -(% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %) 157 -|=(% colspan="3" %)ATZ: Trig a reset of the MCU 158 -|**Command Example**|**Function**|**Response** 159 -|ATZ|Reset MCU|((( 152 +(% style="color:blue" %)**AT Command: ATZ** 153 + 154 +(% border="1" style="background-color:#ffffcc; color:green; width:546px" %) 155 +|=(% colspan="3" style="width: 543px;" %)ATZ: Trig a reset of the MCU 156 +|(% style="width:157px" %)**Command Example**|(% style="width:92px" %)**Function**|(% style="width:294px" %)**Response** 157 +|(% style="width:157px" %)ATZ|(% style="width:92px" %)Reset MCU|(% style="width:294px" %)((( 160 160 Device reset and show booting info 161 161 162 162 LSN50 Device/LoRa ST Module ... ... @@ -170,9 +170,7 @@ 170 170 <followed by the Tx and Rx information> 171 171 ))) 172 172 173 -{{info}} 174 -**Downlink Command: 0x04** 175 -{{/info}} 171 +(% style="color:blue" %)**Downlink Command: 0x04** 176 176 177 177 ((( 178 178 Format: Command Code (0x04) followed by FF. ... ... @@ -179,23 +179,22 @@ 179 179 ))) 180 180 181 181 ((( 182 -If the downlink payload=**04FF**, the end node will reboot. 183 - 184 - 178 +If the downlink payload=**04FF**, the end node will reboot. 185 185 ))) 186 186 181 + 187 187 == 4.3 Reset to factory Default == 188 188 184 + 189 189 Feature: Reset the parameters to Factory Default, factory default value depends on the firmware settings, the OTAA and ABP keys will reserve after this command. 190 190 191 -{{info}} 192 -**AT Command: AT+FDR** 193 -{{/info}} 194 194 195 -(% border="1" style="background-color:#ffffcc; color:green; width:831.222px" %) 196 -|=(% colspan="3" style="width: 828px;" %)Reset to factory default 197 -|(% style="width:181px" %)**Command Example**|(% style="width:181px" %)**Function**|(% style="width:465px" %)**Response** 198 -|(% style="width:181px" %)AT+FDR|(% style="width:181px" %)Reset to factory default|(% style="width:465px" %)((( 188 +(% style="color:blue" %)**AT Command: AT+FDR** 189 + 190 +(% border="1" style="background-color:#ffffcc; color:green; width:789px" %) 191 +|=(% colspan="3" style="width: 786px;" %)Reset to factory default 192 +|(% style="width:154px" %)**Command Example**|(% style="width:175px" %)**Function**|(% style="width:456px" %)**Response** 193 +|(% style="width:154px" %)AT+FDR|(% style="width:175px" %)Reset to factory default|(% style="width:456px" %)((( 199 199 Device reset to factory default parameters and show booting info 200 200 201 201 LSN50 Device/LoRa ST Module ... ... @@ -209,9 +209,7 @@ 209 209 Please set the parameters or reset Device to apply change 210 210 ))) 211 211 212 -{{info}} 213 -**Downlink Command: 0x04** 214 -{{/info}} 207 +(% style="color:blue" %)**Downlink Command: 0x04** 215 215 216 216 ((( 217 217 Format: Command Code (0x04) followed by FE. ... ... @@ -224,24 +224,22 @@ 224 224 225 225 == 4.4 Show Firmware Version == 226 226 220 + 227 227 Feature: Show firmware version. No downlink command yet. 228 228 229 -{{info}} 230 -**AT Command: AT+VER** 231 -{{/info}} 232 232 233 -(% border="1" style="background-color:#ffffcc; color:green; width:586px" %) 234 -|=(% colspan="3" style="width: 583px;" %)AT+VER: Image Version and Frequency Band 235 -|(% style="width:170px" %)**Command Example**|(% style="width:300px" %)**Function**|(% style="width:113px" %)**Response** 236 -|(% style="width:170px" %)AT+VER=?|(% style="width:300px" %)Show Image version and Frequency Band|(% style="width:113px" %)((( 224 +(% style="color:blue" %)**AT Command: AT+VER** 225 + 226 +(% border="1" style="background-color:#ffffcc; color:green; width:542px" %) 227 +|=(% colspan="3" style="width: 539px;" %)AT+VER: Image Version and Frequency Band 228 +|(% style="width:157px" %)**Command Example**|(% style="width:295px" %)**Function**|(% style="width:86px" %)**Response** 229 +|(% style="width:157px" %)AT+VER=?|(% style="width:295px" %)Show Image version and Frequency Band|(% style="width:86px" %)((( 237 237 1.3 EU868 238 238 239 239 OK 240 240 ))) 241 241 242 -{{info}} 243 -**Downlink Command: 0x26 (Valid in 006 stack)** 244 -{{/info}} 235 +(% style="color:blue" %)**Downlink Command: 0x26 (Valid in 006 stack)** 245 245 246 246 ((( 247 247 Downlink Format: 0x26 ... ... @@ -252,6 +252,8 @@ 252 252 ))) 253 253 254 254 ((( 246 + 247 + 255 255 **xx: Software Type:** 256 256 ))) 257 257 ... ... @@ -260,6 +260,8 @@ 260 260 * 0x00 03: LSE01/LDDS75/LDDS20/LSPH01/LLMS01/LSNPK01 261 261 262 262 ((( 256 + 257 + 263 263 **yy: Frequency Band:** 264 264 ))) 265 265 ... ... @@ -275,6 +275,8 @@ 275 275 * 0xa0: AS923-3 276 276 277 277 ((( 273 + 274 + 278 278 **zz: Subband** 279 279 ))) 280 280 ... ... @@ -283,39 +283,36 @@ 283 283 284 284 == 4.5 Show System Configure == 285 285 283 + 286 286 Feature: Show All configure. No downlink command yet. 287 287 288 -{{info}} 289 -**AT Command: AT+CFG** 290 -{{/info}} 291 291 287 +(% style="color:blue" %)**AT Command: AT+CFG** 288 + 292 292 (% border="1" style="background-color:#ffffcc; color:green; width:599.222px" %) 293 293 |=(% colspan="3" style="width: 596px;" %)AT+CFG: Print all configurations 294 294 |(% style="width:160px" %)**Command Example**|(% style="width:154px" %)**Function**|(% style="width:280px" %)**Response** 295 295 |(% style="width:160px" %)AT+CFG|(% style="width:154px" %)Show all configures|(% style="width:280px" %)((( 296 296 AT+DEUI = XX XX XX XX XX XX XX XX 297 - 298 298 AT+DADDR=XXXXXXXX 299 - 300 300 ………. 301 - 302 302 AT+RX2WTO=X 303 - 304 304 AT+CHS=868100000 305 - 306 306 OK 307 307 ))) 308 308 301 +(% style="display:none" %) (%%) 302 + 309 309 = 5. Keys, IDs and EUIs management = 310 310 311 311 == 5.1 Application EUI == 312 312 307 + 313 313 Feature: Get or Set the Application EUI. 314 314 315 -{{info}} 316 -**AT Command: AT+APPEUI** 317 -{{/info}} 318 318 311 +(% style="color:blue" %)**AT Command: AT+APPEUI** 312 + 319 319 (% border="1" style="background-color:#ffffcc; color:green; width:686.222px" %) 320 320 |=(% colspan="3" style="width: 683px;" %)AT+APPEUI 321 321 |(% style="width:305px" %)**Command Example**|(% style="width:186px" %)**Function**|(% style="width:191px" %)**Response** ... ... @@ -324,14 +324,16 @@ 324 324 ))) 325 325 |(% style="width:305px" %)AT+APPEUI=00 b3 d5 7e f0 00 4d 34|(% style="width:186px" %)Set the Application EUI|(% style="width:191px" %)OK 326 326 321 +(% style="display:none" %) (%%) 322 + 327 327 == 5.2 Application Key == 328 328 325 + 329 329 Feature: Get or Set the Application Key. 330 330 331 -{{info}} 332 -**AT Command: AT+APPKEY** 333 -{{/info}} 334 334 329 +(% style="color:blue" %)**AT Command: AT+APPKEY** 330 + 335 335 (% border="1" style="background-color:#ffffcc; color:green; width:976.222px" %) 336 336 |=(% colspan="3" style="width: 973px;" %)AT+APPKEY 337 337 |(% style="width:441px" %)**Command Example**|(% style="width:180px" %)**Function**|(% style="width:350px" %)**Response** ... ... @@ -340,14 +340,16 @@ 340 340 ))) 341 341 |(% style="width:441px" %)AT+APPKEY=00 35 55 55 22 23 55 53 43 24 23 42 34 35 35 35|(% style="width:180px" %)Set the Application Key|(% style="width:350px" %)OK 342 342 339 +(% style="display:none" %) (%%) 340 + 343 343 == 5.3 Application Session Key == 344 344 343 + 345 345 Feature: Get or Set the Application Session Key. 346 346 347 -{{info}} 348 -**AT Command: AT+APPSKEY** 349 -{{/info}} 350 350 347 +(% style="color:blue" %)**AT Command: AT+APPSKEY** 348 + 351 351 (% border="1" style="background-color:#ffffcc; color:green; width:1040.22px" %) 352 352 |=(% colspan="3" style="width: 1037px;" %)AT+APPSKEY 353 353 |(% style="width:451px" %)**Command Example**|(% style="width:231px" %)**Function**|(% style="width:354px" %)**Response** ... ... @@ -358,14 +358,16 @@ 358 358 OK 359 359 ))) 360 360 359 +(% style="display:none" %) (%%) 360 + 361 361 == 5.4 Device Address == 362 362 363 + 363 363 Feature: Get or Set the Device Address. 364 364 365 -{{info}} 366 -**AT Command: AT+DADDR** 367 -{{/info}} 368 368 367 +(% style="color:blue" %)**AT Command: AT+DADDR** 368 + 369 369 (% border="1" style="background-color:#ffffcc; color:green; width:795.222px" %) 370 370 |=(% colspan="3" style="width: 792px;" %)AT+DADDR 371 371 |(% style="width:192px" %)**Command Example**|(% style="width:241px" %)**Function**|(% style="width:359px" %)**Response** ... ... @@ -376,14 +376,16 @@ 376 376 ))) 377 377 |(% style="width:192px" %)AT+DADDR=A8 40 41 FF|(% style="width:241px" %)Set the Application Session Key.|(% style="width:359px" %)OK 378 378 379 +(% style="display:none" %) (%%) 380 + 379 379 == 5.5 Device EUI == 380 380 383 + 381 381 Feature: Get or Set the Device EUI. 382 382 383 -{{info}} 384 -**AT Command: AT+DEUI** 385 -{{/info}} 386 386 387 +(% style="color:blue" %)**AT Command: AT+DEUI** 388 + 387 387 (% border="1" style="background-color:#ffffcc; color:green; width:1035.22px" %) 388 388 |=(% colspan="3" style="width: 1032px;" %)AT+DEUI 389 389 |(% style="width:250px" %)**Command Example**|(% style="width:147px" %)**Function**|(% style="width:634px" %)**Response** ... ... @@ -394,14 +394,16 @@ 394 394 OK 395 395 ))) 396 396 399 +(% style="display:none" %) (%%) 400 + 397 397 == 5.6 Network ID == 398 398 403 + 399 399 Feature: Get or Set the Network ID.(You can enter this command change only after successful network connection) 400 400 401 -{{info}} 402 -**AT Command: AT+NWKID** 403 -{{/info}} 404 404 407 +(% style="color:blue" %)**AT Command: AT+NWKID** 408 + 405 405 (% border="1" style="background-color:#ffffcc; color:green; width:448.222px" %) 406 406 |=(% colspan="3" style="width: 445px;" %)AT+NWKID 407 407 |(% style="width:191px" %)**Command Example**|(% style="width:153px" %)**Function**|(% style="width:101px" %)**Response** ... ... @@ -410,14 +410,16 @@ 410 410 ))) 411 411 |(% style="width:191px" %)AT+NWKID=A8 40 41 FF|(% style="width:153px" %)Set the Network ID.|(% style="width:101px" %)OK 412 412 417 +(% style="display:none" %) (%%) 418 + 413 413 == 5.7 Network Session Key == 414 414 421 + 415 415 Feature: Get or Set the Network Session Key 416 416 417 -{{info}} 418 -**AT Command: AT+NWKSKEY** 419 -{{/info}} 420 420 425 +(% style="color:blue" %)**AT Command: AT+NWKSKEY** 426 + 421 421 (% border="1" style="background-color:#ffffcc; color:green; width:1017.22px" %) 422 422 |=(% colspan="3" style="width: 1014px;" %)AT+NWKSKEY 423 423 |(% style="width:455px" %)**Command Example**|(% style="width:215px" %)**Function**|(% style="width:343px" %)**Response** ... ... @@ -426,18 +426,20 @@ 426 426 ))) 427 427 |(% style="width:455px" %)AT+NWKSKEY=A8 40 41 FF FF 12 34 56 00 01 02 04 05 06 06 07|(% style="width:215px" %)Set the Network Session Key.|(% style="width:343px" %)OK 428 428 435 +(% style="display:none" %) (%%) 436 + 429 429 = 6. Joining and sending date on LoRaWAN network = 430 430 431 431 == 6.1 Confirm Mode == 432 432 433 -=== AT+CFM command before DR-LWS007 software stack === 441 +=== 6.1.1 AT+CFM command before DR-LWS007 software stack === 434 434 443 + 435 435 Feature: Get or Set the confirmation mode (0-1). 436 436 437 -{{info}} 438 -**AT Command: AT+CFM** 439 -{{/info}} 440 440 447 +(% style="color:blue" %)**AT Command: AT+CFM** 448 + 441 441 (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 442 442 |=(% colspan="3" style="width: 707px;" %)AT+CFM 443 443 |(% style="width:155px" %)**Command Example**|(% style="width:205px" %)**Function**|(% style="width:346px" %)**Response** ... ... @@ -447,21 +447,22 @@ 447 447 |(% style="width:155px" %)AT+CFM=1|(% style="width:205px" %)Set the confirmation mode|(% style="width:346px" %)OK 448 448 |(% style="width:155px" %)AT+CFM=2|(% style="width:205px" %)Set the confirmation mode|(% style="width:346px" %)While Error in format, return AT_PARAM_ERROR 449 449 450 -Downlink Command: 0x05 458 +(% style="color:blue" %)**Downlink Command: 0x05** 451 451 452 452 Format: Command Code (0x05) followed by 2 bytes mode value. 453 453 454 454 If the downlink payload=0501, it means set end node to use confirm mode, while type code is 05. 455 455 456 -* Example 1: Downlink Payload: 0501 ~/~/ Set AT+CFM=1 457 -* Example 2: Downlink Payload: 0500 ~/~/ Set AT+CFM=0 464 +* **Example 1:** Downlink Payload: 0501 ~/~/ Set AT+CFM=1 465 +* **Example 2:** Downlink Payload: 0500 ~/~/ Set AT+CFM=0 458 458 459 - ===AT+CFM commandsinceDR-LWS007softwarestack===467 +(% style="display:none" %) (%%) 460 460 461 -{{info}} 462 -**AT Command: AT+CFM** 463 -{{/info}} 469 +=== 6.1.2 AT+CFM command since DR-LWS007 software stack === 464 464 471 + 472 +(% style="color:blue" %)**AT Command: AT+CFM** 473 + 465 465 (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 466 466 |=(% colspan="3" style="width: 707px;" %)AT+CFM 467 467 |(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response** ... ... @@ -493,57 +493,60 @@ 493 493 OK 494 494 ))) 495 495 496 -{{info}} 497 -**Downlink Command: 0x05** 498 -{{/info}} 505 +(% style="color:blue" %)**Downlink Command: 0x05** 499 499 500 500 Format: Command Code (0x05) followed by 2 bytes mode value. 501 501 502 502 If the downlink payload=05010101, it means set end node to use confirm mode, while type code is 05. 503 503 504 -* Example 1: Downlink Payload: 05010101 ~/~/ Set AT+CFM=1,1,1 505 -* Example 2: Downlink Payload: 05000700 ~/~/ Set AT+CFM=0,7,0 511 +* **Example 1:** Downlink Payload: 05010101 ~/~/ Set AT+CFM=1,1,1 512 +* **Example 2:** Downlink Payload: 05000700 ~/~/ Set AT+CFM=0,7,0 506 506 514 +(% style="display:none" %) (%%) 515 + 507 507 == 6.2 Confirm Status == 508 508 518 + 509 509 Feature: Get confirmation status of the last AT+SEND (0-1). 510 510 511 -{{info}} 512 -**AT Command: AT+CFS** 513 -{{/info}} 514 514 515 -(% border="1" style="background-color:#ffffcc; color:green; width:534.222px" %) 516 -|=(% colspan="3" style="width: 531px;" %)AT+CFS 517 -|(% style="width:156px" %)**Command Example**|(% style="width:193px" %)**Function**|(% style="width:178px" %)**Response** 518 -|(% style="width:156px" %)AT+CFS=?|(% style="width:193px" %)Get confirmation status|(% style="width:178px" %)0((( 522 +(% style="color:blue" %)**AT Command: AT+CFS** 523 + 524 +(% border="1" style="background-color:#ffffcc; color:green; width:463px" %) 525 +|=(% colspan="3" style="width: 460px;" %)AT+CFS 526 +|(% style="width:156px" %)**Command Example**|(% style="width:193px" %)**Function**|(% style="width:107px" %)**Response** 527 +|(% style="width:156px" %)AT+CFS=?|(% style="width:193px" %)Get confirmation status|(% style="width:107px" %)0((( 519 519 OK 520 520 ))) 521 521 531 +(% style="display:none" %) (%%) 532 + 522 522 == 6.3 Join LoRa® Network == 523 523 535 + 524 524 Feature: Join network. 525 525 526 -{{info}} 527 -**AT Command: AT+JOIN** 528 -{{/info}} 529 529 539 +(% style="color:blue" %)**AT Command: AT+JOIN** 540 + 530 530 (% border="1" style="background-color:#ffffcc; color:green; width:647.222px" %) 531 531 |=(% colspan="3" style="width: 644px;" %)AT+JOIN 532 532 |(% style="width:163px" %)**Command Example**|(% style="width:147px" %)**Function**|(% style="width:334px" %)**Response** 533 533 |(% style="width:163px" %)AT+JOIN ?|(% style="width:147px" %)Get imformation.|(% style="width:334px" %)AT+JOIN: Join network((( 534 534 OK 535 - 536 536 While Error in format, return AT_BUSY_ERROR 537 537 ))) 538 538 549 +(% style="display:none" %) (%%) 550 + 539 539 == 6.4 LoRa® Network Join Mode == 540 540 553 + 541 541 Feature: Get or Set the Network Join Mode. (0: ABP, 1: OTAA). 542 542 543 -{{info}} 544 -**AT Command: AT+NJM** 545 -{{/info}} 546 546 557 +(% style="color:blue" %)**AT Command: AT+NJM** 558 + 547 547 (% border="1" style="background-color:#ffffcc; color:green; width:753.222px" %) 548 548 |=(% colspan="3" style="width: 750px;" %)AT+NJM 549 549 |(% style="width:162px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:361px" %)**Response** ... ... @@ -553,25 +553,25 @@ 553 553 |(% style="width:162px" %)AT+NJM=0|(% style="width:227px" %)Set the Network Join Mode|(% style="width:361px" %)OK 554 554 |(% style="width:162px" %)AT+NJM=2|(% style="width:227px" %)Set the Network Join Mode|(% style="width:361px" %)While Error in format, return AT_PARAM_ERROR 555 555 556 -{{info}} 557 -**Downlink Command: 0x20** 558 -{{/info}} 568 +(% style="color:blue" %)**Downlink Command: 0x20** 559 559 560 560 Format: Command Code (0x20) followed by 1 bytes mode value. 561 561 562 562 If the downlink payload=2000, it means set the Network Join Mode, while type code is 20. 563 563 564 -* **Example 1: **Downlink Payload: **2000** 565 -* **Example 2:** Downlink Payload: **2001** ~/~/ Set AT+NJM=1 574 +* **Example 1: **Downlink Payload: **2000 ** ~/~/ Set AT+NJM=0 575 +* **Example 2:** Downlink Payload: **2001** ~/~/ Set AT+NJM=1 566 566 577 +(% style="display:none" %) (%%) 578 + 567 567 == 6.5 LoRa® Network Join Status == 568 568 581 + 569 569 Feature: LoRa® Network Join Status. 570 570 571 -{{info}} 572 -**AT Command: AT+NJS** 573 -{{/info}} 574 574 585 +(% style="color:blue" %)**AT Command: AT+NJS** 586 + 575 575 (% border="1" style="background-color:#ffffcc; color:green; width:498.222px" %) 576 576 |=(% colspan="3" style="width: 495px;" %)AT+NJS 577 577 |(% style="width:169px" %)**Command Example**|(% style="width:164px" %)**Function**|(% style="width:161px" %)**Response** ... ... @@ -579,14 +579,16 @@ 579 579 OK 580 580 ))) 581 581 594 +(% style="display:none" %) (%%) 595 + 582 582 == 6.6 Print Last Received Data in Raw Format == 583 583 598 + 584 584 Feature: Print Last Received Data in Raw Format<port:data>. 585 585 586 -{{info}} 587 -**AT Command: AT+RECV** 588 -{{/info}} 589 589 602 +(% style="color:blue" %)**AT Command: AT+RECV** 603 + 590 590 (% border="1" style="background-color:#ffffcc; color:green; width:587.222px" %) 591 591 |=(% colspan="3" style="width: 584px;" %)AT+RECV 592 592 |(% style="width:161px" %)**Command Example**|(% style="width:272px" %)**Function**|(% style="width:150px" %)**Response** ... ... @@ -594,14 +594,16 @@ 594 594 OK 595 595 ))) 596 596 611 +(% style="display:none" %) (%%) 612 + 597 597 == 6.7 Print Last Received Data in Binary Format == 598 598 615 + 599 599 Feature: Print Last Received Data in Binary Format<port:data>. 600 600 601 -{{info}} 602 -**AT Command: AT+RECVB** 603 -{{/info}} 604 604 619 +(% style="color:blue" %)**AT Command: AT+RECVB** 620 + 605 605 (% border="1" style="background-color:#ffffcc; color:green; width:793.222px" %) 606 606 |=(% colspan="3" style="width: 790px;" %)AT+RECVB 607 607 |(% style="width:173px" %)**Command Example**|(% style="width:497px" %)**Function**|(% style="width:120px" %)**Response** ... ... @@ -609,53 +609,54 @@ 609 609 OK 610 610 ))) 611 611 628 +(% style="display:none" %) (%%) 629 + 612 612 == 6.8 Send Text Data == 613 613 632 + 614 614 Feature: Send Text Data<port:data>. 615 615 616 -{{info}} 617 -**AT Command: AT+SEND** 618 -{{/info}} 619 619 636 +(% style="color:blue" %)**AT Command: AT+SEND** 637 + 620 620 (% border="1" style="background-color:#ffffcc; color:green; width:991.222px" %) 621 621 |=(% colspan="3" style="width: 988px;" %)AT+SEND 622 622 |(% style="width:201px" %)**Command Example**|(% style="width:340px" %)**Function**|(% style="width:446px" %)**Response** 623 623 |(% style="width:201px" %)AT+SEND=12:hello world|(% style="width:340px" %)Send text data along with the application port.|(% style="width:446px" %)OK((( 624 624 While Error in format, return 625 - 626 626 AT_BUSY_ERROR/AT_BUSY_ERROR/AT_NO_NETWORK_JOINED 627 - 628 - 629 629 ))) 630 630 646 +(% style="display:none" %) (%%) 647 + 631 631 == 6.9 Send Hexadecimal Data == 632 632 650 + 633 633 Feature: Send hexadecimal data along with the application port. 634 634 635 -{{info}} 636 -**AT Command: AT+SENDB** 637 -{{/info}} 638 638 639 -(% border="1" style="background-color:#ffffcc; color:green; width:1120.22px" %) 640 -|=(% colspan="3" style="width: 1117px;" %)AT+SENDB 641 -|(% style="width:257px" %)**Command Example**|(% style="width:406px" %)**Function**|(% style="width:453px" %)**Response** 642 -|(% style="width:257px" %)AT+SENDB=12:abcdef0123456789|(% style="width:406px" %)Send hexadecimal data along with the application port.|(% style="width:453px" %)OK 643 -|(% style="width:257px" %)AT+SENDB=abcdef0123456789|(% style="width:406px" %)Send hexadecimal data along with the application port.|(% style="width:453px" %)While Error in format, return((( 644 -AT_PARAM_ERROR AT_BUSY_ERROR/AT_NO_NETWORK_JOINED 654 +(% style="color:blue" %)**AT Command: AT+SENDB** 645 645 646 - 656 +(% border="1" style="background-color:#ffffcc; color:green; width:1101px" %) 657 +|=(% colspan="3" style="width: 1098px;" %)AT+SENDB 658 +|(% style="width:257px" %)**Command Example**|(% style="width:394px" %)**Function**|(% style="width:446px" %)**Response** 659 +|(% style="width:257px" %)AT+SENDB=12:abcdef0123456789|(% style="width:394px" %)Send hexadecimal data along with the application port.|(% style="width:446px" %)OK 660 +|(% style="width:257px" %)AT+SENDB=abcdef0123456789|(% style="width:394px" %)Send hexadecimal data along with the application port.|(% style="width:446px" %)While Error in format, return((( 661 +AT_PARAM_ERROR AT_BUSY_ERROR/AT_NO_NETWORK_JOINED 647 647 ))) 648 648 664 +(% style="display:none" %) (%%) 665 + 649 649 = 7. LoRaWAN network management = 650 650 651 651 == 7.1 Adaptive Data Rate == 652 652 670 + 653 653 Feature: Get or Set the Adaptive Data Rate setting. (0: off, 1: on). 654 654 655 -{{info}} 656 -**AT Command: AT+ADR** 657 -{{/info}} 658 658 674 +(% style="color:blue" %)**AT Command: AT+ADR** 675 + 659 659 (% border="1" style="background-color:#ffffcc; color:green; width:683.222px" %) 660 660 |=(% colspan="3" style="width: 680px;" %)AT+ADR 661 661 |(% style="width:162px" %)**Command Example**|(% style="width:266px" %)**Function**|(% style="width:250px" %)**Response** ... ... @@ -667,24 +667,23 @@ 667 667 AT_PARAM_ERROR 668 668 ))) 669 669 670 -{{info}} 671 -**Downlink Command: 0x22** 672 -{{/info}} 687 +(% style="color:blue" %)**Downlink Command: 0x22** 673 673 674 - 675 675 If the downlink payload=2201, it means setting the adaptive data rate to 1, while type code is 22. 676 676 677 -* **Example 1**: Downlink Payload: **2201** ~/~/ Set AT+ADR=1. 678 -* **Example 2**: Downlink Payload: **2200FFFF** ~/~/ Set AT+ADR=0. 691 +* **Example 1**: Downlink Payload: **2201** ~/~/ Set AT+ADR=1. 692 +* **Example 2**: Downlink Payload: **2200FFFF** ~/~/ Set AT+ADR=0. 679 679 694 +(% style="display:none" %) (%%) 695 + 680 680 == 7.2 LoRa® Class == 681 681 698 + 682 682 Feature: Get or Set the Device Class(Currently only support class A, class C). 683 683 684 -{{info}} 685 -**AT Command:AT+CLASS** 686 -{{/info}} 687 687 702 +(% style="color:blue" %)**AT Command: AT+CLASS** 703 + 688 688 (% border="1" style="background-color:#ffffcc; color:green; width:507.222px" %) 689 689 |=(% colspan="3" style="width: 504px;" %)AT+CLASS 690 690 |(% style="width:163px" %)**Command Example**|(% style="width:166px" %)**Function**|(% style="width:175px" %)**Response** ... ... @@ -695,14 +695,21 @@ 695 695 696 696 ))) 697 697 714 +(% style="display:none" %) 715 + 716 +(% style="color:red" %)**Notice:** 717 + 718 +* Run AT+FDR before running AT+CLASS=C 719 +* After change to Class=C, Before OTAA Join Successfule, the end node will still shows to use CLASS=A for OTAA Joined. It will use CLASS=C after OTAA Join Succeccful. 720 + 698 698 == 7.3 Duty Cycle Setting == 699 699 700 -Feature: Get or Set the ETSI Duty Cycle setting - 0=disable, 1=enable - Only for testing. 701 701 702 -{{info}} 703 -**AT Command:AT+DCS** 704 -{{/info}} 724 +Feature: Get or Set the ETSI Duty Cycle setting** - 0**=disable, **1**=enable - Only for testing. 705 705 726 + 727 +(% style="color:blue" %)**AT Command: AT+DCS** 728 + 706 706 (% border="1" style="background-color:#ffffcc; color:green; width:515.222px" %) 707 707 |=(% colspan="3" style="width: 512px;" %)AT+DCS 708 708 |(% style="width:165px" %)**Command Example**|(% style="width:239px" %)**Function**|(% style="width:107px" %)**Response** ... ... @@ -713,14 +713,21 @@ 713 713 714 714 ))) 715 715 739 +(% style="display:none" %) (%%) 740 + 716 716 == 7.4 Data Rate == 717 717 718 -Feature: Get or Set the Data Rate. (0-7 corresponding to DR_X) . Note: while set Data Rate, please use set Adptive Data Rate, ADR=0 first. otherwise device will response to server's ADR command and change the DR to the setting from server 719 719 720 -{{info}} 721 -**AT Command: AT+DR** 722 -{{/info}} 744 +Feature: Get or Set the Data Rate. (0-7 corresponding to DR_X) . 723 723 746 +(% style="color:red" %) 747 +**Notice:** 748 + 749 +* User need to set Adaptive Data Rate(ADR)=0 first. otherwise device will respond to server's ADR command and change the DR according to server auto-adjustment. 750 +* Data Rate specifies Spreading Factor. The mapping varies in different frequency bands. User can check this link for detail. [[rp2-1.0.3-lorawan-regional-parameters.pdf>>https://lora-alliance.org/resource_hub/rp2-1-0-3-lorawan-regional-parameters/]] 751 + 752 +(% style="color:blue" %)**AT Command: AT+DR** 753 + 724 724 (% border="1" style="background-color:#ffffcc; color:green; width:466.222px" %) 725 725 |=(% colspan="3" style="width: 463px;" %)AT+DR 726 726 |(% style="width:156px" %)**Command Example**|(% style="width:167px" %)**Function**|(% style="width:140px" %)**Response** ... ... @@ -731,24 +731,23 @@ 731 731 732 732 ))) 733 733 734 -{{info}} 735 -**Downlink Command: 0x2200aaFF** 736 -{{/info}} 764 +(% style="color:blue" %)**Downlink Command: 0x2200aaFF** 737 737 738 - 739 739 If the downlink payload=220001FF, it means setting the data rate to 1, while type code is 22 00 aa FF. 740 740 741 -* **Example 1**: Downlink Payload: **220001FF** ~/~/ Set AT+DR=1. 742 -* **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+DR=0. 768 +* **Example 1**: Downlink Payload: **220001FF** ~/~/ Set AT+DR=1. 769 +* **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+DR=0. 743 743 771 +(% style="display:none" %) (%%) 772 + 744 744 == 7.5 Frame Counter Downlink == 745 745 775 + 746 746 Feature: Get or Set the Frame Counter Downlink. 747 747 748 -{{info}} 749 -**AT Command:AT+FCD** 750 -{{/info}} 751 751 779 +(% style="color:blue" %)**AT Command: AT+FCD** 780 + 752 752 (% border="1" style="background-color:#ffffcc; color:green; width:693.222px" %) 753 753 |=(% colspan="3" style="width: 690px;" %)AT+FCD 754 754 |(% style="width:162px" %)**Command Example**|(% style="width:258px" %)**Function**|(% style="width:269px" %)**Response** ... ... @@ -757,18 +757,17 @@ 757 757 ))) 758 758 |(% style="width:162px" %)AT+FCD=10|(% style="width:258px" %)Set the Frame Counter Downlink.|(% style="width:269px" %)(System will write new value to FCD)((( 759 759 OK 760 - 761 - 762 762 ))) 763 763 791 +(% style="display:none" %) (%%) 792 + 764 764 == 7.6 Frame Counter Uplink == 765 765 766 766 Feature: Get or Set the Frame Counter Uplink. 767 767 768 -{{info}} 769 -**AT Command:AT+FCU** 770 -{{/info}} 771 771 798 +(% style="color:blue" %)**AT Command: AT+FCU** 799 + 772 772 (% border="1" style="background-color:#ffffcc; color:green; width:534.222px" %) 773 773 |=(% colspan="3" style="width: 531px;" %)AT+FCU 774 774 |(% style="width:177px" %)**Command Example**|(% style="width:239px" %)**Function**|(% style="width:113px" %)**Response** ... ... @@ -779,14 +779,16 @@ 779 779 780 780 ))) 781 781 810 +(% style="display:none" %) (%%) 811 + 782 782 == 7.7 Join Accept Delay1 == 783 783 814 + 784 784 Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 1 in ms. 785 785 786 -{{info}} 787 -**AT Command:AT+JN1DL** 788 -{{/info}} 789 789 818 +(% style="color:blue" %)**AT Command: AT+JN1DL** 819 + 790 790 (% border="1" style="background-color:#ffffcc; color:green; width:537.222px" %) 791 791 |=(% colspan="3" style="width: 534px;" %)AT+JN1DL 792 792 |(% style="width:164px" %)**Command Example**|(% style="width:229px" %)**Function**|(% style="width:140px" %)**Response** ... ... @@ -797,14 +797,16 @@ 797 797 798 798 ))) 799 799 830 +(% style="display:none" %) (%%) 831 + 800 800 == 7.8 Join Accept Delay2 == 801 801 834 + 802 802 Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 2 in ms. 803 803 804 -{{info}} 805 -**AT Command:AT+JN2DL** 806 -{{/info}} 807 807 838 +(% style="color:blue" %)**AT Command: AT+JN2DL** 839 + 808 808 (% border="1" style="background-color:#ffffcc; color:green; width:538.222px" %) 809 809 |=(% colspan="3" style="width: 535px;" %)AT+JN2DL 810 810 |(% style="width:160px" %)**Command Example**|(% style="width:228px" %)**Function**|(% style="width:146px" %)**Response** ... ... @@ -815,16 +815,18 @@ 815 815 816 816 ))) 817 817 850 +(% style="display:none" %) (%%) 851 + 818 818 == 7.9 Public Network Mode == 819 819 854 + 820 820 Feature: Get or Set the public network mode. (0: off, 1: on). A Public LoRaWAN network use 0x34 as syncword. Default Settings; PNM=1 821 821 822 -Notice: If user build their own LoRaWAN server but still use syncword=0x34, this is still considered a public LoRaWAN network 857 +(% style="color:red" %)**Notice: If user build their own LoRaWAN server but still use syncword=0x34, this is still considered a public LoRaWAN network.** 823 823 824 -{{info}} 825 -**AT Command:AT+PNM** 826 -{{/info}} 827 827 860 +(% style="color:blue" %)**AT Command: AT+PNM** 861 + 828 828 (% border="1" style="background-color:#ffffcc; color:green; width:667.222px" %) 829 829 |=(% colspan="3" style="width: 664px;" %)AT+PNM 830 830 |(% style="width:166px" %)**Command Example**|(% style="width:225px" %)**Function**|(% style="width:272px" %)**Response** ... ... @@ -842,14 +842,16 @@ 842 842 ))) 843 843 |(% style="width:166px" %)AT+PNM=0|(% style="width:225px" %)Set to use private network autoset syncword=0x12|(% style="width:272px" %) 844 844 879 +(% style="display:none" %) (%%) 880 + 845 845 == 7.10 Receive Delay1 == 846 846 883 + 847 847 Feature: Get or Set the delay between the end of the Tx and the Rx Window 1 in ms 848 848 849 -{{info}} 850 -**AT Command:AT+RX1DL** 851 -{{/info}} 852 852 887 +(% style="color:blue" %)**AT Command: AT+RX1DL** 888 + 853 853 (% border="1" style="background-color:#ffffcc; color:green; width:408.222px" %) 854 854 |=(% colspan="3" style="width: 405px;" %)AT+RX1DL 855 855 |(% style="width:155px" %)**Command Example**|(% style="width:128px" %)**Function**|(% style="width:122px" %)**Response** ... ... @@ -860,14 +860,16 @@ 860 860 861 861 ))) 862 862 899 +(% style="display:none" %) (%%) 900 + 863 863 == 7.11 Receive Delay2 == 864 864 903 + 865 865 Feature: Get or Set the delay between the end of the Tx and the Rx Window 2 in ms 866 866 867 -{{info}} 868 -**AT Command:AT+RX2DL** 869 -{{/info}} 870 870 907 +(% style="color:blue" %)**AT Command: AT+RX2DL** 908 + 871 871 (% border="1" style="background-color:#ffffcc; color:green; width:481.222px" %) 872 872 |=(% colspan="3" style="width: 478px;" %)AT+RX2DL 873 873 |(% style="width:175px" %)**Command Example**|(% style="width:152px" %)**Function**|(% style="width:150px" %)**Response** ... ... @@ -878,14 +878,16 @@ 878 878 879 879 ))) 880 880 919 +(% style="display:none" %) (%%) 920 + 881 881 == 7.12 Rx2 Window Data Rate == 882 882 923 + 883 883 Feature: Get or Set the Rx2 window data rate (0-7 corresponding to DR_X) 884 884 885 -{{info}} 886 -**AT Command:AT+RX2DR** 887 -{{/info}} 888 888 927 +(% style="color:blue" %)**AT Command: AT+RX2DR** 928 + 889 889 (% border="1" style="background-color:#ffffcc; color:green; width:525.222px" %) 890 890 |=(% colspan="3" style="width: 522px;" %)AT+RX2DR 891 891 |(% style="width:160px" %)**Command Example**|(% style="width:232px" %)**Function**|(% style="width:130px" %)**Response** ... ... @@ -896,14 +896,16 @@ 896 896 897 897 ))) 898 898 939 +(% style="display:none" %) (%%) 940 + 899 899 == 7.13 Rx2 Window Frequency == 900 900 943 + 901 901 Feature: Get or Set the Rx2 window frequency 902 902 903 -{{info}} 904 -**AT Command:AT+RX2FQ** 905 -{{/info}} 906 906 947 +(% style="color:blue" %)**AT Command: AT+RX2FQ** 948 + 907 907 (% border="1" style="background-color:#ffffcc; color:green; width:587.222px" %) 908 908 |=(% colspan="3" style="width: 584px;" %)AT+RX2FQ 909 909 |(% style="width:183px" %)**Command Example**|(% style="width:240px" %)**Function**|(% style="width:160px" %)**Response** ... ... @@ -914,14 +914,18 @@ 914 914 915 915 ))) 916 916 959 +(% style="display:none" %) (%%) 960 + 917 917 == 7.14 Transmit Power == 918 918 963 + 919 919 Feature: Get or Set the Transmit Power(0-5, MAX:0, MIN:5, according to LoRaWAN Spec, or 40=10dB, 41 = 11dB, …, 50 = 20dB which is out of LoRaWAN spec. ) 920 920 921 -{{info}} 922 -**AT Command:AT+TXP** 923 -{{/info}} 966 +(% style="color:red" %)**Notice: Transmit Power might be changed by ADR from LoRaWAN server. So manually change TXP also remember to set AT+ADR=0 in sensor** 924 924 968 + 969 +(% style="color:blue" %)**AT Command: AT+TXP** 970 + 925 925 (% border="1" style="background-color:#ffffcc; color:green; width:465.222px" %) 926 926 |=(% colspan="3" style="width: 462px;" %)AT+TXP 927 927 |(% style="width:161px" %)**Command Example**|(% style="width:189px" %)**Function**|(% style="width:112px" %)**Response** ... ... @@ -936,17 +936,19 @@ 936 936 937 937 If the downlink payload=22000100, it means setting the TXP to 0. 938 938 939 -* **Example 1**: Downlink Payload: **22000102** ~/~/ Set AT+TXP=2. 940 -* **Example 2**: Downlink Payload: **220000 FF** ~/~/ Set AT+TXP=0.985 +* **Example 1**: Downlink Payload: **22000102** ~/~/ Set AT+TXP=2. 986 +* **Example 2**: Downlink Payload: **22000000** ~/~/ Set AT+TXP=0. 941 941 988 +(% style="display:none" %) (%%) 989 + 942 942 == 7.15 RSSI of the Last Received Packet == 943 943 992 + 944 944 Feature: Get or Set the Rx2 window frequency 945 945 946 -{{info}} 947 -**AT Command:AT+RSSI** 948 -{{/info}} 949 949 996 +(% style="color:blue" %)**AT Command:AT+RSSI** 997 + 950 950 (% border="1" style="background-color:#ffffcc; color:green; width:557.222px" %) 951 951 |=(% colspan="3" style="width: 554px;" %)AT+RSSI 952 952 |(% style="width:164px" %)**Command Example**|(% style="width:289px" %)**Function**|(% style="width:100px" %)**Response** ... ... @@ -954,14 +954,16 @@ 954 954 OK 955 955 ))) 956 956 1005 +(% style="display:none" %) (%%) 1006 + 957 957 == 7.16 SNR of the Last Received Packet == 958 958 1009 + 959 959 Feature: Get the SNR of the last received packet 960 960 961 -{{info}} 962 -**AT Command:AT+SNR** 963 -{{/info}} 964 964 1013 +(% style="color:blue" %)**AT Command: AT+SNR** 1014 + 965 965 (% border="1" style="background-color:#ffffcc; color:green; width:571.222px" %) 966 966 |=(% colspan="3" style="width: 568px;" %)AT+SNR 967 967 |(% style="width:164px" %)**Command Example**|(% style="width:290px" %)**Function**|(% style="width:113px" %)**Response** ... ... @@ -969,14 +969,16 @@ 969 969 OK 970 970 ))) 971 971 1022 +(% style="display:none" %) (%%) 1023 + 972 972 == 7.17 Application Port == 973 973 1026 + 974 974 Feature: Get or set the application port. 975 975 976 -{{info}} 977 -**AT Command: AT+PORT** 978 -{{/info}} 979 979 1030 +(% style="color:blue" %)**AT Command: AT+PORT** 1031 + 980 980 (% border="1" style="background-color:#ffffcc; color:green; width:500.222px" %) 981 981 |=(% colspan="3" style="width: 497px;" %)AT+PORT 982 982 |(% style="width:157px" %)**Command Example**|(% style="width:204px" %)**Function**|(% style="width:135px" %)**Response** ... ... @@ -985,25 +985,25 @@ 985 985 ))) 986 986 |(% style="width:157px" %)AT+PORT=21|(% style="width:204px" %)Set the application port|(% style="width:135px" %)OK 987 987 988 -{{info}} 989 -**Downlink Command: 0x23** 990 -{{/info}} 1040 +(% style="color:blue" %)**Downlink Command: 0x23** 991 991 992 992 Format: Command Code (0x23) followed by 1 bytes port value. 993 993 994 994 If the downlink payload=2301, it means set the application port to 1, while type code is 23. 995 995 996 -* **Example 1**: Downlink Payload: **2301** ~/~/ set the application port to 1 997 -* **Example 2**: Downlink Payload:** 2305** ~/~/ set the application port to 5 1046 +* **Example 1**: Downlink Payload: **2301** ~/~/ set the application port to 1 1047 +* **Example 2**: Downlink Payload:** 2305** ~/~/ set the application port to 5 998 998 1049 +(% style="display:none" %) (%%) 1050 + 999 999 == 7.18 Single Channel Mode == 1000 1000 1053 + 1001 1001 Feature:Get or Set Frequency (Unit: Hz) for Single Channel Mode. 1002 1002 1003 -{{info}} 1004 -**AT Command: AT+CHS** 1005 -{{/info}} 1006 1006 1057 +(% style="color:blue" %)**AT Command: AT+CHS** 1058 + 1007 1007 (% border="1" style="background-color:#ffffcc; color:green; width:603.222px" %) 1008 1008 |=(% colspan="3" style="width: 600px;" %)AT+CHS 1009 1009 |(% style="width:182px" %)**Command Example**|(% style="width:295px" %)**Function**|(% style="width:122px" %)**Response** ... ... @@ -1012,14 +1012,16 @@ 1012 1012 ))) 1013 1013 |(% style="width:182px" %)AT+CHS=868100000|(% style="width:295px" %)Set Frequency for Single Channel Mode|(% style="width:122px" %)OK 1014 1014 1067 +(% style="display:none" %) (%%) 1068 + 1015 1015 == 7.19 Eight Channel Mode == 1016 1016 1071 + 1017 1017 Feature: Get or Set eight channels mode,Only for US915,AU915,CN470. 1018 1018 1019 -{{info}} 1020 -**AT Command: AT+CHE** 1021 -{{/info}} 1022 1022 1075 +(% style="color:blue" %)**AT Command: AT+CHE** 1076 + 1023 1023 (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 1024 1024 |=(% colspan="3" style="width: 707px;" %)AT+CHE 1025 1025 |(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response** ... ... @@ -1030,25 +1030,25 @@ 1030 1030 ))) 1031 1031 |(% style="width:160px" %)AT+CHE=1|(% style="width:198px" %)Set eight channels mode|(% style="width:349px" %)OK 1032 1032 1033 -{{info}} 1034 -**Downlink Command: 0x24** 1035 -{{/info}} 1087 +(% style="color:blue" %)**Downlink Command: 0x24 (LHT65,LHT65N Downlink Command:0x07)** 1036 1036 1037 1037 Format: Command Code (0x24) followed by 1 bytes channel value. 1038 1038 1039 1039 If the downlink payload=2401, it means set channel mode to 1, while type code is 24. 1040 1040 1041 -* **Example 1**: Downlink Payload: 2401 ~/~/ set channel mode to 1 1042 -* **Example 2**: Downlink Payload: 2405 ~/~/ set channel mode to 5 1093 +* **Example 1**: Downlink Payload: 2401 ~/~/ set channel mode to 1 1094 +* **Example 2**: Downlink Payload: 2405 ~/~/ set channel mode to 5 1043 1043 1096 +(% style="display:none" %) (%%) 1097 + 1044 1044 == 7.20 Get or Set RXwindows1 timeout == 1045 1045 1046 -Feature:Get or Set the number of symbols to detect and timeout from RXwindow1(0 to 255). 1047 1047 1048 -{{info}} 1049 -**AT Command: AT+RX1WTO** 1050 -{{/info}} 1101 +Feature: Get or Set the number of symbols to detect and timeout from RXwindow1(0 to 255). 1051 1051 1103 + 1104 +(% style="color:blue" %)**AT Command: AT+RX1WTO** 1105 + 1052 1052 (% border="1" style="background-color:#ffffcc; color:green; width:460.222px" %) 1053 1053 |=(% colspan="3" style="width: 457px;" %)AT+ RX1WTO 1054 1054 |(% style="width:163px" %)**Command Example**|(% style="width:201px" %)**Function**|(% style="width:93px" %)**Response** ... ... @@ -1057,8 +1057,10 @@ 1057 1057 ))) 1058 1058 |(% style="width:163px" %)AT+RX1WTO=60|(% style="width:201px" %)Set RXwindows1 timeout|(% style="width:93px" %)OK 1059 1059 1114 +(% style="display:none" %) (%%) 1115 + 1060 1060 ((( 1061 -**AT+RX1 TWO**1117 +(% style="color:blue" %)**AT+RX1WTO**(%%) is theRxSingle timeout value of receive window 1. If it is not set, then the queriedvalue is the default value. If it is set, then the queried value is the setvalue. AT+RX2TWO is thesame as above. The definitionof RxSingle timeout is as described in the following paragraph. 1062 1062 ))) 1063 1063 1064 1064 [[image:image-20220526162535-1.png]] ... ... @@ -1065,18 +1065,17 @@ 1065 1065 1066 1066 ((( 1067 1067 Increasing thisvalue is equal to extending the time that the receiving window is opened, butthe corresponding power consumption will also increase. Properly increasingthis value can increase the success rate of the downlink. 1068 - 1069 - 1070 1070 ))) 1071 1071 1126 + 1072 1072 == 7.21 Get or Set RXwindows2 timeout == 1073 1073 1074 -Feature:Get or Set the number of symbols to detect and timeout from RXwindow2(0 to 255). 1075 1075 1076 -{{info}} 1077 -**AT Command: AT+RX2WTO** 1078 -{{/info}} 1130 +Feature: Get or Set the number of symbols to detect and timeout from RXwindow2(0 to 255). 1079 1079 1132 + 1133 +(% style="color:blue" %)**AT Command: AT+RX2WTO** 1134 + 1080 1080 (% border="1" style="background-color:#ffffcc; color:green; width:497.222px" %) 1081 1081 |=(% colspan="3" style="width: 494px;" %)AT+ RX2WTO 1082 1082 |(% style="width:190px" %)**Command Example**|(% style="width:199px" %)**Function**|(% style="width:104px" %)**Response** ... ... @@ -1085,14 +1085,16 @@ 1085 1085 ))) 1086 1086 |(% style="width:190px" %)AT+RX2WTO=20|(% style="width:199px" %)Set RXwindows2 timeout|(% style="width:104px" %)OK 1087 1087 1143 +(% style="display:none" %) (%%) 1144 + 1088 1088 == 7.22 Setting up uplinkdwelltime (as923, au915) == 1089 1089 1147 + 1090 1090 Feature: Get or Set uplinkdwelltime 1091 1091 1092 -{{info}} 1093 -**AT Command: AT+DWELLT** 1094 -{{/info}} 1095 1095 1151 +(% style="color:blue" %)**AT Command: AT+DWELLT** 1152 + 1096 1096 (% border="1" style="background-color:#ffffcc; color:green; width:497.222px" %) 1097 1097 |=(% colspan="3" style="width: 494px;" %)AT+DWELLT 1098 1098 |(% style="width:183px" %)**Command Example**|(% style="width:179px" %)**Function**|(% style="width:131px" %)**Response** ... ... @@ -1101,23 +1101,25 @@ 1101 1101 ))) 1102 1102 |(% style="width:183px" %)AT+DWELLT=0|(% style="width:179px" %)Set uplinkdwelltime|(% style="width:131px" %)OK 1103 1103 1104 -{{info}} 1105 -**Downlink Command: 0x25** 1106 -{{/info}} 1161 +(% style="color:blue" %)**Downlink Command: 0x25** 1107 1107 1108 1108 Format: Command Code (0x25) followed by 1 bytes state value. 1109 1109 1110 1110 If the downlink payload=2501, it means set uplinkdwelltime to 1, while type code is 25. 1111 1111 1112 -* **Example 1**: Downlink Payload: **2501** ~/~/ set uplinkdwelltime to 1 1113 -* **Example 2**: Downlink Payload: **2500** ~/~/ set uplinkdwelltime to 0 1167 +* **Example 1**: Downlink Payload: **2501** ~/~/ set uplinkdwelltime to 1 1168 +* **Example 2**: Downlink Payload: **2500** ~/~/ set uplinkdwelltime to 0 1114 1114 1170 +(% style="display:none" %) (%%) 1171 + 1115 1115 == 7.23 Set Packet Receiving Response Level == 1116 1116 1174 + 1117 1117 Feature: Get or Set packet receiving response level. This feature is used to set compatible with different LoRaWAN servers. If RPL doesn;t match , user will see strange message in the server portal. 1118 1118 1119 -RPL value: 1120 1120 1178 +**RPL value:** 1179 + 1121 1121 * **AT+RPL=0:** Device won't immediately reply any downlink commands from platform. 1122 1122 * **AT+RPL=1:** Device will immediately reply message to Unconfirmed Data Down. Payload is 0x00. 1123 1123 * **AT+RPL=2:** Device will immediately reply message to Confirmed Data Down. Payload is 0x00 and requied response header for this command. ... ... @@ -1124,15 +1124,13 @@ 1124 1124 * **AT+RPL=3:** Device will immediately reply message to MAC Command. Payload is 0x00 and requied response header for this command. 1125 1125 * **AT+RPL=4: **Device will immediately reply message to Confirmed Data Down & MAC Command. Payload is 0x00 and requied response header for these two commands. 1126 1126 1127 -Case Analyes: 1186 +**Case Analyes:** 1128 1128 1129 1129 * For Class A devices, AT+RPL=0 is ok. that is defaut settings in software. 1130 1130 * For Class C devices used in ChirpStack, need to set AT+RPL=4 because Chirpstack require immedietely reply message to MAC Command. 1131 1131 * For Class C devices used in TTI, need to set AT+RPL=4 because TTI require immediately reply message to Confirmed Data Down & MAC Command. 1132 1132 1133 -{{info}} 1134 -**AT Command: AT+RPL** 1135 -{{/info}} 1192 +(% style="color:blue" %)**AT Command: AT+RPL** 1136 1136 1137 1137 (% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %) 1138 1138 |=(% colspan="3" style="width: 533px;" %)AT+RPL ... ... @@ -1142,52 +1142,59 @@ 1142 1142 ))) 1143 1143 |(% style="width:160px" %)AT+RPL=0|(% style="width:263px" %)Set packet receiving response level|(% style="width:109px" %)OK 1144 1144 1145 -{{info}} 1146 -**Downlink Command: 0x21** 1147 -{{/info}} 1202 +(% style="color:blue" %)**Downlink Command: 0x21** 1148 1148 1149 1149 Format: Command Code (0x21) followed by 1 bytes level value. 1150 1150 1151 1151 If the downlink payload=2101, it means set packet receiving response level to 1, while type code is 21. 1152 1152 1153 -* **Example 1**: Downlink Payload: **2101** ~/~/ set packet receiving response level to 1 1154 -* **Example 2**: Downlink Payload: **2102** ~/~/ set packet receiving response level to 2 1208 +* **Example 1**: Downlink Payload: **2101** ~/~/ set packet receiving response level to 1 1209 +* **Example 2**: Downlink Payload: **2102** ~/~/ set packet receiving response level to 2 1155 1155 1211 +(% style="display:none" %) (%%) 1212 + 1156 1156 == 7.24 Controls NBTrans in unconfirmed uplink mode(LWS007 NBTrans:Set retransmission packets) == 1157 1157 1158 -{{info}} 1159 -**AT Command: AT+SETMAXNBTRANS ** 1160 -{{/info}} 1161 1161 1162 -(% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %) 1163 -|=(% colspan="3" style="width: 533px;" %)AT+**SETMAXNBTRANS** 1164 -|(% style="width:160px" %)**Command Example**|(% style="width:263px" %)**Function**|(% style="width:109px" %)**Response** 1165 -|(% style="width:160px" %)**AT+SETMAXNBTRANS=1,0**|(% style="width:263px" %)Value1: set the maximum NBTrans.|(% style="width:109px" %)1((( 1216 +(% style="color:blue" %)**AT Command: AT+SETMAXNBTRANS ** 1217 + 1218 +(% border="1" style="background-color:#ffffcc; color:green; width:589px" %) 1219 +|=(% colspan="3" style="width: 586px;" %)AT+**SETMAXNBTRANS** 1220 +|(% style="width:227px" %)**Command Example**|(% style="width:300px" %)**Function**|(% style="width:87px" %)**Response** 1221 +|(% style="width:227px" %)**AT+SETMAXNBTRANS=1,0**|(% style="width:300px" %)Value1: set the maximum NBTrans.|(% style="width:87px" %)1((( 1166 1166 OK 1167 1167 ))) 1168 -|(% style="width:160px" %)**AT+SETMAXNBTRANS=?,1**|(% style="width:263px" %)value2: 0: uplink fcnt doesn't change for each NBTrans; 1: uplink fcnt increase by 1 for each NBTrans.|(% style="width:109px" %)((( 1224 +|(% style="width:227px" %)**AT+SETMAXNBTRANS=?,1**|(% style="width:300px" %)((( 1225 +value2: 0: uplink fcnt doesn't change for each NBTrans; 1226 + 1227 +1: uplink fcnt increase by 1 for each NBTrans. 1228 +)))|(% style="width:87px" %)((( 1169 1169 1 1170 1170 1171 1171 OK 1172 1172 ))) 1173 1173 1174 -{{info}} 1175 -**Downlink Command: 0x33** 1176 -{{/info}} 1234 +(% style="color:blue" %)**Downlink Command: 0x33** 1177 1177 1178 1178 Format: Command Code (0x33) followed by 2 bytes mode value. 1179 1179 1180 1180 If the downlink payload=330100, it means set end node to use confirm mode, while type code is 33. 1181 1181 1182 -* Example 1: Downlink Payload: 330100 ~/~/ Set AT+SETMAXNBTRANS=1,0 1183 -* Example 2: Downlink Payload: 330201 ~/~/ Set AT+SETMAXNBTRANS=2,1 1240 +* Example 1: Downlink Payload: 330100 ~/~/ Set AT+SETMAXNBTRANS=1,0 1241 +* Example 2: Downlink Payload: 330201 ~/~/ Set AT+SETMAXNBTRANS=2,1 1184 1184 1243 +(% style="display:none" %) (%%) 1244 + 1185 1185 == 7.25 Device offline rejoining (LWS007) == 1186 1186 1187 -{{info}} 1188 -**AT Command: AT+DDETECT** 1189 -{{/info}} 1190 1190 1248 +(% style="color:blue" %)**AT Command: AT+DDETECT** 1249 + 1250 +AT+DDETECT=<Flag>,<ACK_Timout_1>,<ACK_Timout_2> (Default Value: AT+DDETECT=1,1440,2880) 1251 + 1252 +* ACK_Timout_1: Unit: min 1253 +* ACK_Timout_2: Unit: min 1254 + 1191 1191 (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 1192 1192 |=(% colspan="3" style="width: 707px;" %)AT+**DDETECT** 1193 1193 |(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response** ... ... @@ -1219,22 +1219,25 @@ 1219 1219 OK 1220 1220 ))) 1221 1221 1222 -{{info}} 1223 -**Downlink Command: 0x33** 1224 -{{/info}} 1286 +(% style="color:blue" %)**Downlink Command: 0x32** 1225 1225 1226 1226 Format: Command Code (0x32) followed by 2 bytes mode value. 1227 1227 1228 -If the downlink payload=320105A00B40, it means set end node to use confirm mode, while type code is 3 3.1290 +If the downlink payload=320105A00B40, it means set end node to use confirm mode, while type code is 32. 1229 1229 1230 -* Example 1: Downlink Payload: 320105A00B40 ~/~/ Set AT+DDETECT=1,1440,2880 1292 +* **Example 1:** Downlink Payload: 320105A00B40 ~/~/ Set AT+DDETECT=1,1440,2880 1293 +** 0x01 : Flag 1294 +** 0x05A0: ACK_Timout_1 : 1440minutes (24 hours) 1295 +** 0x0B40: ACK_Timout_2 : 2880minutes (48 hours) 1296 +** **Explain**: Enable Online Detect, if end node doesn't receive any downlink within ACK_Timout_1( 1440 minutes or 24 hours). End node will use confirmed uplink to send packets during ACK_Timout_1 (the 24th hour) to ACK_Timout_2 ( the 48th hour). If from the 24th to 48th hour, end node got an downlink from server, it will switch back to unconfirmed uplink. end node will restart ACK_Timout_1. If from the 24th to 48th hour, end node still not got any downlink, means device doesn't get ACK from server within last 48 hours. Device will process rejoin, rejoin request interval is AT+RJTDC period. For AU915/ US915, device will use the sub-band used for last join. 1231 1231 1298 +(% style="display:none" %) (%%) 1299 + 1232 1232 == 7.26 Request the server to send an ACK == 1233 1233 1234 -{{info}} 1235 -**AT Command: AT+PNACKMD** 1236 -{{/info}} 1237 1237 1303 +(% style="color:blue" %)**AT Command: AT+PNACKMD** 1304 + 1238 1238 (% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %) 1239 1239 |=(% colspan="3" style="width: 533px;" %)**AT+PNACKMD** 1240 1240 |(% style="width:160px" %)**Command Example**|(% style="width:263px" %)**Function**|(% style="width:109px" %)**Response** ... ... @@ -1243,55 +1243,61 @@ 1243 1243 ))) 1244 1244 |(% style="width:160px" %)**AT+PNACKMD=0**|(% style="width:263px" %)off request the server to send an ACK|(% style="width:109px" %)((( 1245 1245 0 1246 - 1247 1247 OK 1248 1248 ))) 1249 1249 1316 +(% style="display:none" %) (%%) 1317 + 1250 1250 == 7.27 Adjust network rejoining interval == 1251 1251 1252 -{{info}} 1253 -**AT Command: AT+RJTDC** 1254 -{{/info}} 1255 1255 1321 +(% style="color:blue" %)**AT Command: AT+RJTDC** 1322 + 1256 1256 (% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %) 1257 1257 |=(% colspan="3" style="width: 724px;" %)AT+RJTDC 1258 1258 |(% style="width:165px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:329px" %)**Response** 1259 -|(% style="width:165px" %)AT+RJTDC=?|(% style="width:227px" %)Show the ReJoin data transmission interval in min|(% style="width:329px" %)30 000(((1326 +|(% style="width:165px" %)AT+RJTDC=?|(% style="width:227px" %)Show the ReJoin data transmission interval in min|(% style="width:329px" %)30((( 1260 1260 OK 1261 1261 1262 -the interval is 30 000ms= 30s1329 +the interval is 30 min 1263 1263 ))) 1264 -|(% style="width:165px" %)AT+RJTDC=60 000|(% style="width:227px" %)Set the ReJoin data transmission interval in min|(% style="width:329px" %)OK(((1265 -Set the ReJoin data transmission interval to 60 000ms= 60 seconds1331 +|(% style="width:165px" %)AT+RJTDC=60|(% style="width:227px" %)Set the ReJoin data transmission interval in min|(% style="width:329px" %)OK((( 1332 +Set the ReJoin data transmission interval to 60 min 1266 1266 ))) 1267 1267 1268 -{{info}} 1269 -**Downlink Command: 0x26** 1270 -{{/info}} 1335 +(% style="color:blue" %)**Downlink Command: 0x26** 1271 1271 1272 1272 Format: Command Code (0x26) followed by 2 bytes mode value. 1273 1273 1274 1274 If the downlink payload=26000A, it means set end node to use confirm mode, while type code is 26. 1275 1275 1276 -* Example 1: Downlink Payload: 26000A ~/~/ Set AT+RJTDC=10 1277 -* Example 2: Downlink Payload: 260002 ~/~/ Set AT+RJTDC=2 1341 +* **Example 1:** Downlink Payload: 26000A ~/~/ Set AT+RJTDC=10 1342 +* **Example 2: **Downlink Payload: 260002 ~/~/ Set AT+RJTDC=2 1278 1278 1344 +(% style="display:none" %) (%%) 1345 + 1279 1279 = 8. AT Commands Combination = 1280 1280 1281 1281 == 8.1 Set a fix RX2DR for downlink window == 1282 1282 1283 -* **AT+ADR=0 **~-~-> Disable ADR first 1284 -* **AT+RX2DR=xxxx** ~-~-> Set xxxx to your wanted DataRate 1285 1285 1351 +* (% style="color:blue" %)**AT+ADR=0 **(%%) **~-~->** Disable ADR first 1352 + 1353 +* (% style="color:blue" %)**AT+RX2DR=xxxx** (%%) **~-~->** Set xxxx to your wanted DataRate 1354 + 1355 +(% style="display:none" %) (%%) 1356 + 1286 1286 == 8.2 Use Downlink Command to set a fix uplink DR == 1287 1287 1288 -{{info}} 1289 -**Downlink Command: 0x22000500** 1290 -{{/info}} 1291 1291 1292 - Same as:1360 +(% style="color:blue" %)**Downlink Command: 0x22000500** 1293 1293 1294 -* AT+ADR=0 [[Reference>>||anchor="H7.1AdaptiveDataRate"]] 1295 -* AT+DR=5 [[Reference>>||anchor="H7.4DataRate"]] 1296 -* AT+TXP=0 [[Reference>>||anchor="H7.14TransmitPower"]] 1297 -~)~)~) 1362 +**Same as:** 1363 + 1364 +* AT+ADR=0 [[Reference>>||anchor="H7.1AdaptiveDataRate"]] 1365 + 1366 +* AT+DR=5 [[Reference>>||anchor="H7.4DataRate"]] 1367 + 1368 +* AT+TXP=0 [[Reference>>||anchor="H7.14TransmitPower"]] 1369 + 1370 +