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
-
... ... @@ -1,4 +1,4 @@ 1 - ** Table of** **Contents:**1 + **Contents:** 2 2 3 3 {{toc/}} 4 4 ... ... @@ -6,31 +6,28 @@ 6 6 7 7 = 1. Introduction = 8 8 9 - 10 10 Dragino LoRaWAN End Node support two types of AT Commands and Downlink Commands: 11 11 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.11 +* **Common Commands:** They should be available for each sensor, such as: change uplink interval, reset device. 12 +* **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.** 16 + 17 17 ))) 18 18 19 - 20 20 = 2. How to use AT Commands or Downlink command = 21 21 22 - 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: 21 +* For AT Command , See Devices User Manual for Device. The user manual can be found in each product page of [[Dragino Official Website>>url:http://www.dragino.com/]] 22 +* For LoRaWAN Downlink: The gateway transfer downlink command in HEX format. This page shows the HEX format downlink code for each command. but some servers use base64 as downlink code. Below are reference 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]] , [[How to Convert>>http://wiki.dragino.com/xwiki/bin/view/Main/Notes%20for%20ChirpStack/#H4.1ConvertHEXtoBase64]]?24 +** Use Base64 format to send a downlink: [[Chirpstack>>Notes for ChirpStack]] 27 27 ** See use note for more serves [[Servers Note>>doc:Main.WebHome]](IoT LoRaWAN Server) 28 28 29 -(% style="display:none" %) (%%) 30 30 28 + 31 31 = 3. Support End Node and firmware version = 32 32 33 - 34 34 (% border="1" style="background-color:#ffffcc; color:green; width:966px" %) 35 35 |=(% colspan="3" style="width: 963px;" %)((( 36 36 Dragino STM32 base hardware Firmware / LoRaWAN stack list ... ... @@ -102,16 +102,19 @@ 102 102 ))) 103 103 ))) 104 104 102 + 103 + 105 105 = 4. System Management Commands = 106 106 107 107 == 4.1 Change Uplink Interval == 108 108 109 - 110 110 Feature: Change LoRaWAN End Node Transmit Interval. 111 111 110 +(% class="box infomessage" %) 111 +((( 112 +**AT Command: AT+TDC** 113 +))) 112 112 113 -(% style="color:blue" %)**AT Command: AT+TDC** 114 - 115 115 (% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %) 116 116 |=(% colspan="3" style="width: 724px;" %)AT+TDC 117 117 |(% style="width:165px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:329px" %)**Response** ... ... @@ -124,33 +124,35 @@ 124 124 Set transmit interval to 60000ms = 60 seconds 125 125 ))) 126 126 127 -((( 128 - 127 +{{info}} 128 +**Downlink Command: 0x01** 129 +{{/info}} 129 129 130 -(% style="color:blue" %)**Downlink Command: 0x01** 131 - 131 +((( 132 132 Format: Command Code (0x01) followed by 3 bytes time value. 133 133 ))) 134 134 135 135 ((( 136 -If the downlink payload=0100003C, it means set the END Node 's Transmit Interval to 0x00003C=60(S), while type code is 01.136 +If the downlink payload=0100003C, it means set the END Node’s Transmit Interval to 0x00003C=60(S), while type code is 01. 137 137 ))) 138 138 139 -* **Example 1**: Downlink Payload:** 0100001E** 140 -* **Example 2**: Downlink Payload:** 0100003C** 139 +* **Example 1**: Downlink Payload:** 0100001E** ~/~/ Set Transmit Interval (TDC) = 30 seconds 140 +* **Example 2**: Downlink Payload:** 0100003C** ~/~/ Set Transmit Interval (TDC) = 60 seconds 141 141 142 -== 4.2 Reboot End Node == 143 143 144 144 144 +== 4.2 Reboot End Node == 145 + 145 145 Feature: Reboot End Node to perform a new OTAA or ABP Join. 146 146 148 +{{info}} 149 +**AT Command: ATZ** 150 +{{/info}} 147 147 148 -(% style="color:blue" %)**AT Command: ATZ** 149 - 150 -(% border="1" style="background-color:#ffffcc; color:green; width:546px" %) 151 -|=(% colspan="3" style="width: 543px;" %)ATZ: Trig a reset of the MCU 152 -|(% style="width:157px" %)**Command Example**|(% style="width:92px" %)**Function**|(% style="width:294px" %)**Response** 153 -|(% style="width:157px" %)ATZ|(% style="width:92px" %)Reset MCU|(% style="width:294px" %)((( 152 +(% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %) 153 +|=(% colspan="3" %)ATZ: Trig a reset of the MCU 154 +|**Command Example**|**Function**|**Response** 155 +|ATZ|Reset MCU|((( 154 154 Device reset and show booting info 155 155 156 156 LSN50 Device/LoRa ST Module ... ... @@ -164,7 +164,9 @@ 164 164 <followed by the Tx and Rx information> 165 165 ))) 166 166 167 -(% style="color:blue" %)**Downlink Command: 0x04** 169 +{{info}} 170 +**Downlink Command: 0x04** 171 +{{/info}} 168 168 169 169 ((( 170 170 Format: Command Code (0x04) followed by FF. ... ... @@ -178,16 +178,16 @@ 178 178 179 179 == 4.3 Reset to factory Default == 180 180 181 - 182 182 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. 183 183 187 +{{info}} 188 +**AT Command: AT+FDR** 189 +{{/info}} 184 184 185 -(% style="color:blue" %)**AT Command: AT+FDR** 186 - 187 -(% border="1" style="background-color:#ffffcc; color:green; width:789px" %) 188 -|=(% colspan="3" style="width: 786px;" %)Reset to factory default 189 -|(% style="width:154px" %)**Command Example**|(% style="width:175px" %)**Function**|(% style="width:456px" %)**Response** 190 -|(% style="width:154px" %)AT+FDR|(% style="width:175px" %)Reset to factory default|(% style="width:456px" %)((( 191 +(% border="1" style="background-color:#ffffcc; color:green; width:831.222px" %) 192 +|=(% colspan="3" style="width: 828px;" %)Reset to factory default 193 +|(% style="width:181px" %)**Command Example**|(% style="width:181px" %)**Function**|(% style="width:465px" %)**Response** 194 +|(% style="width:181px" %)AT+FDR|(% style="width:181px" %)Reset to factory default|(% style="width:465px" %)((( 191 191 Device reset to factory default parameters and show booting info 192 192 193 193 LSN50 Device/LoRa ST Module ... ... @@ -201,7 +201,9 @@ 201 201 Please set the parameters or reset Device to apply change 202 202 ))) 203 203 204 -(% style="color:blue" %)**Downlink Command: 0x04** 208 +{{info}} 209 +**Downlink Command: 0x04** 210 +{{/info}} 205 205 206 206 ((( 207 207 Format: Command Code (0x04) followed by FE. ... ... @@ -214,22 +214,24 @@ 214 214 215 215 == 4.4 Show Firmware Version == 216 216 217 - 218 218 Feature: Show firmware version. No downlink command yet. 219 219 225 +{{info}} 226 +**AT Command: AT+VER** 227 +{{/info}} 220 220 221 -(% style="color:blue" %)**AT Command: AT+VER** 222 - 223 -(% border="1" style="background-color:#ffffcc; color:green; width:542px" %) 224 -|=(% colspan="3" style="width: 539px;" %)AT+VER: Image Version and Frequency Band 225 -|(% style="width:157px" %)**Command Example**|(% style="width:295px" %)**Function**|(% style="width:86px" %)**Response** 226 -|(% style="width:157px" %)AT+VER=?|(% style="width:295px" %)Show Image version and Frequency Band|(% style="width:86px" %)((( 229 +(% border="1" style="background-color:#ffffcc; color:green; width:586px" %) 230 +|=(% colspan="3" style="width: 583px;" %)AT+VER: Image Version and Frequency Band 231 +|(% style="width:170px" %)**Command Example**|(% style="width:300px" %)**Function**|(% style="width:113px" %)**Response** 232 +|(% style="width:170px" %)AT+VER=?|(% style="width:300px" %)Show Image version and Frequency Band|(% style="width:113px" %)((( 227 227 1.3 EU868 228 228 229 229 OK 230 230 ))) 231 231 232 -(% style="color:blue" %)**Downlink Command: 0x26 (Valid in 006 stack)** 238 +{{info}} 239 +**Downlink Command: 0x26 (Valid in 006 stack)** 240 +{{/info}} 233 233 234 234 ((( 235 235 Downlink Format: 0x26 ... ... @@ -240,8 +240,6 @@ 240 240 ))) 241 241 242 242 ((( 243 - 244 - 245 245 **xx: Software Type:** 246 246 ))) 247 247 ... ... @@ -250,8 +250,6 @@ 250 250 * 0x00 03: LSE01/LDDS75/LDDS20/LSPH01/LLMS01/LSNPK01 251 251 252 252 ((( 253 - 254 - 255 255 **yy: Frequency Band:** 256 256 ))) 257 257 ... ... @@ -267,8 +267,6 @@ 267 267 * 0xa0: AS923-3 268 268 269 269 ((( 270 - 271 - 272 272 **zz: Subband** 273 273 ))) 274 274 ... ... @@ -277,12 +277,12 @@ 277 277 278 278 == 4.5 Show System Configure == 279 279 280 - 281 281 Feature: Show All configure. No downlink command yet. 282 282 284 +{{info}} 285 +**AT Command: AT+CFG** 286 +{{/info}} 283 283 284 -(% style="color:blue" %)**AT Command: AT+CFG** 285 - 286 286 (% border="1" style="background-color:#ffffcc; color:green; width:599.222px" %) 287 287 |=(% colspan="3" style="width: 596px;" %)AT+CFG: Print all configurations 288 288 |(% style="width:160px" %)**Command Example**|(% style="width:154px" %)**Function**|(% style="width:280px" %)**Response** ... ... @@ -300,16 +300,18 @@ 300 300 OK 301 301 ))) 302 302 305 + 306 + 303 303 = 5. Keys, IDs and EUIs management = 304 304 305 305 == 5.1 Application EUI == 306 306 307 - 308 308 Feature: Get or Set the Application EUI. 309 309 313 +{{info}} 314 +**AT Command: AT+APPEUI** 315 +{{/info}} 310 310 311 -(% style="color:blue" %)**AT Command: AT+APPEUI** 312 - 313 313 (% border="1" style="background-color:#ffffcc; color:green; width:686.222px" %) 314 314 |=(% colspan="3" style="width: 683px;" %)AT+APPEUI 315 315 |(% style="width:305px" %)**Command Example**|(% style="width:186px" %)**Function**|(% style="width:191px" %)**Response** ... ... @@ -318,14 +318,16 @@ 318 318 ))) 319 319 |(% style="width:305px" %)AT+APPEUI=00 b3 d5 7e f0 00 4d 34|(% style="width:186px" %)Set the Application EUI|(% style="width:191px" %)OK 320 320 321 -== 5.2 Application Key == 322 322 323 323 327 +== 5.2 Application Key == 328 + 324 324 Feature: Get or Set the Application Key. 325 325 331 +{{info}} 332 +**AT Command: AT+APPKEY** 333 +{{/info}} 326 326 327 -(% style="color:blue" %)**AT Command: AT+APPKEY** 328 - 329 329 (% border="1" style="background-color:#ffffcc; color:green; width:976.222px" %) 330 330 |=(% colspan="3" style="width: 973px;" %)AT+APPKEY 331 331 |(% style="width:441px" %)**Command Example**|(% style="width:180px" %)**Function**|(% style="width:350px" %)**Response** ... ... @@ -334,14 +334,16 @@ 334 334 ))) 335 335 |(% 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 336 336 337 -== 5.3 Application Session Key == 338 338 339 339 345 +== 5.3 Application Session Key == 346 + 340 340 Feature: Get or Set the Application Session Key. 341 341 349 +{{info}} 350 +**AT Command: AT+APPSKEY** 351 +{{/info}} 342 342 343 -(% style="color:blue" %)**AT Command: AT+APPSKEY** 344 - 345 345 (% border="1" style="background-color:#ffffcc; color:green; width:1040.22px" %) 346 346 |=(% colspan="3" style="width: 1037px;" %)AT+APPSKEY 347 347 |(% style="width:451px" %)**Command Example**|(% style="width:231px" %)**Function**|(% style="width:354px" %)**Response** ... ... @@ -352,14 +352,16 @@ 352 352 OK 353 353 ))) 354 354 355 -== 5.4 Device Address == 356 356 357 357 365 +== 5.4 Device Address == 366 + 358 358 Feature: Get or Set the Device Address. 359 359 369 +{{info}} 370 +**AT Command: AT+DADDR** 371 +{{/info}} 360 360 361 -(% style="color:blue" %)**AT Command: AT+DADDR** 362 - 363 363 (% border="1" style="background-color:#ffffcc; color:green; width:795.222px" %) 364 364 |=(% colspan="3" style="width: 792px;" %)AT+DADDR 365 365 |(% style="width:192px" %)**Command Example**|(% style="width:241px" %)**Function**|(% style="width:359px" %)**Response** ... ... @@ -370,14 +370,16 @@ 370 370 ))) 371 371 |(% style="width:192px" %)AT+DADDR=A8 40 41 FF|(% style="width:241px" %)Set the Application Session Key.|(% style="width:359px" %)OK 372 372 373 -== 5.5 Device EUI == 374 374 375 375 385 +== 5.5 Device EUI == 386 + 376 376 Feature: Get or Set the Device EUI. 377 377 389 +{{info}} 390 +**AT Command: AT+DEUI** 391 +{{/info}} 378 378 379 -(% style="color:blue" %)**AT Command: AT+DEUI** 380 - 381 381 (% border="1" style="background-color:#ffffcc; color:green; width:1035.22px" %) 382 382 |=(% colspan="3" style="width: 1032px;" %)AT+DEUI 383 383 |(% style="width:250px" %)**Command Example**|(% style="width:147px" %)**Function**|(% style="width:634px" %)**Response** ... ... @@ -388,14 +388,16 @@ 388 388 OK 389 389 ))) 390 390 391 -== 5.6 Network ID == 392 392 393 393 405 +== 5.6 Network ID == 406 + 394 394 Feature: Get or Set the Network ID.(You can enter this command change only after successful network connection) 395 395 409 +{{info}} 410 +**AT Command: AT+NWKID** 411 +{{/info}} 396 396 397 -(% style="color:blue" %)**AT Command: AT+NWKID** 398 - 399 399 (% border="1" style="background-color:#ffffcc; color:green; width:448.222px" %) 400 400 |=(% colspan="3" style="width: 445px;" %)AT+NWKID 401 401 |(% style="width:191px" %)**Command Example**|(% style="width:153px" %)**Function**|(% style="width:101px" %)**Response** ... ... @@ -404,14 +404,16 @@ 404 404 ))) 405 405 |(% style="width:191px" %)AT+NWKID=A8 40 41 FF|(% style="width:153px" %)Set the Network ID.|(% style="width:101px" %)OK 406 406 407 -== 5.7 Network Session Key == 408 408 409 409 423 +== 5.7 Network Session Key == 424 + 410 410 Feature: Get or Set the Network Session Key 411 411 427 +{{info}} 428 +**AT Command: AT+NWKSKEY** 429 +{{/info}} 412 412 413 -(% style="color:blue" %)**AT Command: AT+NWKSKEY** 414 - 415 415 (% border="1" style="background-color:#ffffcc; color:green; width:1017.22px" %) 416 416 |=(% colspan="3" style="width: 1014px;" %)AT+NWKSKEY 417 417 |(% style="width:455px" %)**Command Example**|(% style="width:215px" %)**Function**|(% style="width:343px" %)**Response** ... ... @@ -420,18 +420,18 @@ 420 420 ))) 421 421 |(% 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 422 422 439 + 440 + 423 423 = 6. Joining and sending date on LoRaWAN network = 424 424 425 425 == 6.1 Confirm Mode == 426 426 427 -=== 6.1.1 AT+CFM command before DR-LWS007 software stack === 428 - 429 - 430 430 Feature: Get or Set the confirmation mode (0-1). 431 431 447 +{{info}} 448 +**AT Command: AT+CFM** 449 +{{/info}} 432 432 433 -(% style="color:blue" %)**AT Command: AT+CFM** 434 - 435 435 (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 436 436 |=(% colspan="3" style="width: 707px;" %)AT+CFM 437 437 |(% style="width:155px" %)**Command Example**|(% style="width:205px" %)**Function**|(% style="width:346px" %)**Response** ... ... @@ -441,83 +441,42 @@ 441 441 |(% style="width:155px" %)AT+CFM=1|(% style="width:205px" %)Set the confirmation mode|(% style="width:346px" %)OK 442 442 |(% style="width:155px" %)AT+CFM=2|(% style="width:205px" %)Set the confirmation mode|(% style="width:346px" %)While Error in format, return AT_PARAM_ERROR 443 443 444 - (% style="color:blue" %)**Downlink Command: 0x05**460 +Downlink Command: 0x05 445 445 446 446 Format: Command Code (0x05) followed by 2 bytes mode value. 447 447 448 448 If the downlink payload=0501, it means set end node to use confirm mode, while type code is 05. 449 449 450 -* **Example 1:**Downlink Payload: 0501451 -* **Example 2:**Downlink Payload: 0500466 +* Example 1: Downlink Payload: 0501 ~/~/ Set AT+CFM=1 467 +* Example 2: Downlink Payload: 0500 ~/~/ Set AT+CFM=0 452 452 453 -=== 6.1.2 AT+CFM command since DR-LWS007 software stack === 454 454 455 455 456 -(% style="color:blue" %)**AT Command: AT+CFM** 457 - 458 -(% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 459 -|=(% colspan="3" style="width: 707px;" %)AT+CFM 460 -|(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response** 461 -|(% style="width:160px" %)((( 462 -AT+CFM=1,0,0 463 - 464 -value1 465 -)))|(% style="width:198px" %)confirmed uplink|(% style="width:349px" %)((( 466 -1 467 - 468 -OK 469 -))) 470 -|(% style="width:160px" %)((( 471 -AT+CFM=0,?,0 472 - 473 -value2 474 -)))|(% style="width:198px" %)set max retry , range: 0 ~~ 7|(% style="width:349px" %)((( 475 -0~~7 476 - 477 -OK 478 -))) 479 -|(% style="width:160px" %)((( 480 -AT+CFM=0,0,1 481 - 482 -value3 483 -)))|(% style="width:198px" %)uplink fcnt increase by 1 for each retry|(% style="width:349px" %)((( 484 -1 485 - 486 -OK 487 -))) 488 - 489 -(% style="color:blue" %)**Downlink Command: 0x05** 490 - 491 -Format: Command Code (0x05) followed by 2 bytes mode value. 492 - 493 -If the downlink payload=05010101, it means set end node to use confirm mode, while type code is 05. 494 - 495 -* **Example 1:** Downlink Payload: 05010101 ~/~/ Set AT+CFM=1,1,1 496 -* **Example 2:** Downlink Payload: 05000700 ~/~/ Set AT+CFM=0,7,0 497 - 498 498 == 6.2 Confirm Status == 499 499 500 - 501 501 Feature: Get confirmation status of the last AT+SEND (0-1). 502 502 475 +{{info}} 476 +**AT Command: AT+CFS** 477 +{{/info}} 503 503 504 -(% style="color:blue" %)**AT Command: AT+CFS** 505 - 506 -(% border="1" style="background-color:#ffffcc; color:green; width:463px" %) 507 -|=(% colspan="3" style="width: 460px;" %)AT+CFS 508 -|(% style="width:156px" %)**Command Example**|(% style="width:193px" %)**Function**|(% style="width:107px" %)**Response** 509 -|(% style="width:156px" %)AT+CFS=?|(% style="width:193px" %)Get confirmation status|(% style="width:107px" %)0((( 479 +(% border="1" style="background-color:#ffffcc; color:green; width:534.222px" %) 480 +|=(% colspan="3" style="width: 531px;" %)AT+CFS 481 +|(% style="width:156px" %)**Command Example**|(% style="width:193px" %)**Function**|(% style="width:178px" %)**Response** 482 +|(% style="width:156px" %)AT+CFS=?|(% style="width:193px" %)Get confirmation status|(% style="width:178px" %)0((( 510 510 OK 511 511 ))) 512 512 513 -== 6.3 Join LoRa® Network == 514 514 515 515 488 +== 6.3 Join LoRa® Network == 489 + 516 516 Feature: Join network. 517 517 492 +{{info}} 493 +**AT Command: AT+JOIN** 494 +{{/info}} 518 518 519 -(% style="color:blue" %)**AT Command: AT+JOIN** 520 - 521 521 (% border="1" style="background-color:#ffffcc; color:green; width:647.222px" %) 522 522 |=(% colspan="3" style="width: 644px;" %)AT+JOIN 523 523 |(% style="width:163px" %)**Command Example**|(% style="width:147px" %)**Function**|(% style="width:334px" %)**Response** ... ... @@ -527,14 +527,16 @@ 527 527 While Error in format, return AT_BUSY_ERROR 528 528 ))) 529 529 530 -== 6.4 LoRa® Network Join Mode == 531 531 532 532 507 +== 6.4 LoRa® Network Join Mode == 508 + 533 533 Feature: Get or Set the Network Join Mode. (0: ABP, 1: OTAA). 534 534 511 +{{info}} 512 +**AT Command: AT+NJM** 513 +{{/info}} 535 535 536 -(% style="color:blue" %)**AT Command: AT+NJM** 537 - 538 538 (% border="1" style="background-color:#ffffcc; color:green; width:753.222px" %) 539 539 |=(% colspan="3" style="width: 750px;" %)AT+NJM 540 540 |(% style="width:162px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:361px" %)**Response** ... ... @@ -544,23 +544,27 @@ 544 544 |(% style="width:162px" %)AT+NJM=0|(% style="width:227px" %)Set the Network Join Mode|(% style="width:361px" %)OK 545 545 |(% 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 546 546 547 -(% style="color:blue" %)**Downlink Command: 0x20** 524 +{{info}} 525 +**Downlink Command: 0x20** 526 +{{/info}} 548 548 549 549 Format: Command Code (0x20) followed by 1 bytes mode value. 550 550 551 551 If the downlink payload=2000, it means set the Network Join Mode, while type code is 20. 552 552 553 -* **Example 1: **Downlink Payload: **2000 0554 -* **Example 2:** Downlink Payload: **2001** 532 +* **Example 1: **Downlink Payload: **2000** ~/~/ Set AT+NJM=O 533 +* **Example 2:** Downlink Payload: **2001** ~/~/ Set AT+NJM=1 555 555 556 -== 6.5 LoRa® Network Join Status == 557 557 558 558 537 +== 6.5 LoRa® Network Join Status == 538 + 559 559 Feature: LoRa® Network Join Status. 560 560 541 +{{info}} 542 +**AT Command: AT+NJS** 543 +{{/info}} 561 561 562 -(% style="color:blue" %)**AT Command: AT+NJS** 563 - 564 564 (% border="1" style="background-color:#ffffcc; color:green; width:498.222px" %) 565 565 |=(% colspan="3" style="width: 495px;" %)AT+NJS 566 566 |(% style="width:169px" %)**Command Example**|(% style="width:164px" %)**Function**|(% style="width:161px" %)**Response** ... ... @@ -568,14 +568,16 @@ 568 568 OK 569 569 ))) 570 570 571 -== 6.6 Print Last Received Data in Raw Format == 572 572 573 573 554 +== 6.6 Print Last Received Data in Raw Format == 555 + 574 574 Feature: Print Last Received Data in Raw Format<port:data>. 575 575 558 +{{info}} 559 +**AT Command: AT+RECV** 560 +{{/info}} 576 576 577 -(% style="color:blue" %)**AT Command: AT+RECV** 578 - 579 579 (% border="1" style="background-color:#ffffcc; color:green; width:587.222px" %) 580 580 |=(% colspan="3" style="width: 584px;" %)AT+RECV 581 581 |(% style="width:161px" %)**Command Example**|(% style="width:272px" %)**Function**|(% style="width:150px" %)**Response** ... ... @@ -583,14 +583,16 @@ 583 583 OK 584 584 ))) 585 585 586 -== 6.7 Print Last Received Data in Binary Format == 587 587 588 588 571 +== 6.7 Print Last Received Data in Binary Format == 572 + 589 589 Feature: Print Last Received Data in Binary Format<port:data>. 590 590 575 +{{info}} 576 +**AT Command: AT+RECVB** 577 +{{/info}} 591 591 592 -(% style="color:blue" %)**AT Command: AT+RECVB** 593 - 594 594 (% border="1" style="background-color:#ffffcc; color:green; width:793.222px" %) 595 595 |=(% colspan="3" style="width: 790px;" %)AT+RECVB 596 596 |(% style="width:173px" %)**Command Example**|(% style="width:497px" %)**Function**|(% style="width:120px" %)**Response** ... ... @@ -598,14 +598,16 @@ 598 598 OK 599 599 ))) 600 600 601 -== 6.8 Send Text Data == 602 602 603 603 588 +== 6.8 Send Text Data == 589 + 604 604 Feature: Send Text Data<port:data>. 605 605 592 +{{info}} 593 +**AT Command: AT+SEND** 594 +{{/info}} 606 606 607 -(% style="color:blue" %)**AT Command: AT+SEND** 608 - 609 609 (% border="1" style="background-color:#ffffcc; color:green; width:991.222px" %) 610 610 |=(% colspan="3" style="width: 988px;" %)AT+SEND 611 611 |(% style="width:201px" %)**Command Example**|(% style="width:340px" %)**Function**|(% style="width:446px" %)**Response** ... ... @@ -617,34 +617,38 @@ 617 617 618 618 ))) 619 619 620 -== 6.9 Send Hexadecimal Data == 621 621 622 622 609 +== 6.9 Send Hexadecimal Data == 610 + 623 623 Feature: Send hexadecimal data along with the application port. 624 624 613 +{{info}} 614 +**AT Command: AT+SENDB** 615 +{{/info}} 625 625 626 -(% style="color:blue" %)**AT Command: AT+SENDB** 627 - 628 -(% border="1" style="background-color:#ffffcc; color:green; width:1101px" %) 629 -|=(% colspan="3" style="width: 1098px;" %)AT+SENDB 630 -|(% style="width:257px" %)**Command Example**|(% style="width:394px" %)**Function**|(% style="width:446px" %)**Response** 631 -|(% style="width:257px" %)AT+SENDB=12:abcdef0123456789|(% style="width:394px" %)Send hexadecimal data along with the application port.|(% style="width:446px" %)OK 632 -|(% 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((( 617 +(% border="1" style="background-color:#ffffcc; color:green; width:1120.22px" %) 618 +|=(% colspan="3" style="width: 1117px;" %)AT+SENDB 619 +|(% style="width:257px" %)**Command Example**|(% style="width:406px" %)**Function**|(% style="width:453px" %)**Response** 620 +|(% style="width:257px" %)AT+SENDB=12:abcdef0123456789|(% style="width:406px" %)Send hexadecimal data along with the application port.|(% style="width:453px" %)OK 621 +|(% 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((( 633 633 AT_PARAM_ERROR AT_BUSY_ERROR/AT_NO_NETWORK_JOINED 634 634 635 635 636 636 ))) 637 637 627 + 628 + 638 638 = 7. LoRaWAN network management = 639 639 640 640 == 7.1 Adaptive Data Rate == 641 641 642 - 643 643 Feature: Get or Set the Adaptive Data Rate setting. (0: off, 1: on). 644 644 635 +{{info}} 636 +**AT Command: AT+ADR** 637 +{{/info}} 645 645 646 -(% style="color:blue" %)**AT Command: AT+ADR** 647 - 648 648 (% border="1" style="background-color:#ffffcc; color:green; width:683.222px" %) 649 649 |=(% colspan="3" style="width: 680px;" %)AT+ADR 650 650 |(% style="width:162px" %)**Command Example**|(% style="width:266px" %)**Function**|(% style="width:250px" %)**Response** ... ... @@ -656,21 +656,26 @@ 656 656 AT_PARAM_ERROR 657 657 ))) 658 658 659 -(% style="color:blue" %)**Downlink Command: 0x22** 650 +{{info}} 651 +**Downlink Command: 0x22** 652 +{{/info}} 660 660 654 + 661 661 If the downlink payload=2201, it means setting the adaptive data rate to 1, while type code is 22. 662 662 663 -* **Example 1**: Downlink Payload: **2201** 664 -* **Example 2**: Downlink Payload: **2200FFFF** 657 +* **Example 1**: Downlink Payload: **2201** ~/~/ Set AT+ADR=1. 658 +* **Example 2**: Downlink Payload: **2200FFFF** ~/~/ Set AT+ADR=0. 665 665 666 -== 7.2 LoRa® Class == 667 667 668 668 662 +== 7.2 LoRa® Class == 663 + 669 669 Feature: Get or Set the Device Class(Currently only support class A, class C). 670 670 666 +{{info}} 667 +**AT Command:AT+CLASS** 668 +{{/info}} 671 671 672 -(% style="color:blue" %)**AT Command: AT+CLASS** 673 - 674 674 (% border="1" style="background-color:#ffffcc; color:green; width:507.222px" %) 675 675 |=(% colspan="3" style="width: 504px;" %)AT+CLASS 676 676 |(% style="width:163px" %)**Command Example**|(% style="width:166px" %)**Function**|(% style="width:175px" %)**Response** ... ... @@ -681,13 +681,15 @@ 681 681 682 682 ))) 683 683 684 -== 7.3 Duty Cycle Setting == 685 685 686 686 687 - Feature:Getor Set the ETSIDuty Cyclesetting** -0**=disable, **1**=enable - Only for testing.682 +== 7.3 Duty Cycle Setting == 688 688 684 +Feature: Get or Set the ETSI Duty Cycle setting - 0=disable, 1=enable - Only for testing. 689 689 690 -(% style="color:blue" %)**AT Command: AT+DCS** 686 +{{info}} 687 +**AT Command:AT+DCS** 688 +{{/info}} 691 691 692 692 (% border="1" style="background-color:#ffffcc; color:green; width:515.222px" %) 693 693 |=(% colspan="3" style="width: 512px;" %)AT+DCS ... ... @@ -699,19 +699,16 @@ 699 699 700 700 ))) 701 701 702 -== 7.4 Data Rate == 703 703 704 704 705 - Feature:Getor Set theData Rate.(0-7 corresponding to DR_X) .702 +== 7.4 Data Rate == 706 706 707 -(% style="color:red" %) 708 -**Notice:** 704 +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 709 709 710 -* 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. 711 -* 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/]] 706 +{{info}} 707 +**AT Command: AT+DR** 708 +{{/info}} 712 712 713 -(% style="color:blue" %)**AT Command: AT+DR** 714 - 715 715 (% border="1" style="background-color:#ffffcc; color:green; width:466.222px" %) 716 716 |=(% colspan="3" style="width: 463px;" %)AT+DR 717 717 |(% style="width:156px" %)**Command Example**|(% style="width:167px" %)**Function**|(% style="width:140px" %)**Response** ... ... @@ -722,21 +722,24 @@ 722 722 723 723 ))) 724 724 725 -(% style="color:blue" %)**Downlink Command: 0x2200aaFF** 720 +{{info}} 721 +**Downlink Command: 0x2200aaFF** 722 +{{/info}} 726 726 724 + 727 727 If the downlink payload=220001FF, it means setting the data rate to 1, while type code is 22 00 aa FF. 728 728 729 -* **Example 1**: Downlink Payload: **220001FF** 730 -* **Example 2**: Downlink Payload: **220000FF** 727 +* **Example 1**: Downlink Payload: **220001FF** ~/~/ Set AT+DR=1. 728 +* **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+DR=0. 731 731 732 732 == 7.5 Frame Counter Downlink == 733 733 734 - 735 735 Feature: Get or Set the Frame Counter Downlink. 736 736 734 +{{info}} 735 +**AT Command:AT+FCD** 736 +{{/info}} 737 737 738 -(% style="color:blue" %)**AT Command: AT+FCD** 739 - 740 740 (% border="1" style="background-color:#ffffcc; color:green; width:693.222px" %) 741 741 |=(% colspan="3" style="width: 690px;" %)AT+FCD 742 742 |(% style="width:162px" %)**Command Example**|(% style="width:258px" %)**Function**|(% style="width:269px" %)**Response** ... ... @@ -745,6 +745,8 @@ 745 745 ))) 746 746 |(% style="width:162px" %)AT+FCD=10|(% style="width:258px" %)Set the Frame Counter Downlink.|(% style="width:269px" %)(System will write new value to FCD)((( 747 747 OK 746 + 747 + 748 748 ))) 749 749 750 750 == 7.6 Frame Counter Uplink == ... ... @@ -751,9 +751,10 @@ 751 751 752 752 Feature: Get or Set the Frame Counter Uplink. 753 753 754 +{{info}} 755 +**AT Command:AT+FCU** 756 +{{/info}} 754 754 755 -(% style="color:blue" %)**AT Command: AT+FCU** 756 - 757 757 (% border="1" style="background-color:#ffffcc; color:green; width:534.222px" %) 758 758 |=(% colspan="3" style="width: 531px;" %)AT+FCU 759 759 |(% style="width:177px" %)**Command Example**|(% style="width:239px" %)**Function**|(% style="width:113px" %)**Response** ... ... @@ -766,12 +766,12 @@ 766 766 767 767 == 7.7 Join Accept Delay1 == 768 768 769 - 770 770 Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 1 in ms. 771 771 772 +{{info}} 773 +**AT Command:AT+JN1DL** 774 +{{/info}} 772 772 773 -(% style="color:blue" %)**AT Command: AT+JN1DL** 774 - 775 775 (% border="1" style="background-color:#ffffcc; color:green; width:537.222px" %) 776 776 |=(% colspan="3" style="width: 534px;" %)AT+JN1DL 777 777 |(% style="width:164px" %)**Command Example**|(% style="width:229px" %)**Function**|(% style="width:140px" %)**Response** ... ... @@ -784,12 +784,12 @@ 784 784 785 785 == 7.8 Join Accept Delay2 == 786 786 787 - 788 788 Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 2 in ms. 789 789 790 +{{info}} 791 +**AT Command:AT+JN2DL** 792 +{{/info}} 790 790 791 -(% style="color:blue" %)**AT Command: AT+JN2DL** 792 - 793 793 (% border="1" style="background-color:#ffffcc; color:green; width:538.222px" %) 794 794 |=(% colspan="3" style="width: 535px;" %)AT+JN2DL 795 795 |(% style="width:160px" %)**Command Example**|(% style="width:228px" %)**Function**|(% style="width:146px" %)**Response** ... ... @@ -802,14 +802,12 @@ 802 802 803 803 == 7.9 Public Network Mode == 804 804 806 +Feature: Get or Set the public network mode. (0: off, 1: on) 805 805 806 -Feature: Get or Set the public network mode. (0: off, 1: on). A Public LoRaWAN network use 0x34 as syncword. Default Settings; PNM=1 808 +{{info}} 809 +**AT Command:AT+PNM** 810 +{{/info}} 807 807 808 -(% style="color:red" %)**Notice: If user build their own LoRaWAN server but still use syncword=0x34, this is still considered a public LoRaWAN network.** 809 - 810 - 811 -(% style="color:blue" %)**AT Command: AT+PNM** 812 - 813 813 (% border="1" style="background-color:#ffffcc; color:green; width:667.222px" %) 814 814 |=(% colspan="3" style="width: 664px;" %)AT+PNM 815 815 |(% style="width:166px" %)**Command Example**|(% style="width:225px" %)**Function**|(% style="width:272px" %)**Response** ... ... @@ -816,25 +816,20 @@ 816 816 |(% style="width:166px" %)AT+PNM=?|(% style="width:225px" %)Get the public network mode.|(% style="width:272px" %)1((( 817 817 OK 818 818 ))) 819 -|(% style="width:166px" %)AT+PNM=1|(% style="width:225px" %)((( 820 -Set the public network mode. 821 - 822 -Set syncword=0x34 823 -)))|(% style="width:272px" %)(System will write new value to PNM)((( 818 +|(% style="width:166px" %)AT+PNM=1|(% style="width:225px" %)Set the public network mode.|(% style="width:272px" %)(System will write new value to PNM)((( 824 824 OK 825 825 826 826 827 827 ))) 828 -|(% style="width:166px" %)AT+PNM=0|(% style="width:225px" %)Set to use private network autoset syncword=0x12|(% style="width:272px" %) 829 829 830 830 == 7.10 Receive Delay1 == 831 831 832 - 833 833 Feature: Get or Set the delay between the end of the Tx and the Rx Window 1 in ms 834 834 828 +{{info}} 829 +**AT Command:AT+RX1DL** 830 +{{/info}} 835 835 836 -(% style="color:blue" %)**AT Command: AT+RX1DL** 837 - 838 838 (% border="1" style="background-color:#ffffcc; color:green; width:408.222px" %) 839 839 |=(% colspan="3" style="width: 405px;" %)AT+RX1DL 840 840 |(% style="width:155px" %)**Command Example**|(% style="width:128px" %)**Function**|(% style="width:122px" %)**Response** ... ... @@ -847,12 +847,12 @@ 847 847 848 848 == 7.11 Receive Delay2 == 849 849 850 - 851 851 Feature: Get or Set the delay between the end of the Tx and the Rx Window 2 in ms 852 852 846 +{{info}} 847 +**AT Command:AT+RX2DL** 848 +{{/info}} 853 853 854 -(% style="color:blue" %)**AT Command: AT+RX2DL** 855 - 856 856 (% border="1" style="background-color:#ffffcc; color:green; width:481.222px" %) 857 857 |=(% colspan="3" style="width: 478px;" %)AT+RX2DL 858 858 |(% style="width:175px" %)**Command Example**|(% style="width:152px" %)**Function**|(% style="width:150px" %)**Response** ... ... @@ -865,12 +865,12 @@ 865 865 866 866 == 7.12 Rx2 Window Data Rate == 867 867 868 - 869 869 Feature: Get or Set the Rx2 window data rate (0-7 corresponding to DR_X) 870 870 864 +{{info}} 865 +**AT Command:AT+RX2DR** 866 +{{/info}} 871 871 872 -(% style="color:blue" %)**AT Command: AT+RX2DR** 873 - 874 874 (% border="1" style="background-color:#ffffcc; color:green; width:525.222px" %) 875 875 |=(% colspan="3" style="width: 522px;" %)AT+RX2DR 876 876 |(% style="width:160px" %)**Command Example**|(% style="width:232px" %)**Function**|(% style="width:130px" %)**Response** ... ... @@ -883,12 +883,12 @@ 883 883 884 884 == 7.13 Rx2 Window Frequency == 885 885 886 - 887 887 Feature: Get or Set the Rx2 window frequency 888 888 882 +{{info}} 883 +**AT Command:AT+RX2FQ** 884 +{{/info}} 889 889 890 -(% style="color:blue" %)**AT Command: AT+RX2FQ** 891 - 892 892 (% border="1" style="background-color:#ffffcc; color:green; width:587.222px" %) 893 893 |=(% colspan="3" style="width: 584px;" %)AT+RX2FQ 894 894 |(% style="width:183px" %)**Command Example**|(% style="width:240px" %)**Function**|(% style="width:160px" %)**Response** ... ... @@ -901,14 +901,12 @@ 901 901 902 902 == 7.14 Transmit Power == 903 903 904 - 905 905 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. ) 906 906 907 -(% 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** 900 +{{info}} 901 +**AT Command:AT+TXP** 902 +{{/info}} 908 908 909 - 910 -(% style="color:blue" %)**AT Command: AT+TXP** 911 - 912 912 (% border="1" style="background-color:#ffffcc; color:green; width:465.222px" %) 913 913 |=(% colspan="3" style="width: 462px;" %)AT+TXP 914 914 |(% style="width:161px" %)**Command Example**|(% style="width:189px" %)**Function**|(% style="width:112px" %)**Response** ... ... @@ -923,17 +923,17 @@ 923 923 924 924 If the downlink payload=22000100, it means setting the TXP to 0. 925 925 926 -* **Example 1**: Downlink Payload: **22000102** 927 -* **Example 2**: Downlink Payload: **220000FF** 918 +* **Example 1**: Downlink Payload: **22000102** ~/~/ Set AT+TXP=2. 919 +* **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+TXP=0. 928 928 929 929 == 7.15 RSSI of the Last Received Packet == 930 930 931 - 932 932 Feature: Get or Set the Rx2 window frequency 933 933 925 +{{info}} 926 +**AT Command:AT+RSSI** 927 +{{/info}} 934 934 935 -(% style="color:blue" %)**AT Command:AT+RSSI** 936 - 937 937 (% border="1" style="background-color:#ffffcc; color:green; width:557.222px" %) 938 938 |=(% colspan="3" style="width: 554px;" %)AT+RSSI 939 939 |(% style="width:164px" %)**Command Example**|(% style="width:289px" %)**Function**|(% style="width:100px" %)**Response** ... ... @@ -943,12 +943,12 @@ 943 943 944 944 == 7.16 SNR of the Last Received Packet == 945 945 946 - 947 947 Feature: Get the SNR of the last received packet 948 948 940 +{{info}} 941 +**AT Command:AT+SNR** 942 +{{/info}} 949 949 950 -(% style="color:blue" %)**AT Command: AT+SNR** 951 - 952 952 (% border="1" style="background-color:#ffffcc; color:green; width:571.222px" %) 953 953 |=(% colspan="3" style="width: 568px;" %)AT+SNR 954 954 |(% style="width:164px" %)**Command Example**|(% style="width:290px" %)**Function**|(% style="width:113px" %)**Response** ... ... @@ -958,12 +958,12 @@ 958 958 959 959 == 7.17 Application Port == 960 960 961 - 962 962 Feature: Get or set the application port. 963 963 955 +{{info}} 956 +**AT Command: AT+PORT** 957 +{{/info}} 964 964 965 -(% style="color:blue" %)**AT Command: AT+PORT** 966 - 967 967 (% border="1" style="background-color:#ffffcc; color:green; width:500.222px" %) 968 968 |=(% colspan="3" style="width: 497px;" %)AT+PORT 969 969 |(% style="width:157px" %)**Command Example**|(% style="width:204px" %)**Function**|(% style="width:135px" %)**Response** ... ... @@ -972,23 +972,25 @@ 972 972 ))) 973 973 |(% style="width:157px" %)AT+PORT=21|(% style="width:204px" %)Set the application port|(% style="width:135px" %)OK 974 974 975 -(% style="color:blue" %)**Downlink Command: 0x23** 967 +{{info}} 968 +**Downlink Command: 0x23** 969 +{{/info}} 976 976 977 977 Format: Command Code (0x23) followed by 1 bytes port value. 978 978 979 979 If the downlink payload=2301, it means set the application port to 1, while type code is 23. 980 980 981 -* **Example 1**: Downlink Payload: **2301** 982 -* **Example 2**: Downlink Payload:** 2305** 975 +* **Example 1**: Downlink Payload: **2301** ~/~/ set the application port to 1 976 +* **Example 2**: Downlink Payload:** 2305** ~/~/ set the application port to 5 983 983 984 984 == 7.18 Single Channel Mode == 985 985 986 - 987 987 Feature:Get or Set Frequency (Unit: Hz) for Single Channel Mode. 988 988 982 +{{info}} 983 +**AT Command: AT+CHS** 984 +{{/info}} 989 989 990 -(% style="color:blue" %)**AT Command: AT+CHS** 991 - 992 992 (% border="1" style="background-color:#ffffcc; color:green; width:603.222px" %) 993 993 |=(% colspan="3" style="width: 600px;" %)AT+CHS 994 994 |(% style="width:182px" %)**Command Example**|(% style="width:295px" %)**Function**|(% style="width:122px" %)**Response** ... ... @@ -999,12 +999,12 @@ 999 999 1000 1000 == 7.19 Eight Channel Mode == 1001 1001 1002 - 1003 1003 Feature: Get or Set eight channels mode,Only for US915,AU915,CN470. 1004 1004 998 +{{info}} 999 +**AT Command: AT+CHE** 1000 +{{/info}} 1005 1005 1006 -(% style="color:blue" %)**AT Command: AT+CHE** 1007 - 1008 1008 (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 1009 1009 |=(% colspan="3" style="width: 707px;" %)AT+CHE 1010 1010 |(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response** ... ... @@ -1015,23 +1015,25 @@ 1015 1015 ))) 1016 1016 |(% style="width:160px" %)AT+CHE=1|(% style="width:198px" %)Set eight channels mode|(% style="width:349px" %)OK 1017 1017 1018 -(% style="color:blue" %)**Downlink Command: 0x24 (LHT65,LHT65N Downlink Command:0x07)** 1012 +{{info}} 1013 +**Downlink Command: 0x24** 1014 +{{/info}} 1019 1019 1020 1020 Format: Command Code (0x24) followed by 1 bytes channel value. 1021 1021 1022 1022 If the downlink payload=2401, it means set channel mode to 1, while type code is 24. 1023 1023 1024 -* **Example 1**: Downlink Payload: 2401 1025 -* **Example 2**: Downlink Payload: 2405 1020 +* **Example 1**: Downlink Payload: 2401 ~/~/ set channel mode to 1 1021 +* **Example 2**: Downlink Payload: 2405 ~/~/ set channel mode to 5 1026 1026 1027 1027 == 7.20 Get or Set RXwindows1 timeout == 1028 1028 1025 +Feature:Get or Set the number of symbols to detect and timeout from RXwindow1(0 to 255). 1029 1029 1030 -Feature: Get or Set the number of symbols to detect and timeout from RXwindow1(0 to 255). 1027 +{{info}} 1028 +**AT Command: AT+RX1WTO** 1029 +{{/info}} 1031 1031 1032 - 1033 -(% style="color:blue" %)**AT Command: AT+RX1WTO** 1034 - 1035 1035 (% border="1" style="background-color:#ffffcc; color:green; width:460.222px" %) 1036 1036 |=(% colspan="3" style="width: 457px;" %)AT+ RX1WTO 1037 1037 |(% style="width:163px" %)**Command Example**|(% style="width:201px" %)**Function**|(% style="width:93px" %)**Response** ... ... @@ -1041,17 +1041,11 @@ 1041 1041 |(% style="width:163px" %)AT+RX1WTO=60|(% style="width:201px" %)Set RXwindows1 timeout|(% style="width:93px" %)OK 1042 1042 1043 1043 ((( 1044 - 1045 - 1046 - 1047 -(% 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. 1048 - 1049 - 1040 +**AT+RX1TWO** 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. 1050 1050 ))) 1051 1051 1052 1052 [[image:image-20220526162535-1.png]] 1053 1053 1054 - 1055 1055 ((( 1056 1056 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. 1057 1057 ... ... @@ -1060,12 +1060,12 @@ 1060 1060 1061 1061 == 7.21 Get or Set RXwindows2 timeout == 1062 1062 1053 +Feature:Get or Set the number of symbols to detect and timeout from RXwindow2(0 to 255). 1063 1063 1064 -Feature: Get or Set the number of symbols to detect and timeout from RXwindow2(0 to 255). 1055 +{{info}} 1056 +**AT Command: AT+RX2WTO** 1057 +{{/info}} 1065 1065 1066 - 1067 -(% style="color:blue" %)**AT Command: AT+RX2WTO** 1068 - 1069 1069 (% border="1" style="background-color:#ffffcc; color:green; width:497.222px" %) 1070 1070 |=(% colspan="3" style="width: 494px;" %)AT+ RX2WTO 1071 1071 |(% style="width:190px" %)**Command Example**|(% style="width:199px" %)**Function**|(% style="width:104px" %)**Response** ... ... @@ -1076,12 +1076,12 @@ 1076 1076 1077 1077 == 7.22 Setting up uplinkdwelltime (as923, au915) == 1078 1078 1079 - 1080 1080 Feature: Get or Set uplinkdwelltime 1081 1081 1071 +{{info}} 1072 +**AT Command: AT+DWELLT** 1073 +{{/info}} 1082 1082 1083 -(% style="color:blue" %)**AT Command: AT+DWELLT** 1084 - 1085 1085 (% border="1" style="background-color:#ffffcc; color:green; width:497.222px" %) 1086 1086 |=(% colspan="3" style="width: 494px;" %)AT+DWELLT 1087 1087 |(% style="width:183px" %)**Command Example**|(% style="width:179px" %)**Function**|(% style="width:131px" %)**Response** ... ... @@ -1090,23 +1090,23 @@ 1090 1090 ))) 1091 1091 |(% style="width:183px" %)AT+DWELLT=0|(% style="width:179px" %)Set uplinkdwelltime|(% style="width:131px" %)OK 1092 1092 1093 -(% style="color:blue" %)**Downlink Command: 0x25** 1083 +{{info}} 1084 +**Downlink Command: 0x25** 1085 +{{/info}} 1094 1094 1095 1095 Format: Command Code (0x25) followed by 1 bytes state value. 1096 1096 1097 1097 If the downlink payload=2501, it means set uplinkdwelltime to 1, while type code is 25. 1098 1098 1099 -* **Example 1**: Downlink Payload: **2501** 1100 -* **Example 2**: Downlink Payload: **2500** 1091 +* **Example 1**: Downlink Payload: **2501** ~/~/ set uplinkdwelltime to 1 1092 +* **Example 2**: Downlink Payload: **2500** ~/~/ set uplinkdwelltime to 0 1101 1101 1102 1102 == 7.23 Set Packet Receiving Response Level == 1103 1103 1104 - 1105 1105 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. 1106 1106 1098 +RPL value: 1107 1107 1108 -**RPL value:** 1109 - 1110 1110 * **AT+RPL=0:** Device won't immediately reply any downlink commands from platform. 1111 1111 * **AT+RPL=1:** Device will immediately reply message to Unconfirmed Data Down. Payload is 0x00. 1112 1112 * **AT+RPL=2:** Device will immediately reply message to Confirmed Data Down. Payload is 0x00 and requied response header for this command. ... ... @@ -1113,13 +1113,15 @@ 1113 1113 * **AT+RPL=3:** Device will immediately reply message to MAC Command. Payload is 0x00 and requied response header for this command. 1114 1114 * **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. 1115 1115 1116 - **Case Analyes:**1106 +Case Analyes: 1117 1117 1118 1118 * For Class A devices, AT+RPL=0 is ok. that is defaut settings in software. 1119 1119 * For Class C devices used in ChirpStack, need to set AT+RPL=4 because Chirpstack require immedietely reply message to MAC Command. 1120 1120 * 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. 1121 1121 1122 -(% style="color:blue" %)**AT Command: AT+RPL** 1112 +{{info}} 1113 +**AT Command: AT+RPL** 1114 +{{/info}} 1123 1123 1124 1124 (% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %) 1125 1125 |=(% colspan="3" style="width: 533px;" %)AT+RPL ... ... @@ -1129,158 +1129,32 @@ 1129 1129 ))) 1130 1130 |(% style="width:160px" %)AT+RPL=0|(% style="width:263px" %)Set packet receiving response level|(% style="width:109px" %)OK 1131 1131 1132 -(% style="color:blue" %)**Downlink Command: 0x21** 1124 +{{info}} 1125 +**Downlink Command: 0x21** 1126 +{{/info}} 1133 1133 1134 1134 Format: Command Code (0x21) followed by 1 bytes level value. 1135 1135 1136 1136 If the downlink payload=2101, it means set packet receiving response level to 1, while type code is 21. 1137 1137 1138 -* **Example 1**: Downlink Payload: **2101** 1139 -* **Example 2**: Downlink Payload: **2102** 1132 +* **Example 1**: Downlink Payload: **2101** ~/~/ set packet receiving response level to 1 1133 +* **Example 2**: Downlink Payload: **2102** ~/~/ set packet receiving response level to 2 1140 1140 1141 -== 7.24 Controls NBTrans in unconfirmed uplink mode(LWS007 NBTrans:Set retransmission packets) == 1142 - 1143 - 1144 -(% style="color:blue" %)**AT Command: AT+SETMAXNBTRANS ** 1145 - 1146 -(% border="1" style="background-color:#ffffcc; color:green; width:589px" %) 1147 -|=(% colspan="3" style="width: 586px;" %)AT+**SETMAXNBTRANS** 1148 -|(% style="width:227px" %)**Command Example**|(% style="width:300px" %)**Function**|(% style="width:87px" %)**Response** 1149 -|(% style="width:227px" %)**AT+SETMAXNBTRANS=1,0**|(% style="width:300px" %)Value1: set the maximum NBTrans.|(% style="width:87px" %)1((( 1150 -OK 1151 -))) 1152 -|(% style="width:227px" %)**AT+SETMAXNBTRANS=?,1**|(% style="width:300px" %)((( 1153 -value2: 0: uplink fcnt doesn't change for each NBTrans; 1154 - 1155 -1: uplink fcnt increase by 1 for each NBTrans. 1156 -)))|(% style="width:87px" %)((( 1157 -1 1158 - 1159 -OK 1160 -))) 1161 - 1162 -(% style="color:blue" %)**Downlink Command: 0x33** 1163 - 1164 -Format: Command Code (0x33) followed by 2 bytes mode value. 1165 - 1166 -If the downlink payload=330100, it means set end node to use confirm mode, while type code is 33. 1167 - 1168 -* Example 1: Downlink Payload: 330100 ~/~/ Set AT+SETMAXNBTRANS=1,0 1169 -* Example 2: Downlink Payload: 330201 ~/~/ Set AT+SETMAXNBTRANS=2,1 1170 - 1171 -== 7.25 Device offline rejoining (LWS007) == 1172 - 1173 - 1174 -(% style="color:blue" %)**AT Command: AT+DDETECT** 1175 - 1176 -AT+DDETECT=<Flag>,<ACK_Timout_1>,<ACK_Timout_2> (Default Value: AT+DDETECT=1,1440,2880) 1177 - 1178 -* ACK_Timout_1: Unit: min 1179 -* ACK_Timout_2: Unit: min 1180 - 1181 -(% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 1182 -|=(% colspan="3" style="width: 707px;" %)AT+**DDETECT** 1183 -|(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response** 1184 -|(% style="width:160px" %)((( 1185 -AT+DDETECT=1,1440,2880 1186 - 1187 -value1 1188 -)))|(% style="width:198px" %)Enable online detect|(% style="width:349px" %)((( 1189 -1 1190 - 1191 -OK 1192 -))) 1193 -|(% style="width:160px" %)((( 1194 -AT+DDETECT=1,?,2880 1195 - 1196 -value2 1197 -)))|(% style="width:198px" %)Online detection packet sending time|(% style="width:349px" %)((( 1198 - 1199 - 1200 -OK 1201 -))) 1202 -|(% style="width:160px" %)((( 1203 -AT+DDETECT=1,1440,? 1204 - 1205 -value3 1206 -)))|(% style="width:198px" %)Process rejoin|(% style="width:349px" %)((( 1207 - 1208 - 1209 -OK 1210 -))) 1211 - 1212 -(% style="color:blue" %)**Downlink Command: 0x32** 1213 - 1214 -Format: Command Code (0x32) followed by 2 bytes mode value. 1215 - 1216 -If the downlink payload=320105A00B40, it means set end node to use confirm mode, while type code is 32. 1217 - 1218 -* **Example 1:** Downlink Payload: 320105A00B40 ~/~/ Set AT+DDETECT=1,1440,2880 1219 -** 0x01 : Flag 1220 -** 0x05A0: ACK_Timout_1 : 1440minutes (24 hours) 1221 -** 0x0B40: ACK_Timout_2 : 2880minutes (48 hours) 1222 -** **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. 1223 - 1224 -== 7.26 Request the server to send an ACK == 1225 - 1226 - 1227 -(% style="color:blue" %)**AT Command: AT+PNACKMD** 1228 - 1229 -(% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %) 1230 -|=(% colspan="3" style="width: 533px;" %)**AT+PNACKMD** 1231 -|(% style="width:160px" %)**Command Example**|(% style="width:263px" %)**Function**|(% style="width:109px" %)**Response** 1232 -|(% style="width:160px" %)**AT+PNACKMD=1**|(% style="width:263px" %)If the node uploads the ACK as confirm, it will request the server to send an ACK. If the server ack is not received, the node will upload the packets that have not received the ACK the next time it receives the ACK|(% style="width:109px" %)1((( 1233 -OK 1234 -))) 1235 -|(% style="width:160px" %)**AT+PNACKMD=0**|(% style="width:263px" %)off request the server to send an ACK|(% style="width:109px" %)((( 1236 -0 1237 - 1238 -OK 1239 -))) 1240 - 1241 -== 7.27 Adjust network rejoining interval == 1242 - 1243 - 1244 -(% style="color:blue" %)**AT Command: AT+RJTDC** 1245 - 1246 -(% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %) 1247 -|=(% colspan="3" style="width: 724px;" %)AT+RJTDC 1248 -|(% style="width:165px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:329px" %)**Response** 1249 -|(% style="width:165px" %)AT+RJTDC=?|(% style="width:227px" %)Show the ReJoin data transmission interval in min|(% style="width:329px" %)30((( 1250 -OK 1251 - 1252 -the interval is 30 min 1253 -))) 1254 -|(% style="width:165px" %)AT+RJTDC=60|(% style="width:227px" %)Set the ReJoin data transmission interval in min|(% style="width:329px" %)OK((( 1255 -Set the ReJoin data transmission interval to 60 min 1256 -))) 1257 - 1258 -(% style="color:blue" %)**Downlink Command: 0x26** 1259 - 1260 -Format: Command Code (0x26) followed by 2 bytes mode value. 1261 - 1262 -If the downlink payload=26000A, it means set end node to use confirm mode, while type code is 26. 1263 - 1264 -* **Example 1:** Downlink Payload: 26000A ~/~/ Set AT+RJTDC=10 1265 -* **Example 2: **Downlink Payload: 260002 ~/~/ Set AT+RJTDC=2 1266 - 1267 1267 = 8. AT Commands Combination = 1268 1268 1269 1269 == 8.1 Set a fix RX2DR for downlink window == 1270 1270 1139 +* **AT+ADR=0 **~-~-> Disable ADR first 1140 +* **AT+RX2DR=xxxx** ~-~-> Set xxxx to your wanted DataRate 1271 1271 1272 -* (% style="color:blue" %)**AT+ADR=0 **(%%) **~-~->** Disable ADR first 1273 -* (% style="color:blue" %)**AT+RX2DR=xxxx** (%%) **~-~->** Set xxxx to your wanted DataRate 1274 - 1275 1275 == 8.2 Use Downlink Command to set a fix uplink DR == 1276 1276 1144 +{{info}} 1145 +**Downlink Command: 0x22000500** 1146 +{{/info}} 1277 1277 1278 - (% style="color:blue"%)**Downlink Command:0x22000500**1148 +Same as: 1279 1279 1280 -**Same as:** 1281 - 1282 -* AT+ADR=0 [[Reference>>||anchor="H7.1AdaptiveDataRate"]] 1283 -* AT+DR=5 [[Reference>>||anchor="H7.4DataRate"]] 1284 -* AT+TXP=0 [[Reference>>||anchor="H7.14TransmitPower"]] 1285 - 1286 - 1150 +* AT+ADR=0 [[Reference>>||anchor="H7.1AdaptiveDataRate"]] 1151 +* AT+DR=5 [[Reference>>||anchor="H7.4DataRate"]] 1152 +* AT+TXP=0 [[Reference>>||anchor="H7.14TransmitPower"]]