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,26 +9,25 @@ 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 - 32 32 = 3. Support End Node and firmware version = 33 33 34 34 ... ... @@ -103,12 +103,10 @@ 103 103 ))) 104 104 ))) 105 105 105 +(% style="display:none" %) (%%) 106 106 107 - 108 - 109 109 = 4. System Management Commands = 110 110 111 - 112 112 == 4.1 Change Uplink Interval == 113 113 114 114 ... ... @@ -138,15 +138,14 @@ 138 138 ))) 139 139 140 140 ((( 141 -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. 142 142 ))) 143 143 144 144 * **Example 1**: Downlink Payload:** 0100001E** ~/~/ Set Transmit Interval (TDC) = 30 seconds 145 145 * **Example 2**: Downlink Payload:** 0100003C** ~/~/ Set Transmit Interval (TDC) = 60 seconds 146 146 144 +(% style="display:none" %) (%%) 147 147 148 - 149 - 150 150 == 4.2 Reboot End Node == 151 151 152 152 ... ... @@ -155,10 +155,10 @@ 155 155 156 156 (% style="color:blue" %)**AT Command: ATZ** 157 157 158 -(% border="1" style="background-color:#ffffcc; color:green; width: 727.222px" %)159 -|=(% colspan="3" %)ATZ: Trig a reset of the MCU 160 -|**Command Example**|**Function**|**Response** 161 -|ATZ|Reset MCU|((( 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" %)((( 162 162 Device reset and show booting info 163 163 164 164 LSN50 Device/LoRa ST Module ... ... @@ -172,7 +172,6 @@ 172 172 <followed by the Tx and Rx information> 173 173 ))) 174 174 175 - 176 176 (% style="color:blue" %)**Downlink Command: 0x04** 177 177 178 178 ((( ... ... @@ -180,11 +180,10 @@ 180 180 ))) 181 181 182 182 ((( 183 -If the downlink payload=**04FF**, the end node will reboot. 184 - 185 - 178 +If the downlink payload=**04FF**, the end node will reboot. 186 186 ))) 187 187 181 + 188 188 == 4.3 Reset to factory Default == 189 189 190 190 ... ... @@ -193,10 +193,10 @@ 193 193 194 194 (% style="color:blue" %)**AT Command: AT+FDR** 195 195 196 -(% border="1" style="background-color:#ffffcc; color:green; width:8 31.222px" %)197 -|=(% colspan="3" style="width: 8 28px;" %)Reset to factory default198 -|(% style="width:1 81px" %)**Command Example**|(% style="width:181px" %)**Function**|(% style="width:465px" %)**Response**199 -|(% style="width:1 81px" %)AT+FDR|(% style="width:181px" %)Reset to factory default|(% style="width:465px" %)(((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" %)((( 200 200 Device reset to factory default parameters and show booting info 201 201 202 202 LSN50 Device/LoRa ST Module ... ... @@ -210,7 +210,6 @@ 210 210 Please set the parameters or reset Device to apply change 211 211 ))) 212 212 213 - 214 214 (% style="color:blue" %)**Downlink Command: 0x04** 215 215 216 216 ((( ... ... @@ -230,16 +230,15 @@ 230 230 231 231 (% style="color:blue" %)**AT Command: AT+VER** 232 232 233 -(% border="1" style="background-color:#ffffcc; color:green; width:5 86px" %)234 -|=(% colspan="3" style="width: 5 83px;" %)AT+VER: Image Version and Frequency Band235 -|(% style="width:17 0px" %)**Command Example**|(% style="width:300px" %)**Function**|(% style="width:113px" %)**Response**236 -|(% style="width:17 0px" %)AT+VER=?|(% style="width:300px" %)Show Image version and Frequency Band|(% style="width:113px" %)(((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 - 243 243 (% style="color:blue" %)**Downlink Command: 0x26 (Valid in 006 stack)** 244 244 245 245 ((( ... ... @@ -253,7 +253,6 @@ 253 253 ((( 254 254 255 255 256 - 257 257 **xx: Software Type:** 258 258 ))) 259 259 ... ... @@ -300,23 +300,17 @@ 300 300 |(% style="width:160px" %)**Command Example**|(% style="width:154px" %)**Function**|(% style="width:280px" %)**Response** 301 301 |(% style="width:160px" %)AT+CFG|(% style="width:154px" %)Show all configures|(% style="width:280px" %)((( 302 302 AT+DEUI = XX XX XX XX XX XX XX XX 303 - 304 304 AT+DADDR=XXXXXXXX 305 - 306 306 ………. 307 - 308 308 AT+RX2WTO=X 309 - 310 310 AT+CHS=868100000 311 - 312 312 OK 313 313 ))) 314 314 301 +(% style="display:none" %) (%%) 315 315 316 - 317 317 = 5. Keys, IDs and EUIs management = 318 318 319 - 320 320 == 5.1 Application EUI == 321 321 322 322 ... ... @@ -333,8 +333,8 @@ 333 333 ))) 334 334 |(% style="width:305px" %)AT+APPEUI=00 b3 d5 7e f0 00 4d 34|(% style="width:186px" %)Set the Application EUI|(% style="width:191px" %)OK 335 335 321 +(% style="display:none" %) (%%) 336 336 337 - 338 338 == 5.2 Application Key == 339 339 340 340 ... ... @@ -351,8 +351,8 @@ 351 351 ))) 352 352 |(% 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 353 353 339 +(% style="display:none" %) (%%) 354 354 355 - 356 356 == 5.3 Application Session Key == 357 357 358 358 ... ... @@ -371,8 +371,8 @@ 371 371 OK 372 372 ))) 373 373 359 +(% style="display:none" %) (%%) 374 374 375 - 376 376 == 5.4 Device Address == 377 377 378 378 ... ... @@ -391,8 +391,8 @@ 391 391 ))) 392 392 |(% style="width:192px" %)AT+DADDR=A8 40 41 FF|(% style="width:241px" %)Set the Application Session Key.|(% style="width:359px" %)OK 393 393 379 +(% style="display:none" %) (%%) 394 394 395 - 396 396 == 5.5 Device EUI == 397 397 398 398 ... ... @@ -411,8 +411,8 @@ 411 411 OK 412 412 ))) 413 413 399 +(% style="display:none" %) (%%) 414 414 415 - 416 416 == 5.6 Network ID == 417 417 418 418 ... ... @@ -429,8 +429,8 @@ 429 429 ))) 430 430 |(% style="width:191px" %)AT+NWKID=A8 40 41 FF|(% style="width:153px" %)Set the Network ID.|(% style="width:101px" %)OK 431 431 417 +(% style="display:none" %) (%%) 432 432 433 - 434 434 == 5.7 Network Session Key == 435 435 436 436 ... ... @@ -447,14 +447,12 @@ 447 447 ))) 448 448 |(% 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 449 449 435 +(% style="display:none" %) (%%) 450 450 451 - 452 452 = 6. Joining and sending date on LoRaWAN network = 453 453 454 - 455 455 == 6.1 Confirm Mode == 456 456 457 - 458 458 === 6.1.1 AT+CFM command before DR-LWS007 software stack === 459 459 460 460 ... ... @@ -472,7 +472,6 @@ 472 472 |(% style="width:155px" %)AT+CFM=1|(% style="width:205px" %)Set the confirmation mode|(% style="width:346px" %)OK 473 473 |(% style="width:155px" %)AT+CFM=2|(% style="width:205px" %)Set the confirmation mode|(% style="width:346px" %)While Error in format, return AT_PARAM_ERROR 474 474 475 - 476 476 (% style="color:blue" %)**Downlink Command: 0x05** 477 477 478 478 Format: Command Code (0x05) followed by 2 bytes mode value. ... ... @@ -482,9 +482,8 @@ 482 482 * **Example 1:** Downlink Payload: 0501 ~/~/ Set AT+CFM=1 483 483 * **Example 2:** Downlink Payload: 0500 ~/~/ Set AT+CFM=0 484 484 467 +(% style="display:none" %) (%%) 485 485 486 - 487 - 488 488 === 6.1.2 AT+CFM command since DR-LWS007 software stack === 489 489 490 490 ... ... @@ -521,7 +521,6 @@ 521 521 OK 522 522 ))) 523 523 524 - 525 525 (% style="color:blue" %)**Downlink Command: 0x05** 526 526 527 527 Format: Command Code (0x05) followed by 2 bytes mode value. ... ... @@ -531,9 +531,8 @@ 531 531 * **Example 1:** Downlink Payload: 05010101 ~/~/ Set AT+CFM=1,1,1 532 532 * **Example 2:** Downlink Payload: 05000700 ~/~/ Set AT+CFM=0,7,0 533 533 514 +(% style="display:none" %) (%%) 534 534 535 - 536 - 537 537 == 6.2 Confirm Status == 538 538 539 539 ... ... @@ -542,15 +542,15 @@ 542 542 543 543 (% style="color:blue" %)**AT Command: AT+CFS** 544 544 545 -(% border="1" style="background-color:#ffffcc; color:green; width: 534.222px" %)546 -|=(% colspan="3" style="width: 531px;" %)AT+CFS547 -|(% style="width:156px" %)**Command Example**|(% style="width:193px" %)**Function**|(% style="width:17 8px" %)**Response**548 -|(% style="width:156px" %)AT+CFS=?|(% style="width:193px" %)Get confirmation status|(% style="width:17 8px" %)0(((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((( 549 549 OK 550 550 ))) 551 551 531 +(% style="display:none" %) (%%) 552 552 553 - 554 554 == 6.3 Join LoRa® Network == 555 555 556 556 ... ... @@ -564,12 +564,11 @@ 564 564 |(% style="width:163px" %)**Command Example**|(% style="width:147px" %)**Function**|(% style="width:334px" %)**Response** 565 565 |(% style="width:163px" %)AT+JOIN ?|(% style="width:147px" %)Get imformation.|(% style="width:334px" %)AT+JOIN: Join network((( 566 566 OK 567 - 568 568 While Error in format, return AT_BUSY_ERROR 569 569 ))) 570 570 549 +(% style="display:none" %) (%%) 571 571 572 - 573 573 == 6.4 LoRa® Network Join Mode == 574 574 575 575 ... ... @@ -587,7 +587,6 @@ 587 587 |(% style="width:162px" %)AT+NJM=0|(% style="width:227px" %)Set the Network Join Mode|(% style="width:361px" %)OK 588 588 |(% 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 589 589 590 - 591 591 (% style="color:blue" %)**Downlink Command: 0x20** 592 592 593 593 Format: Command Code (0x20) followed by 1 bytes mode value. ... ... @@ -594,12 +594,11 @@ 594 594 595 595 If the downlink payload=2000, it means set the Network Join Mode, while type code is 20. 596 596 597 -* **Example 1: **Downlink Payload: **2000 574 +* **Example 1: **Downlink Payload: **2000 ** ~/~/ Set AT+NJM=0 598 598 * **Example 2:** Downlink Payload: **2001** ~/~/ Set AT+NJM=1 599 599 577 +(% style="display:none" %) (%%) 600 600 601 - 602 - 603 603 == 6.5 LoRa® Network Join Status == 604 604 605 605 ... ... @@ -615,8 +615,8 @@ 615 615 OK 616 616 ))) 617 617 594 +(% style="display:none" %) (%%) 618 618 619 - 620 620 == 6.6 Print Last Received Data in Raw Format == 621 621 622 622 ... ... @@ -632,8 +632,8 @@ 632 632 OK 633 633 ))) 634 634 611 +(% style="display:none" %) (%%) 635 635 636 - 637 637 == 6.7 Print Last Received Data in Binary Format == 638 638 639 639 ... ... @@ -649,8 +649,8 @@ 649 649 OK 650 650 ))) 651 651 628 +(% style="display:none" %) (%%) 652 652 653 - 654 654 == 6.8 Send Text Data == 655 655 656 656 ... ... @@ -664,14 +664,11 @@ 664 664 |(% style="width:201px" %)**Command Example**|(% style="width:340px" %)**Function**|(% style="width:446px" %)**Response** 665 665 |(% style="width:201px" %)AT+SEND=12:hello world|(% style="width:340px" %)Send text data along with the application port.|(% style="width:446px" %)OK((( 666 666 While Error in format, return 667 - 668 668 AT_BUSY_ERROR/AT_BUSY_ERROR/AT_NO_NETWORK_JOINED 669 - 670 - 671 671 ))) 672 672 646 +(% style="display:none" %) (%%) 673 673 674 - 675 675 == 6.9 Send Hexadecimal Data == 676 676 677 677 ... ... @@ -680,21 +680,18 @@ 680 680 681 681 (% style="color:blue" %)**AT Command: AT+SENDB** 682 682 683 -(% border="1" style="background-color:#ffffcc; color:green; width:1120.22px" %) 684 -|=(% colspan="3" style="width: 1117px;" %)AT+SENDB 685 -|(% style="width:257px" %)**Command Example**|(% style="width:406px" %)**Function**|(% style="width:453px" %)**Response** 686 -|(% style="width:257px" %)AT+SENDB=12:abcdef0123456789|(% style="width:406px" %)Send hexadecimal data along with the application port.|(% style="width:453px" %)OK 687 -|(% 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((( 688 -AT_PARAM_ERROR AT_BUSY_ERROR/AT_NO_NETWORK_JOINED 689 - 690 - 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 691 691 ))) 692 692 664 +(% style="display:none" %) (%%) 693 693 694 - 695 695 = 7. LoRaWAN network management = 696 696 697 - 698 698 == 7.1 Adaptive Data Rate == 699 699 700 700 ... ... @@ -714,7 +714,6 @@ 714 714 AT_PARAM_ERROR 715 715 ))) 716 716 717 - 718 718 (% style="color:blue" %)**Downlink Command: 0x22** 719 719 720 720 If the downlink payload=2201, it means setting the adaptive data rate to 1, while type code is 22. ... ... @@ -722,9 +722,8 @@ 722 722 * **Example 1**: Downlink Payload: **2201** ~/~/ Set AT+ADR=1. 723 723 * **Example 2**: Downlink Payload: **2200FFFF** ~/~/ Set AT+ADR=0. 724 724 694 +(% style="display:none" %) (%%) 725 725 726 - 727 - 728 728 == 7.2 LoRa® Class == 729 729 730 730 ... ... @@ -731,7 +731,7 @@ 731 731 Feature: Get or Set the Device Class(Currently only support class A, class C). 732 732 733 733 734 -(% style="color:blue" %)**AT Command:AT+CLASS** 702 +(% style="color:blue" %)**AT Command: AT+CLASS** 735 735 736 736 (% border="1" style="background-color:#ffffcc; color:green; width:507.222px" %) 737 737 |=(% colspan="3" style="width: 504px;" %)AT+CLASS ... ... @@ -743,15 +743,15 @@ 743 743 744 744 ))) 745 745 714 +(% style="display:none" %) (%%) 746 746 747 - 748 748 == 7.3 Duty Cycle Setting == 749 749 750 750 751 -Feature: Get or Set the ETSI Duty Cycle setting 719 +Feature: Get or Set the ETSI Duty Cycle setting** - 0**=disable, **1**=enable - Only for testing. 752 752 753 753 754 -(% style="color:blue" %)**AT Command:AT+DCS** 722 +(% style="color:blue" %)**AT Command: AT+DCS** 755 755 756 756 (% border="1" style="background-color:#ffffcc; color:green; width:515.222px" %) 757 757 |=(% colspan="3" style="width: 512px;" %)AT+DCS ... ... @@ -763,14 +763,19 @@ 763 763 764 764 ))) 765 765 734 +(% style="display:none" %) (%%) 766 766 767 - 768 768 == 7.4 Data Rate == 769 769 770 770 771 -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 server739 +Feature: Get or Set the Data Rate. (0-7 corresponding to DR_X) . 772 772 741 +(% style="color:red" %) 742 +**Notice:** 773 773 744 +* 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. 745 +* 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/]] 746 + 774 774 (% style="color:blue" %)**AT Command: AT+DR** 775 775 776 776 (% border="1" style="background-color:#ffffcc; color:green; width:466.222px" %) ... ... @@ -783,7 +783,6 @@ 783 783 784 784 ))) 785 785 786 - 787 787 (% style="color:blue" %)**Downlink Command: 0x2200aaFF** 788 788 789 789 If the downlink payload=220001FF, it means setting the data rate to 1, while type code is 22 00 aa FF. ... ... @@ -791,9 +791,8 @@ 791 791 * **Example 1**: Downlink Payload: **220001FF** ~/~/ Set AT+DR=1. 792 792 * **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+DR=0. 793 793 766 +(% style="display:none" %) (%%) 794 794 795 - 796 - 797 797 == 7.5 Frame Counter Downlink == 798 798 799 799 ... ... @@ -800,7 +800,7 @@ 800 800 Feature: Get or Set the Frame Counter Downlink. 801 801 802 802 803 -(% style="color:blue" %)**AT Command:AT+FCD** 774 +(% style="color:blue" %)**AT Command: AT+FCD** 804 804 805 805 (% border="1" style="background-color:#ffffcc; color:green; width:693.222px" %) 806 806 |=(% colspan="3" style="width: 690px;" %)AT+FCD ... ... @@ -812,14 +812,12 @@ 812 812 OK 813 813 ))) 814 814 815 - 816 - 817 817 == 7.6 Frame Counter Uplink == 818 818 819 819 Feature: Get or Set the Frame Counter Uplink. 820 820 821 821 822 -(% style="color:blue" %)**AT Command:AT+FCU** 791 +(% style="color:blue" %)**AT Command: AT+FCU** 823 823 824 824 (% border="1" style="background-color:#ffffcc; color:green; width:534.222px" %) 825 825 |=(% colspan="3" style="width: 531px;" %)AT+FCU ... ... @@ -831,8 +831,8 @@ 831 831 832 832 ))) 833 833 803 +(% style="display:none" %) (%%) 834 834 835 - 836 836 == 7.7 Join Accept Delay1 == 837 837 838 838 ... ... @@ -839,7 +839,7 @@ 839 839 Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 1 in ms. 840 840 841 841 842 -(% style="color:blue" %)**AT Command:AT+JN1DL** 811 +(% style="color:blue" %)**AT Command: AT+JN1DL** 843 843 844 844 (% border="1" style="background-color:#ffffcc; color:green; width:537.222px" %) 845 845 |=(% colspan="3" style="width: 534px;" %)AT+JN1DL ... ... @@ -851,14 +851,15 @@ 851 851 852 852 ))) 853 853 823 +(% style="display:none" %) (%%) 854 854 855 - 856 856 == 7.8 Join Accept Delay2 == 857 857 827 + 858 858 Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 2 in ms. 859 859 860 860 861 -(% style="color:blue" %)**AT Command:AT+JN2DL** 831 +(% style="color:blue" %)**AT Command: AT+JN2DL** 862 862 863 863 (% border="1" style="background-color:#ffffcc; color:green; width:538.222px" %) 864 864 |=(% colspan="3" style="width: 535px;" %)AT+JN2DL ... ... @@ -870,17 +870,17 @@ 870 870 871 871 ))) 872 872 843 +(% style="display:none" %) (%%) 873 873 874 - 875 875 == 7.9 Public Network Mode == 876 876 877 877 878 878 Feature: Get or Set the public network mode. (0: off, 1: on). A Public LoRaWAN network use 0x34 as syncword. Default Settings; PNM=1 879 879 880 -(% style="color:red" %)Notice: If user build their own LoRaWAN server but still use syncword=0x34, this is still considered a public LoRaWAN network 850 +(% style="color:red" %)**Notice: If user build their own LoRaWAN server but still use syncword=0x34, this is still considered a public LoRaWAN network.** 881 881 882 882 883 -(% style="color:blue" %)**AT Command:AT+PNM** 853 +(% style="color:blue" %)**AT Command: AT+PNM** 884 884 885 885 (% border="1" style="background-color:#ffffcc; color:green; width:667.222px" %) 886 886 |=(% colspan="3" style="width: 664px;" %)AT+PNM ... ... @@ -899,8 +899,8 @@ 899 899 ))) 900 900 |(% style="width:166px" %)AT+PNM=0|(% style="width:225px" %)Set to use private network autoset syncword=0x12|(% style="width:272px" %) 901 901 872 +(% style="display:none" %) (%%) 902 902 903 - 904 904 == 7.10 Receive Delay1 == 905 905 906 906 ... ... @@ -907,7 +907,7 @@ 907 907 Feature: Get or Set the delay between the end of the Tx and the Rx Window 1 in ms 908 908 909 909 910 -(% style="color:blue" %)**AT Command:AT+RX1DL** 880 +(% style="color:blue" %)**AT Command: AT+RX1DL** 911 911 912 912 (% border="1" style="background-color:#ffffcc; color:green; width:408.222px" %) 913 913 |=(% colspan="3" style="width: 405px;" %)AT+RX1DL ... ... @@ -919,8 +919,8 @@ 919 919 920 920 ))) 921 921 892 +(% style="display:none" %) (%%) 922 922 923 - 924 924 == 7.11 Receive Delay2 == 925 925 926 926 ... ... @@ -927,7 +927,7 @@ 927 927 Feature: Get or Set the delay between the end of the Tx and the Rx Window 2 in ms 928 928 929 929 930 -(% style="color:blue" %)**AT Command:AT+RX2DL** 900 +(% style="color:blue" %)**AT Command: AT+RX2DL** 931 931 932 932 (% border="1" style="background-color:#ffffcc; color:green; width:481.222px" %) 933 933 |=(% colspan="3" style="width: 478px;" %)AT+RX2DL ... ... @@ -939,8 +939,8 @@ 939 939 940 940 ))) 941 941 912 +(% style="display:none" %) (%%) 942 942 943 - 944 944 == 7.12 Rx2 Window Data Rate == 945 945 946 946 ... ... @@ -947,7 +947,7 @@ 947 947 Feature: Get or Set the Rx2 window data rate (0-7 corresponding to DR_X) 948 948 949 949 950 -(% style="color:blue" %)**AT Command:AT+RX2DR** 920 +(% style="color:blue" %)**AT Command: AT+RX2DR** 951 951 952 952 (% border="1" style="background-color:#ffffcc; color:green; width:525.222px" %) 953 953 |=(% colspan="3" style="width: 522px;" %)AT+RX2DR ... ... @@ -959,8 +959,8 @@ 959 959 960 960 ))) 961 961 932 +(% style="display:none" %) (%%) 962 962 963 - 964 964 == 7.13 Rx2 Window Frequency == 965 965 966 966 ... ... @@ -967,7 +967,7 @@ 967 967 Feature: Get or Set the Rx2 window frequency 968 968 969 969 970 -(% style="color:blue" %)**AT Command:AT+RX2FQ** 940 +(% style="color:blue" %)**AT Command: AT+RX2FQ** 971 971 972 972 (% border="1" style="background-color:#ffffcc; color:green; width:587.222px" %) 973 973 |=(% colspan="3" style="width: 584px;" %)AT+RX2FQ ... ... @@ -979,16 +979,18 @@ 979 979 980 980 ))) 981 981 952 +(% style="display:none" %) (%%) 982 982 983 - 984 984 == 7.14 Transmit Power == 985 985 986 986 987 987 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. ) 988 988 959 +(% 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** 989 989 990 -(% style="color:blue" %)**AT Command:AT+TXP** 991 991 962 +(% style="color:blue" %)**AT Command: AT+TXP** 963 + 992 992 (% border="1" style="background-color:#ffffcc; color:green; width:465.222px" %) 993 993 |=(% colspan="3" style="width: 462px;" %)AT+TXP 994 994 |(% style="width:161px" %)**Command Example**|(% style="width:189px" %)**Function**|(% style="width:112px" %)**Response** ... ... @@ -999,7 +999,6 @@ 999 999 1000 1000 ))) 1001 1001 1002 - 1003 1003 Downlink Payload. The 4th byte of 0x22 downlink. 1004 1004 1005 1005 If the downlink payload=22000100, it means setting the TXP to 0. ... ... @@ -1007,9 +1007,8 @@ 1007 1007 * **Example 1**: Downlink Payload: **22000102** ~/~/ Set AT+TXP=2. 1008 1008 * **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+TXP=0. 1009 1009 981 +(% style="display:none" %) (%%) 1010 1010 1011 - 1012 - 1013 1013 == 7.15 RSSI of the Last Received Packet == 1014 1014 1015 1015 ... ... @@ -1025,8 +1025,8 @@ 1025 1025 OK 1026 1026 ))) 1027 1027 998 +(% style="display:none" %) (%%) 1028 1028 1029 - 1030 1030 == 7.16 SNR of the Last Received Packet == 1031 1031 1032 1032 ... ... @@ -1033,7 +1033,7 @@ 1033 1033 Feature: Get the SNR of the last received packet 1034 1034 1035 1035 1036 -(% style="color:blue" %)**AT Command:AT+SNR** 1006 +(% style="color:blue" %)**AT Command: AT+SNR** 1037 1037 1038 1038 (% border="1" style="background-color:#ffffcc; color:green; width:571.222px" %) 1039 1039 |=(% colspan="3" style="width: 568px;" %)AT+SNR ... ... @@ -1042,8 +1042,8 @@ 1042 1042 OK 1043 1043 ))) 1044 1044 1015 +(% style="display:none" %) (%%) 1045 1045 1046 - 1047 1047 == 7.17 Application Port == 1048 1048 1049 1049 ... ... @@ -1060,7 +1060,6 @@ 1060 1060 ))) 1061 1061 |(% style="width:157px" %)AT+PORT=21|(% style="width:204px" %)Set the application port|(% style="width:135px" %)OK 1062 1062 1063 - 1064 1064 (% style="color:blue" %)**Downlink Command: 0x23** 1065 1065 1066 1066 Format: Command Code (0x23) followed by 1 bytes port value. ... ... @@ -1070,8 +1070,8 @@ 1070 1070 * **Example 1**: Downlink Payload: **2301** ~/~/ set the application port to 1 1071 1071 * **Example 2**: Downlink Payload:** 2305** ~/~/ set the application port to 5 1072 1072 1042 +(% style="display:none" %) (%%) 1073 1073 1074 - 1075 1075 == 7.18 Single Channel Mode == 1076 1076 1077 1077 ... ... @@ -1088,10 +1088,11 @@ 1088 1088 ))) 1089 1089 |(% style="width:182px" %)AT+CHS=868100000|(% style="width:295px" %)Set Frequency for Single Channel Mode|(% style="width:122px" %)OK 1090 1090 1060 +(% style="display:none" %) (%%) 1091 1091 1092 - 1093 1093 == 7.19 Eight Channel Mode == 1094 1094 1064 + 1095 1095 Feature: Get or Set eight channels mode,Only for US915,AU915,CN470. 1096 1096 1097 1097 ... ... @@ -1107,9 +1107,8 @@ 1107 1107 ))) 1108 1108 |(% style="width:160px" %)AT+CHE=1|(% style="width:198px" %)Set eight channels mode|(% style="width:349px" %)OK 1109 1109 1080 +(% style="color:blue" %)**Downlink Command: 0x24 (LHT65,LHT65N Downlink Command:0x07)** 1110 1110 1111 -(% style="color:blue" %)**Downlink Command: 0x24** 1112 - 1113 1113 Format: Command Code (0x24) followed by 1 bytes channel value. 1114 1114 1115 1115 If the downlink payload=2401, it means set channel mode to 1, while type code is 24. ... ... @@ -1117,9 +1117,8 @@ 1117 1117 * **Example 1**: Downlink Payload: 2401 ~/~/ set channel mode to 1 1118 1118 * **Example 2**: Downlink Payload: 2405 ~/~/ set channel mode to 5 1119 1119 1089 +(% style="display:none" %) (%%) 1120 1120 1121 - 1122 - 1123 1123 == 7.20 Get or Set RXwindows1 timeout == 1124 1124 1125 1125 ... ... @@ -1136,23 +1136,19 @@ 1136 1136 ))) 1137 1137 |(% style="width:163px" %)AT+RX1WTO=60|(% style="width:201px" %)Set RXwindows1 timeout|(% style="width:93px" %)OK 1138 1138 1139 -((( 1140 - 1107 +(% style="display:none" %) (%%) 1141 1141 1142 -**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. 1143 - 1144 - 1109 +((( 1110 +(% 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. 1145 1145 ))) 1146 1146 1147 1147 [[image:image-20220526162535-1.png]] 1148 1148 1149 - 1150 1150 ((( 1151 1151 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. 1152 - 1153 - 1154 1154 ))) 1155 1155 1119 + 1156 1156 == 7.21 Get or Set RXwindows2 timeout == 1157 1157 1158 1158 ... ... @@ -1169,8 +1169,8 @@ 1169 1169 ))) 1170 1170 |(% style="width:190px" %)AT+RX2WTO=20|(% style="width:199px" %)Set RXwindows2 timeout|(% style="width:104px" %)OK 1171 1171 1136 +(% style="display:none" %) (%%) 1172 1172 1173 - 1174 1174 == 7.22 Setting up uplinkdwelltime (as923, au915) == 1175 1175 1176 1176 ... ... @@ -1187,7 +1187,6 @@ 1187 1187 ))) 1188 1188 |(% style="width:183px" %)AT+DWELLT=0|(% style="width:179px" %)Set uplinkdwelltime|(% style="width:131px" %)OK 1189 1189 1190 - 1191 1191 (% style="color:blue" %)**Downlink Command: 0x25** 1192 1192 1193 1193 Format: Command Code (0x25) followed by 1 bytes state value. ... ... @@ -1197,9 +1197,8 @@ 1197 1197 * **Example 1**: Downlink Payload: **2501** ~/~/ set uplinkdwelltime to 1 1198 1198 * **Example 2**: Downlink Payload: **2500** ~/~/ set uplinkdwelltime to 0 1199 1199 1163 +(% style="display:none" %) (%%) 1200 1200 1201 - 1202 - 1203 1203 == 7.23 Set Packet Receiving Response Level == 1204 1204 1205 1205 ... ... @@ -1214,7 +1214,6 @@ 1214 1214 * **AT+RPL=3:** Device will immediately reply message to MAC Command. Payload is 0x00 and requied response header for this command. 1215 1215 * **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. 1216 1216 1217 - 1218 1218 **Case Analyes:** 1219 1219 1220 1220 * For Class A devices, AT+RPL=0 is ok. that is defaut settings in software. ... ... @@ -1221,7 +1221,6 @@ 1221 1221 * For Class C devices used in ChirpStack, need to set AT+RPL=4 because Chirpstack require immedietely reply message to MAC Command. 1222 1222 * 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. 1223 1223 1224 - 1225 1225 (% style="color:blue" %)**AT Command: AT+RPL** 1226 1226 1227 1227 (% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %) ... ... @@ -1232,7 +1232,6 @@ 1232 1232 ))) 1233 1233 |(% style="width:160px" %)AT+RPL=0|(% style="width:263px" %)Set packet receiving response level|(% style="width:109px" %)OK 1234 1234 1235 - 1236 1236 (% style="color:blue" %)**Downlink Command: 0x21** 1237 1237 1238 1238 Format: Command Code (0x21) followed by 1 bytes level value. ... ... @@ -1242,9 +1242,8 @@ 1242 1242 * **Example 1**: Downlink Payload: **2101** ~/~/ set packet receiving response level to 1 1243 1243 * **Example 2**: Downlink Payload: **2102** ~/~/ set packet receiving response level to 2 1244 1244 1204 +(% style="display:none" %) (%%) 1245 1245 1246 - 1247 - 1248 1248 == 7.24 Controls NBTrans in unconfirmed uplink mode(LWS007 NBTrans:Set retransmission packets) == 1249 1249 1250 1250 ... ... @@ -1266,7 +1266,6 @@ 1266 1266 OK 1267 1267 ))) 1268 1268 1269 - 1270 1270 (% style="color:blue" %)**Downlink Command: 0x33** 1271 1271 1272 1272 Format: Command Code (0x33) followed by 2 bytes mode value. ... ... @@ -1276,13 +1276,18 @@ 1276 1276 * Example 1: Downlink Payload: 330100 ~/~/ Set AT+SETMAXNBTRANS=1,0 1277 1277 * Example 2: Downlink Payload: 330201 ~/~/ Set AT+SETMAXNBTRANS=2,1 1278 1278 1236 +(% style="display:none" %) (%%) 1279 1279 1280 - 1281 1281 == 7.25 Device offline rejoining (LWS007) == 1282 1282 1283 1283 1284 1284 (% style="color:blue" %)**AT Command: AT+DDETECT** 1285 1285 1243 +AT+DDETECT=<Flag>,<ACK_Timout_1>,<ACK_Timout_2> (Default Value: AT+DDETECT=1,1440,2880) 1244 + 1245 +* ACK_Timout_1: Unit: min 1246 +* ACK_Timout_2: Unit: min 1247 + 1286 1286 (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 1287 1287 |=(% colspan="3" style="width: 707px;" %)AT+**DDETECT** 1288 1288 |(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response** ... ... @@ -1314,17 +1314,20 @@ 1314 1314 OK 1315 1315 ))) 1316 1316 1279 +(% style="color:blue" %)**Downlink Command: 0x32** 1317 1317 1318 -(% style="color:blue" %)**Downlink Command: 0x33** 1319 - 1320 1320 Format: Command Code (0x32) followed by 2 bytes mode value. 1321 1321 1322 -If the downlink payload=320105A00B40, it means set end node to use confirm mode, while type code is 3 3.1283 +If the downlink payload=320105A00B40, it means set end node to use confirm mode, while type code is 32. 1323 1323 1324 -* **Example 1:** Downlink Payload: 320105A00B40 ~/~/ Set AT+DDETECT=1,1440,2880 1285 +* **Example 1:** Downlink Payload: 320105A00B40 ~/~/ Set AT+DDETECT=1,1440,2880 1286 +** 0x01 : Flag 1287 +** 0x05A0: ACK_Timout_1 : 1440minutes (24 hours) 1288 +** 0x0B40: ACK_Timout_2 : 2880minutes (48 hours) 1289 +** **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. 1325 1325 1291 +(% style="display:none" %) (%%) 1326 1326 1327 - 1328 1328 == 7.26 Request the server to send an ACK == 1329 1329 1330 1330 ... ... @@ -1338,12 +1338,11 @@ 1338 1338 ))) 1339 1339 |(% style="width:160px" %)**AT+PNACKMD=0**|(% style="width:263px" %)off request the server to send an ACK|(% style="width:109px" %)((( 1340 1340 0 1341 - 1342 1342 OK 1343 1343 ))) 1344 1344 1309 +(% style="display:none" %) (%%) 1345 1345 1346 - 1347 1347 == 7.27 Adjust network rejoining interval == 1348 1348 1349 1349 ... ... @@ -1352,16 +1352,15 @@ 1352 1352 (% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %) 1353 1353 |=(% colspan="3" style="width: 724px;" %)AT+RJTDC 1354 1354 |(% style="width:165px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:329px" %)**Response** 1355 -|(% style="width:165px" %)AT+RJTDC=?|(% style="width:227px" %)Show the ReJoin data transmission interval in min|(% style="width:329px" %)30 000(((1319 +|(% style="width:165px" %)AT+RJTDC=?|(% style="width:227px" %)Show the ReJoin data transmission interval in min|(% style="width:329px" %)30((( 1356 1356 OK 1357 1357 1358 -the interval is 30 000ms= 30s1322 +the interval is 30 min 1359 1359 ))) 1360 -|(% style="width:165px" %)AT+RJTDC=60 000|(% style="width:227px" %)Set the ReJoin data transmission interval in min|(% style="width:329px" %)OK(((1361 -Set the ReJoin data transmission interval to 60 000ms= 60 seconds1324 +|(% style="width:165px" %)AT+RJTDC=60|(% style="width:227px" %)Set the ReJoin data transmission interval in min|(% style="width:329px" %)OK((( 1325 +Set the ReJoin data transmission interval to 60 min 1362 1362 ))) 1363 1363 1364 - 1365 1365 (% style="color:blue" %)**Downlink Command: 0x26** 1366 1366 1367 1367 Format: Command Code (0x26) followed by 2 bytes mode value. ... ... @@ -1371,18 +1371,18 @@ 1371 1371 * **Example 1:** Downlink Payload: 26000A ~/~/ Set AT+RJTDC=10 1372 1372 * **Example 2: **Downlink Payload: 260002 ~/~/ Set AT+RJTDC=2 1373 1373 1337 +(% style="display:none" %) (%%) 1374 1374 1375 - 1376 1376 = 8. AT Commands Combination = 1377 1377 1378 - 1379 1379 == 8.1 Set a fix RX2DR for downlink window == 1380 1380 1381 1381 1382 -* **AT+ADR=0 ** **~-~->** Disable ADR first 1383 -* **AT+RX2DR=xxxx** **~-~->** Set xxxx to your wanted DataRate 1344 +* (% style="color:blue" %)**AT+ADR=0 **(%%) **~-~->** Disable ADR first 1384 1384 1346 +* (% style="color:blue" %)**AT+RX2DR=xxxx** (%%) **~-~->** Set xxxx to your wanted DataRate 1385 1385 1348 +(% style="display:none" %) (%%) 1386 1386 1387 1387 == 8.2 Use Downlink Command to set a fix uplink DR == 1388 1388 ... ... @@ -1392,5 +1392,9 @@ 1392 1392 **Same as:** 1393 1393 1394 1394 * AT+ADR=0 [[Reference>>||anchor="H7.1AdaptiveDataRate"]] 1358 + 1395 1395 * AT+DR=5 [[Reference>>||anchor="H7.4DataRate"]] 1360 + 1396 1396 * AT+TXP=0 [[Reference>>||anchor="H7.14TransmitPower"]] 1362 + 1363 +