Changes for page End Device AT Commands and Downlink Command
Last modified by kai on 2024/09/06 10:00
Change comment:
There is no comment for this version
Summary
-
Page properties (2 modified, 0 added, 0 removed)
Details
- Page properties
-
- Author
-
... ... @@ -1,1 +1,1 @@ 1 -XWiki. Edwin1 +XWiki.Xiaoling - Content
-
... ... @@ -9,14 +9,12 @@ 9 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.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. 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 17 18 - 19 - 20 20 ))) 21 21 22 22 = 2. How to use AT Commands or Downlink command = ... ... @@ -25,10 +25,11 @@ 25 25 * 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/]] 26 26 * 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: 27 27 ** Use HEX format to send a downlink: [[TTN v3>>Notes for TTN]] 28 -** 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]]?26 +** Use Base64 format to send a downlink: [[Chirpstack>>Notes for ChirpStack]] 29 29 ** See use note for more serves [[Servers Note>>doc:Main.WebHome]](IoT LoRaWAN Server) 30 30 31 31 30 + 32 32 = 3. Support End Node and firmware version = 33 33 34 34 ... ... @@ -106,6 +106,7 @@ 106 106 107 107 = 4. System Management Commands = 108 108 108 + 109 109 == 4.1 Change Uplink Interval == 110 110 111 111 ... ... @@ -135,13 +135,14 @@ 135 135 ))) 136 136 137 137 ((( 138 -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. 139 139 ))) 140 140 141 -* **Example 1**: Downlink Payload:** 0100001E** 142 -* **Example 2**: Downlink Payload:** 0100003C** 141 +* **Example 1**: Downlink Payload:** 0100001E** ~/~/ Set Transmit Interval (TDC) = 30 seconds 142 +* **Example 2**: Downlink Payload:** 0100003C** ~/~/ Set Transmit Interval (TDC) = 60 seconds 143 143 144 144 145 + 145 145 == 4.2 Reboot End Node == 146 146 147 147 ... ... @@ -150,10 +150,10 @@ 150 150 151 151 (% style="color:blue" %)**AT Command: ATZ** 152 152 153 -(% border="1" style="background-color:#ffffcc; color:green; width: 546px" %)154 -|=(% colspan="3" style="width: 543px;"%)ATZ: Trig a reset of the MCU155 -| (% style="width:157px" %)**Command Example**|(% style="width:92px" %)**Function**|(% style="width:294px" %)**Response**156 -| (% style="width:157px" %)ATZ|(% style="width:92px" %)Reset MCU|(% style="width:294px" %)(((154 +(% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %) 155 +|=(% colspan="3" %)ATZ: Trig a reset of the MCU 156 +|**Command Example**|**Function**|**Response** 157 +|ATZ|Reset MCU|((( 157 157 Device reset and show booting info 158 158 159 159 LSN50 Device/LoRa ST Module ... ... @@ -167,6 +167,7 @@ 167 167 <followed by the Tx and Rx information> 168 168 ))) 169 169 171 + 170 170 (% style="color:blue" %)**Downlink Command: 0x04** 171 171 172 172 ((( ... ... @@ -176,7 +176,6 @@ 176 176 ((( 177 177 If the downlink payload=**04FF**, the end node will reboot. 178 178 179 - 180 180 181 181 ))) 182 182 ... ... @@ -188,10 +188,10 @@ 188 188 189 189 (% style="color:blue" %)**AT Command: AT+FDR** 190 190 191 -(% border="1" style="background-color:#ffffcc; color:green; width: 789px" %)192 -|=(% colspan="3" style="width: 786px;" %)Reset to factory default193 -|(% style="width:1 54px" %)**Command Example**|(% style="width:175px" %)**Function**|(% style="width:456px" %)**Response**194 -|(% style="width:1 54px" %)AT+FDR|(% style="width:175px" %)Reset to factory default|(% style="width:456px" %)(((192 +(% border="1" style="background-color:#ffffcc; color:green; width:831.222px" %) 193 +|=(% colspan="3" style="width: 828px;" %)Reset to factory default 194 +|(% style="width:181px" %)**Command Example**|(% style="width:181px" %)**Function**|(% style="width:465px" %)**Response** 195 +|(% style="width:181px" %)AT+FDR|(% style="width:181px" %)Reset to factory default|(% style="width:465px" %)((( 195 195 Device reset to factory default parameters and show booting info 196 196 197 197 LSN50 Device/LoRa ST Module ... ... @@ -205,6 +205,7 @@ 205 205 Please set the parameters or reset Device to apply change 206 206 ))) 207 207 209 + 208 208 (% style="color:blue" %)**Downlink Command: 0x04** 209 209 210 210 ((( ... ... @@ -216,7 +216,6 @@ 216 216 ))) 217 217 218 218 219 - 220 220 == 4.4 Show Firmware Version == 221 221 222 222 ... ... @@ -225,15 +225,16 @@ 225 225 226 226 (% style="color:blue" %)**AT Command: AT+VER** 227 227 228 -(% border="1" style="background-color:#ffffcc; color:green; width:5 42px" %)229 -|=(% colspan="3" style="width: 53 9px;" %)AT+VER: Image Version and Frequency Band230 -|(% style="width:1 57px" %)**Command Example**|(% style="width:295px" %)**Function**|(% style="width:86px" %)**Response**231 -|(% style="width:1 57px" %)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" %)((( 232 232 1.3 EU868 233 233 234 234 OK 235 235 ))) 236 236 238 + 237 237 (% style="color:blue" %)**Downlink Command: 0x26 (Valid in 006 stack)** 238 238 239 239 ((( ... ... @@ -258,6 +258,7 @@ 258 258 ((( 259 259 260 260 263 + 261 261 **yy: Frequency Band:** 262 262 ))) 263 263 ... ... @@ -275,6 +275,7 @@ 275 275 ((( 276 276 277 277 281 + 278 278 **zz: Subband** 279 279 ))) 280 280 ... ... @@ -281,7 +281,6 @@ 281 281 firmware version: v1.1.0 ~-~-> 110 282 282 283 283 284 - 285 285 == 4.5 Show System Configure == 286 286 287 287 ... ... @@ -308,8 +308,10 @@ 308 308 ))) 309 309 310 310 314 + 311 311 = 5. Keys, IDs and EUIs management = 312 312 317 + 313 313 == 5.1 Application EUI == 314 314 315 315 ... ... @@ -327,6 +327,7 @@ 327 327 |(% style="width:305px" %)AT+APPEUI=00 b3 d5 7e f0 00 4d 34|(% style="width:186px" %)Set the Application EUI|(% style="width:191px" %)OK 328 328 329 329 335 + 330 330 == 5.2 Application Key == 331 331 332 332 ... ... @@ -344,6 +344,7 @@ 344 344 |(% 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 345 345 346 346 353 + 347 347 == 5.3 Application Session Key == 348 348 349 349 ... ... @@ -363,6 +363,7 @@ 363 363 ))) 364 364 365 365 373 + 366 366 == 5.4 Device Address == 367 367 368 368 ... ... @@ -382,6 +382,7 @@ 382 382 |(% style="width:192px" %)AT+DADDR=A8 40 41 FF|(% style="width:241px" %)Set the Application Session Key.|(% style="width:359px" %)OK 383 383 384 384 393 + 385 385 == 5.5 Device EUI == 386 386 387 387 ... ... @@ -401,6 +401,7 @@ 401 401 ))) 402 402 403 403 413 + 404 404 == 5.6 Network ID == 405 405 406 406 ... ... @@ -418,6 +418,7 @@ 418 418 |(% style="width:191px" %)AT+NWKID=A8 40 41 FF|(% style="width:153px" %)Set the Network ID.|(% style="width:101px" %)OK 419 419 420 420 431 + 421 421 == 5.7 Network Session Key == 422 422 423 423 ... ... @@ -435,10 +435,13 @@ 435 435 |(% 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 436 436 437 437 449 + 438 438 = 6. Joining and sending date on LoRaWAN network = 439 439 452 + 440 440 == 6.1 Confirm Mode == 441 441 455 + 442 442 === 6.1.1 AT+CFM command before DR-LWS007 software stack === 443 443 444 444 ... ... @@ -456,6 +456,7 @@ 456 456 |(% style="width:155px" %)AT+CFM=1|(% style="width:205px" %)Set the confirmation mode|(% style="width:346px" %)OK 457 457 |(% style="width:155px" %)AT+CFM=2|(% style="width:205px" %)Set the confirmation mode|(% style="width:346px" %)While Error in format, return AT_PARAM_ERROR 458 458 473 + 459 459 (% style="color:blue" %)**Downlink Command: 0x05** 460 460 461 461 Format: Command Code (0x05) followed by 2 bytes mode value. ... ... @@ -462,10 +462,12 @@ 462 462 463 463 If the downlink payload=0501, it means set end node to use confirm mode, while type code is 05. 464 464 465 -* **Example 1:**Downlink Payload: 0501466 -* **Example 2:**Downlink Payload: 0500480 +* Example 1: Downlink Payload: 0501 ~/~/ Set AT+CFM=1 481 +* Example 2: Downlink Payload: 0500 ~/~/ Set AT+CFM=0 467 467 468 468 484 + 485 + 469 469 === 6.1.2 AT+CFM command since DR-LWS007 software stack === 470 470 471 471 ... ... @@ -502,6 +502,7 @@ 502 502 OK 503 503 ))) 504 504 522 + 505 505 (% style="color:blue" %)**Downlink Command: 0x05** 506 506 507 507 Format: Command Code (0x05) followed by 2 bytes mode value. ... ... @@ -508,10 +508,12 @@ 508 508 509 509 If the downlink payload=05010101, it means set end node to use confirm mode, while type code is 05. 510 510 511 -* **Example 1:**Downlink Payload: 05010101512 -* **Example 2:**Downlink Payload: 05000700529 +* Example 1: Downlink Payload: 05010101 ~/~/ Set AT+CFM=1,1,1 530 +* Example 2: Downlink Payload: 05000700 ~/~/ Set AT+CFM=0,7,0 513 513 514 514 533 + 534 + 515 515 == 6.2 Confirm Status == 516 516 517 517 ... ... @@ -528,6 +528,7 @@ 528 528 ))) 529 529 530 530 551 + 531 531 == 6.3 Join LoRa® Network == 532 532 533 533 ... ... @@ -546,6 +546,7 @@ 546 546 ))) 547 547 548 548 570 + 549 549 == 6.4 LoRa® Network Join Mode == 550 550 551 551 ... ... @@ -563,6 +563,7 @@ 563 563 |(% style="width:162px" %)AT+NJM=0|(% style="width:227px" %)Set the Network Join Mode|(% style="width:361px" %)OK 564 564 |(% 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 565 565 588 + 566 566 (% style="color:blue" %)**Downlink Command: 0x20** 567 567 568 568 Format: Command Code (0x20) followed by 1 bytes mode value. ... ... @@ -569,10 +569,12 @@ 569 569 570 570 If the downlink payload=2000, it means set the Network Join Mode, while type code is 20. 571 571 572 -* **Example 1: **Downlink Payload: **2000 573 -* **Example 2:** Downlink Payload: **2001** 595 +* **Example 1: **Downlink Payload: **2000** ~/~/ Set AT+NJM=0 596 +* **Example 2:** Downlink Payload: **2001** ~/~/ Set AT+NJM=1 574 574 575 575 599 + 600 + 576 576 == 6.5 LoRa® Network Join Status == 577 577 578 578 ... ... @@ -589,6 +589,7 @@ 589 589 ))) 590 590 591 591 617 + 592 592 == 6.6 Print Last Received Data in Raw Format == 593 593 594 594 ... ... @@ -605,6 +605,7 @@ 605 605 ))) 606 606 607 607 634 + 608 608 == 6.7 Print Last Received Data in Binary Format == 609 609 610 610 ... ... @@ -621,6 +621,7 @@ 621 621 ))) 622 622 623 623 651 + 624 624 == 6.8 Send Text Data == 625 625 626 626 ... ... @@ -641,6 +641,7 @@ 641 641 ))) 642 642 643 643 672 + 644 644 == 6.9 Send Hexadecimal Data == 645 645 646 646 ... ... @@ -649,11 +649,11 @@ 649 649 650 650 (% style="color:blue" %)**AT Command: AT+SENDB** 651 651 652 -(% border="1" style="background-color:#ffffcc; color:green; width:110 1px" %)653 -|=(% colspan="3" style="width: 1 098px;" %)AT+SENDB654 -|(% style="width:257px" %)**Command Example**|(% style="width: 394px" %)**Function**|(% style="width:446px" %)**Response**655 -|(% style="width:257px" %)AT+SENDB=12:abcdef0123456789|(% style="width: 394px" %)Send hexadecimal data along with the application port.|(% style="width:446px" %)OK656 -|(% 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(((681 +(% border="1" style="background-color:#ffffcc; color:green; width:1120.22px" %) 682 +|=(% colspan="3" style="width: 1117px;" %)AT+SENDB 683 +|(% style="width:257px" %)**Command Example**|(% style="width:406px" %)**Function**|(% style="width:453px" %)**Response** 684 +|(% style="width:257px" %)AT+SENDB=12:abcdef0123456789|(% style="width:406px" %)Send hexadecimal data along with the application port.|(% style="width:453px" %)OK 685 +|(% 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((( 657 657 AT_PARAM_ERROR AT_BUSY_ERROR/AT_NO_NETWORK_JOINED 658 658 659 659 ... ... @@ -660,8 +660,10 @@ 660 660 ))) 661 661 662 662 692 + 663 663 = 7. LoRaWAN network management = 664 664 695 + 665 665 == 7.1 Adaptive Data Rate == 666 666 667 667 ... ... @@ -683,20 +683,21 @@ 683 683 684 684 (% style="color:blue" %)**Downlink Command: 0x22** 685 685 686 -If the downlink payload=2201, it means setting the adaptive data rate to 1, while type code is 22. 687 687 688 -* **Example 1**: Downlink Payload: **2201** ~/~/ Set AT+ADR=1. 689 -* **Example 2**: Downlink Payload: **2200FFFF** ~/~/ Set AT+ADR=0. 690 690 719 +If the downlink payload=2201, it means setting the adaptive data rate to 1, while type code is 22. 691 691 721 +* **Example 1**: Downlink Payload: **2201** ~/~/ Set AT+ADR=1. 722 +* **Example 2**: Downlink Payload: **2200FFFF** ~/~/ Set AT+ADR=0. 723 + 692 692 == 7.2 LoRa® Class == 693 693 694 - 695 695 Feature: Get or Set the Device Class(Currently only support class A, class C). 696 696 697 697 698 -(% style="color:blue" %)**AT Command: 729 +(% style="color:blue" %)**AT Command:AT+CLASS** 699 699 731 + 700 700 (% border="1" style="background-color:#ffffcc; color:green; width:507.222px" %) 701 701 |=(% colspan="3" style="width: 504px;" %)AT+CLASS 702 702 |(% style="width:163px" %)**Command Example**|(% style="width:166px" %)**Function**|(% style="width:175px" %)**Response** ... ... @@ -707,14 +707,13 @@ 707 707 708 708 ))) 709 709 710 - 711 711 == 7.3 Duty Cycle Setting == 712 712 744 +Feature: Get or Set the ETSI Duty Cycle setting - 0=disable, 1=enable - Only for testing. 713 713 714 -Feature: Get or Set the ETSI Duty Cycle setting** - 0**=disable, **1**=enable - Only for testing. 715 715 747 +(% style="color:blue" %)**AT Command:AT+DCS** 716 716 717 -(% style="color:blue" %)**AT Command: AT+DCS** 718 718 719 719 (% border="1" style="background-color:#ffffcc; color:green; width:515.222px" %) 720 720 |=(% colspan="3" style="width: 512px;" %)AT+DCS ... ... @@ -726,21 +726,14 @@ 726 726 727 727 ))) 728 728 729 - 730 730 == 7.4 Data Rate == 731 731 762 +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 732 732 733 -Feature: Get or Set the Data Rate. (0-7 corresponding to DR_X) . 734 734 735 -(% style="color:red" %) 736 -**Notice:** 737 - 738 -* 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. 739 -* Data Rate specifies Spreading Factor. The mapping various in different frequency band. 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/]] 740 - 741 - 742 742 (% style="color:blue" %)**AT Command: AT+DR** 743 743 767 + 744 744 (% border="1" style="background-color:#ffffcc; color:green; width:466.222px" %) 745 745 |=(% colspan="3" style="width: 463px;" %)AT+DR 746 746 |(% style="width:156px" %)**Command Example**|(% style="width:167px" %)**Function**|(% style="width:140px" %)**Response** ... ... @@ -753,20 +753,21 @@ 753 753 754 754 (% style="color:blue" %)**Downlink Command: 0x2200aaFF** 755 755 756 -If the downlink payload=220001FF, it means setting the data rate to 1, while type code is 22 00 aa FF. 757 757 758 -* **Example 1**: Downlink Payload: **220001FF** ~/~/ Set AT+DR=1. 759 -* **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+DR=0. 760 760 782 +If the downlink payload=220001FF, it means setting the data rate to 1, while type code is 22 00 aa FF. 761 761 784 +* **Example 1**: Downlink Payload: **220001FF** ~/~/ Set AT+DR=1. 785 +* **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+DR=0. 786 + 762 762 == 7.5 Frame Counter Downlink == 763 763 764 - 765 765 Feature: Get or Set the Frame Counter Downlink. 766 766 767 767 768 -(% style="color:blue" %)**AT Command: 792 +(% style="color:blue" %)**AT Command:AT+FCD** 769 769 794 + 770 770 (% border="1" style="background-color:#ffffcc; color:green; width:693.222px" %) 771 771 |=(% colspan="3" style="width: 690px;" %)AT+FCD 772 772 |(% style="width:162px" %)**Command Example**|(% style="width:258px" %)**Function**|(% style="width:269px" %)**Response** ... ... @@ -775,16 +775,18 @@ 775 775 ))) 776 776 |(% style="width:162px" %)AT+FCD=10|(% style="width:258px" %)Set the Frame Counter Downlink.|(% style="width:269px" %)(System will write new value to FCD)((( 777 777 OK 803 + 804 + 778 778 ))) 779 779 780 - 781 781 == 7.6 Frame Counter Uplink == 782 782 783 783 Feature: Get or Set the Frame Counter Uplink. 784 784 785 785 786 -(% style="color:blue" %)**AT Command: 812 +(% style="color:blue" %)**AT Command:AT+FCU** 787 787 814 + 788 788 (% border="1" style="background-color:#ffffcc; color:green; width:534.222px" %) 789 789 |=(% colspan="3" style="width: 531px;" %)AT+FCU 790 790 |(% style="width:177px" %)**Command Example**|(% style="width:239px" %)**Function**|(% style="width:113px" %)**Response** ... ... @@ -795,15 +795,14 @@ 795 795 796 796 ))) 797 797 798 - 799 799 == 7.7 Join Accept Delay1 == 800 800 801 - 802 802 Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 1 in ms. 803 803 804 804 805 -(% style="color:blue" %)**AT Command: 830 +(% style="color:blue" %)**AT Command:AT+JN1DL** 806 806 832 + 807 807 (% border="1" style="background-color:#ffffcc; color:green; width:537.222px" %) 808 808 |=(% colspan="3" style="width: 534px;" %)AT+JN1DL 809 809 |(% style="width:164px" %)**Command Example**|(% style="width:229px" %)**Function**|(% style="width:140px" %)**Response** ... ... @@ -814,15 +814,14 @@ 814 814 815 815 ))) 816 816 817 - 818 818 == 7.8 Join Accept Delay2 == 819 819 820 - 821 821 Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 2 in ms. 822 822 823 823 824 -(% style="color:blue" %)**AT Command: 848 +(% style="color:blue" %)**AT Command:AT+JN2DL** 825 825 850 + 826 826 (% border="1" style="background-color:#ffffcc; color:green; width:538.222px" %) 827 827 |=(% colspan="3" style="width: 535px;" %)AT+JN2DL 828 828 |(% style="width:160px" %)**Command Example**|(% style="width:228px" %)**Function**|(% style="width:146px" %)**Response** ... ... @@ -833,17 +833,16 @@ 833 833 834 834 ))) 835 835 836 - 837 837 == 7.9 Public Network Mode == 838 838 839 - 840 840 Feature: Get or Set the public network mode. (0: off, 1: on). A Public LoRaWAN network use 0x34 as syncword. Default Settings; PNM=1 841 841 842 - (% style="color:red" %)**Notice: If user build their own LoRaWAN server but still use syncword=0x34, this is still considered a public LoRaWAN network.**865 +Notice: If user build their own LoRaWAN server but still use syncword=0x34, this is still considered a public LoRaWAN network 843 843 844 844 845 -(% style="color:blue" %)**AT Command: 868 +(% style="color:blue" %)**AT Command:AT+PNM** 846 846 870 + 847 847 (% border="1" style="background-color:#ffffcc; color:green; width:667.222px" %) 848 848 |=(% colspan="3" style="width: 664px;" %)AT+PNM 849 849 |(% style="width:166px" %)**Command Example**|(% style="width:225px" %)**Function**|(% style="width:272px" %)**Response** ... ... @@ -861,15 +861,14 @@ 861 861 ))) 862 862 |(% style="width:166px" %)AT+PNM=0|(% style="width:225px" %)Set to use private network autoset syncword=0x12|(% style="width:272px" %) 863 863 864 - 865 865 == 7.10 Receive Delay1 == 866 866 867 - 868 868 Feature: Get or Set the delay between the end of the Tx and the Rx Window 1 in ms 869 869 870 870 871 -(% style="color:blue" %)**AT Command: 893 +(% style="color:blue" %)**AT Command:AT+RX1DL** 872 872 895 + 873 873 (% border="1" style="background-color:#ffffcc; color:green; width:408.222px" %) 874 874 |=(% colspan="3" style="width: 405px;" %)AT+RX1DL 875 875 |(% style="width:155px" %)**Command Example**|(% style="width:128px" %)**Function**|(% style="width:122px" %)**Response** ... ... @@ -880,15 +880,14 @@ 880 880 881 881 ))) 882 882 883 - 884 884 == 7.11 Receive Delay2 == 885 885 886 - 887 887 Feature: Get or Set the delay between the end of the Tx and the Rx Window 2 in ms 888 888 889 889 890 -(% style="color:blue" %)**AT Command: 911 +(% style="color:blue" %)**AT Command:AT+RX2DL** 891 891 913 + 892 892 (% border="1" style="background-color:#ffffcc; color:green; width:481.222px" %) 893 893 |=(% colspan="3" style="width: 478px;" %)AT+RX2DL 894 894 |(% style="width:175px" %)**Command Example**|(% style="width:152px" %)**Function**|(% style="width:150px" %)**Response** ... ... @@ -899,15 +899,14 @@ 899 899 900 900 ))) 901 901 902 - 903 903 == 7.12 Rx2 Window Data Rate == 904 904 905 - 906 906 Feature: Get or Set the Rx2 window data rate (0-7 corresponding to DR_X) 907 907 908 908 909 -(% style="color:blue" %)**AT Command: 929 +(% style="color:blue" %)**AT Command:AT+RX2DR** 910 910 931 + 911 911 (% border="1" style="background-color:#ffffcc; color:green; width:525.222px" %) 912 912 |=(% colspan="3" style="width: 522px;" %)AT+RX2DR 913 913 |(% style="width:160px" %)**Command Example**|(% style="width:232px" %)**Function**|(% style="width:130px" %)**Response** ... ... @@ -918,15 +918,14 @@ 918 918 919 919 ))) 920 920 921 - 922 922 == 7.13 Rx2 Window Frequency == 923 923 924 - 925 925 Feature: Get or Set the Rx2 window frequency 926 926 927 927 928 -(% style="color:blue" %)**AT Command: 947 +(% style="color:blue" %)**AT Command:AT+RX2FQ** 929 929 949 + 930 930 (% border="1" style="background-color:#ffffcc; color:green; width:587.222px" %) 931 931 |=(% colspan="3" style="width: 584px;" %)AT+RX2FQ 932 932 |(% style="width:183px" %)**Command Example**|(% style="width:240px" %)**Function**|(% style="width:160px" %)**Response** ... ... @@ -937,16 +937,13 @@ 937 937 938 938 ))) 939 939 940 - 941 941 == 7.14 Transmit Power == 942 942 943 - 944 944 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. ) 945 945 946 -(% 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** 947 947 965 +(% style="color:blue" %)**AT Command:AT+TXP** 948 948 949 -(% style="color:blue" %)**AT Command: AT+TXP** 950 950 951 951 (% border="1" style="background-color:#ffffcc; color:green; width:465.222px" %) 952 952 |=(% colspan="3" style="width: 462px;" %)AT+TXP ... ... @@ -962,18 +962,17 @@ 962 962 963 963 If the downlink payload=22000100, it means setting the TXP to 0. 964 964 965 -* **Example 1**: Downlink Payload: **22000102** 966 -* **Example 2**: Downlink Payload: **220000FF** 982 +* **Example 1**: Downlink Payload: **22000102** ~/~/ Set AT+TXP=2. 983 +* **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+TXP=0. 967 967 968 - 969 969 == 7.15 RSSI of the Last Received Packet == 970 970 971 - 972 972 Feature: Get or Set the Rx2 window frequency 973 973 974 974 975 975 (% style="color:blue" %)**AT Command:AT+RSSI** 976 976 992 + 977 977 (% border="1" style="background-color:#ffffcc; color:green; width:557.222px" %) 978 978 |=(% colspan="3" style="width: 554px;" %)AT+RSSI 979 979 |(% style="width:164px" %)**Command Example**|(% style="width:289px" %)**Function**|(% style="width:100px" %)**Response** ... ... @@ -981,15 +981,14 @@ 981 981 OK 982 982 ))) 983 983 984 - 985 985 == 7.16 SNR of the Last Received Packet == 986 986 987 - 988 988 Feature: Get the SNR of the last received packet 989 989 990 990 991 -(% style="color:blue" %)**AT Command: 1005 +(% style="color:blue" %)**AT Command:AT+SNR** 992 992 1007 + 993 993 (% border="1" style="background-color:#ffffcc; color:green; width:571.222px" %) 994 994 |=(% colspan="3" style="width: 568px;" %)AT+SNR 995 995 |(% style="width:164px" %)**Command Example**|(% style="width:290px" %)**Function**|(% style="width:113px" %)**Response** ... ... @@ -997,15 +997,14 @@ 997 997 OK 998 998 ))) 999 999 1000 - 1001 1001 == 7.17 Application Port == 1002 1002 1003 - 1004 1004 Feature: Get or set the application port. 1005 1005 1006 1006 1007 1007 (% style="color:blue" %)**AT Command: AT+PORT** 1008 1008 1022 + 1009 1009 (% border="1" style="background-color:#ffffcc; color:green; width:500.222px" %) 1010 1010 |=(% colspan="3" style="width: 497px;" %)AT+PORT 1011 1011 |(% style="width:157px" %)**Command Example**|(% style="width:204px" %)**Function**|(% style="width:135px" %)**Response** ... ... @@ -1016,22 +1016,22 @@ 1016 1016 1017 1017 (% style="color:blue" %)**Downlink Command: 0x23** 1018 1018 1033 + 1019 1019 Format: Command Code (0x23) followed by 1 bytes port value. 1020 1020 1021 1021 If the downlink payload=2301, it means set the application port to 1, while type code is 23. 1022 1022 1023 -* **Example 1**: Downlink Payload: **2301** 1024 -* **Example 2**: Downlink Payload:** 2305** 1038 +* **Example 1**: Downlink Payload: **2301** ~/~/ set the application port to 1 1039 +* **Example 2**: Downlink Payload:** 2305** ~/~/ set the application port to 5 1025 1025 1026 - 1027 1027 == 7.18 Single Channel Mode == 1028 1028 1029 - 1030 1030 Feature:Get or Set Frequency (Unit: Hz) for Single Channel Mode. 1031 1031 1032 1032 1033 1033 (% style="color:blue" %)**AT Command: AT+CHS** 1034 1034 1048 + 1035 1035 (% border="1" style="background-color:#ffffcc; color:green; width:603.222px" %) 1036 1036 |=(% colspan="3" style="width: 600px;" %)AT+CHS 1037 1037 |(% style="width:182px" %)**Command Example**|(% style="width:295px" %)**Function**|(% style="width:122px" %)**Response** ... ... @@ -1040,15 +1040,14 @@ 1040 1040 ))) 1041 1041 |(% style="width:182px" %)AT+CHS=868100000|(% style="width:295px" %)Set Frequency for Single Channel Mode|(% style="width:122px" %)OK 1042 1042 1043 - 1044 1044 == 7.19 Eight Channel Mode == 1045 1045 1046 - 1047 1047 Feature: Get or Set eight channels mode,Only for US915,AU915,CN470. 1048 1048 1049 1049 1050 1050 (% style="color:blue" %)**AT Command: AT+CHE** 1051 1051 1064 + 1052 1052 (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 1053 1053 |=(% colspan="3" style="width: 707px;" %)AT+CHE 1054 1054 |(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response** ... ... @@ -1061,22 +1061,22 @@ 1061 1061 1062 1062 (% style="color:blue" %)**Downlink Command: 0x24** 1063 1063 1077 + 1064 1064 Format: Command Code (0x24) followed by 1 bytes channel value. 1065 1065 1066 1066 If the downlink payload=2401, it means set channel mode to 1, while type code is 24. 1067 1067 1068 -* **Example 1**: Downlink Payload: 2401 1069 -* **Example 2**: Downlink Payload: 2405 1082 +* **Example 1**: Downlink Payload: 2401 ~/~/ set channel mode to 1 1083 +* **Example 2**: Downlink Payload: 2405 ~/~/ set channel mode to 5 1070 1070 1071 - 1072 1072 == 7.20 Get or Set RXwindows1 timeout == 1073 1073 1087 +Feature:Get or Set the number of symbols to detect and timeout from RXwindow1(0 to 255). 1074 1074 1075 -Feature: Get or Set the number of symbols to detect and timeout from RXwindow1(0 to 255). 1076 1076 1077 - 1078 1078 (% style="color:blue" %)**AT Command: AT+RX1WTO** 1079 1079 1092 + 1080 1080 (% border="1" style="background-color:#ffffcc; color:green; width:460.222px" %) 1081 1081 |=(% colspan="3" style="width: 457px;" %)AT+ RX1WTO 1082 1082 |(% style="width:163px" %)**Command Example**|(% style="width:201px" %)**Function**|(% style="width:93px" %)**Response** ... ... @@ -1086,32 +1086,25 @@ 1086 1086 |(% style="width:163px" %)AT+RX1WTO=60|(% style="width:201px" %)Set RXwindows1 timeout|(% style="width:93px" %)OK 1087 1087 1088 1088 ((( 1089 - 1090 - 1091 - 1092 -(% 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. 1093 - 1094 - 1102 +**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. 1095 1095 ))) 1096 1096 1097 1097 [[image:image-20220526162535-1.png]] 1098 1098 1099 - 1100 1100 ((( 1101 1101 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. 1102 1102 1103 - 1104 1104 1105 1105 ))) 1106 1106 1107 1107 == 7.21 Get or Set RXwindows2 timeout == 1108 1108 1115 +Feature:Get or Set the number of symbols to detect and timeout from RXwindow2(0 to 255). 1109 1109 1110 -Feature: Get or Set the number of symbols to detect and timeout from RXwindow2(0 to 255). 1111 1111 1112 - 1113 1113 (% style="color:blue" %)**AT Command: AT+RX2WTO** 1114 1114 1120 + 1115 1115 (% border="1" style="background-color:#ffffcc; color:green; width:497.222px" %) 1116 1116 |=(% colspan="3" style="width: 494px;" %)AT+ RX2WTO 1117 1117 |(% style="width:190px" %)**Command Example**|(% style="width:199px" %)**Function**|(% style="width:104px" %)**Response** ... ... @@ -1120,15 +1120,14 @@ 1120 1120 ))) 1121 1121 |(% style="width:190px" %)AT+RX2WTO=20|(% style="width:199px" %)Set RXwindows2 timeout|(% style="width:104px" %)OK 1122 1122 1123 - 1124 1124 == 7.22 Setting up uplinkdwelltime (as923, au915) == 1125 1125 1126 - 1127 1127 Feature: Get or Set uplinkdwelltime 1128 1128 1129 1129 1130 1130 (% style="color:blue" %)**AT Command: AT+DWELLT** 1131 1131 1136 + 1132 1132 (% border="1" style="background-color:#ffffcc; color:green; width:497.222px" %) 1133 1133 |=(% colspan="3" style="width: 494px;" %)AT+DWELLT 1134 1134 |(% style="width:183px" %)**Command Example**|(% style="width:179px" %)**Function**|(% style="width:131px" %)**Response** ... ... @@ -1139,22 +1139,20 @@ 1139 1139 1140 1140 (% style="color:blue" %)**Downlink Command: 0x25** 1141 1141 1147 + 1142 1142 Format: Command Code (0x25) followed by 1 bytes state value. 1143 1143 1144 1144 If the downlink payload=2501, it means set uplinkdwelltime to 1, while type code is 25. 1145 1145 1146 -* **Example 1**: Downlink Payload: **2501** 1147 -* **Example 2**: Downlink Payload: **2500** 1152 +* **Example 1**: Downlink Payload: **2501** ~/~/ set uplinkdwelltime to 1 1153 +* **Example 2**: Downlink Payload: **2500** ~/~/ set uplinkdwelltime to 0 1148 1148 1149 - 1150 1150 == 7.23 Set Packet Receiving Response Level == 1151 1151 1152 - 1153 1153 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. 1154 1154 1159 +RPL value: 1155 1155 1156 -**RPL value:** 1157 - 1158 1158 * **AT+RPL=0:** Device won't immediately reply any downlink commands from platform. 1159 1159 * **AT+RPL=1:** Device will immediately reply message to Unconfirmed Data Down. Payload is 0x00. 1160 1160 * **AT+RPL=2:** Device will immediately reply message to Confirmed Data Down. Payload is 0x00 and requied response header for this command. ... ... @@ -1161,7 +1161,7 @@ 1161 1161 * **AT+RPL=3:** Device will immediately reply message to MAC Command. Payload is 0x00 and requied response header for this command. 1162 1162 * **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. 1163 1163 1164 - **Case Analyes:**1167 +Case Analyes: 1165 1165 1166 1166 * For Class A devices, AT+RPL=0 is ok. that is defaut settings in software. 1167 1167 * For Class C devices used in ChirpStack, need to set AT+RPL=4 because Chirpstack require immedietely reply message to MAC Command. ... ... @@ -1169,6 +1169,7 @@ 1169 1169 1170 1170 (% style="color:blue" %)**AT Command: AT+RPL** 1171 1171 1175 + 1172 1172 (% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %) 1173 1173 |=(% colspan="3" style="width: 533px;" %)AT+RPL 1174 1174 |(% style="width:160px" %)**Command Example**|(% style="width:263px" %)**Function**|(% style="width:109px" %)**Response** ... ... @@ -1179,30 +1179,27 @@ 1179 1179 1180 1180 (% style="color:blue" %)**Downlink Command: 0x21** 1181 1181 1186 + 1182 1182 Format: Command Code (0x21) followed by 1 bytes level value. 1183 1183 1184 1184 If the downlink payload=2101, it means set packet receiving response level to 1, while type code is 21. 1185 1185 1186 -* **Example 1**: Downlink Payload: **2101** 1187 -* **Example 2**: Downlink Payload: **2102** 1191 +* **Example 1**: Downlink Payload: **2101** ~/~/ set packet receiving response level to 1 1192 +* **Example 2**: Downlink Payload: **2102** ~/~/ set packet receiving response level to 2 1188 1188 1189 - 1190 1190 == 7.24 Controls NBTrans in unconfirmed uplink mode(LWS007 NBTrans:Set retransmission packets) == 1191 1191 1192 1192 1193 1193 (% style="color:blue" %)**AT Command: AT+SETMAXNBTRANS ** 1194 1194 1195 -(% border="1" style="background-color:#ffffcc; color:green; width:589px" %) 1196 -|=(% colspan="3" style="width: 586px;" %)AT+**SETMAXNBTRANS** 1197 -|(% style="width:227px" %)**Command Example**|(% style="width:300px" %)**Function**|(% style="width:87px" %)**Response** 1198 -|(% style="width:227px" %)**AT+SETMAXNBTRANS=1,0**|(% style="width:300px" %)Value1: set the maximum NBTrans.|(% style="width:87px" %)1((( 1199 + 1200 +(% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %) 1201 +|=(% colspan="3" style="width: 533px;" %)AT+**SETMAXNBTRANS** 1202 +|(% style="width:160px" %)**Command Example**|(% style="width:263px" %)**Function**|(% style="width:109px" %)**Response** 1203 +|(% style="width:160px" %)**AT+SETMAXNBTRANS=1,0**|(% style="width:263px" %)Value1: set the maximum NBTrans.|(% style="width:109px" %)1((( 1199 1199 OK 1200 1200 ))) 1201 -|(% style="width:227px" %)**AT+SETMAXNBTRANS=?,1**|(% style="width:300px" %)((( 1202 -value2: 0: uplink fcnt doesn't change for each NBTrans; 1203 - 1204 -1: uplink fcnt increase by 1 for each NBTrans. 1205 -)))|(% style="width:87px" %)((( 1206 +|(% style="width:160px" %)**AT+SETMAXNBTRANS=?,1**|(% style="width:263px" %)value2: 0: uplink fcnt doesn't change for each NBTrans; 1: uplink fcnt increase by 1 for each NBTrans.|(% style="width:109px" %)((( 1206 1206 1 1207 1207 1208 1208 OK ... ... @@ -1210,19 +1210,20 @@ 1210 1210 1211 1211 (% style="color:blue" %)**Downlink Command: 0x33** 1212 1212 1214 + 1213 1213 Format: Command Code (0x33) followed by 2 bytes mode value. 1214 1214 1215 1215 If the downlink payload=330100, it means set end node to use confirm mode, while type code is 33. 1216 1216 1217 -* Example 1: Downlink Payload: 330100 1218 -* Example 2: Downlink Payload: 330201 1219 +* Example 1: Downlink Payload: 330100 ~/~/ Set AT+SETMAXNBTRANS=1,0 1220 +* Example 2: Downlink Payload: 330201 ~/~/ Set AT+SETMAXNBTRANS=2,1 1219 1219 1220 - 1221 1221 == 7.25 Device offline rejoining (LWS007) == 1222 1222 1223 1223 1224 1224 (% style="color:blue" %)**AT Command: AT+DDETECT** 1225 1225 1227 + 1226 1226 (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 1227 1227 |=(% colspan="3" style="width: 707px;" %)AT+**DDETECT** 1228 1228 |(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response** ... ... @@ -1256,18 +1256,19 @@ 1256 1256 1257 1257 (% style="color:blue" %)**Downlink Command: 0x33** 1258 1258 1261 + 1259 1259 Format: Command Code (0x32) followed by 2 bytes mode value. 1260 1260 1261 1261 If the downlink payload=320105A00B40, it means set end node to use confirm mode, while type code is 33. 1262 1262 1263 -* **Example 1:**Downlink Payload: 320105A00B401266 +* Example 1: Downlink Payload: 320105A00B40 ~/~/ Set AT+DDETECT=1,1440,2880 1264 1264 1265 - 1266 1266 == 7.26 Request the server to send an ACK == 1267 1267 1268 1268 1269 1269 (% style="color:blue" %)**AT Command: AT+PNACKMD** 1270 1270 1273 + 1271 1271 (% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %) 1272 1272 |=(% colspan="3" style="width: 533px;" %)**AT+PNACKMD** 1273 1273 |(% style="width:160px" %)**Command Example**|(% style="width:263px" %)**Function**|(% style="width:109px" %)**Response** ... ... @@ -1280,12 +1280,12 @@ 1280 1280 OK 1281 1281 ))) 1282 1282 1283 - 1284 1284 == 7.27 Adjust network rejoining interval == 1285 1285 1286 1286 1287 1287 (% style="color:blue" %)**AT Command: AT+RJTDC** 1288 1288 1291 + 1289 1289 (% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %) 1290 1290 |=(% colspan="3" style="width: 724px;" %)AT+RJTDC 1291 1291 |(% style="width:165px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:329px" %)**Response** ... ... @@ -1300,32 +1300,29 @@ 1300 1300 1301 1301 (% style="color:blue" %)**Downlink Command: 0x26** 1302 1302 1306 + 1303 1303 Format: Command Code (0x26) followed by 2 bytes mode value. 1304 1304 1305 1305 If the downlink payload=26000A, it means set end node to use confirm mode, while type code is 26. 1306 1306 1307 -* **Example 1:**Downlink Payload: 26000A1308 -* **Example 2:**Downlink Payload: 2600021311 +* Example 1: Downlink Payload: 26000A ~/~/ Set AT+RJTDC=10 1312 +* Example 2: Downlink Payload: 260002 ~/~/ Set AT+RJTDC=2 1309 1309 1310 - 1311 1311 = 8. AT Commands Combination = 1312 1312 1313 1313 == 8.1 Set a fix RX2DR for downlink window == 1314 1314 1318 +* **AT+ADR=0 **~-~-> Disable ADR first 1319 +* **AT+RX2DR=xxxx** ~-~-> Set xxxx to your wanted DataRate 1315 1315 1316 -* (% style="color:blue" %)**AT+ADR=0 **(%%) **~-~->** Disable ADR first 1317 -* (% style="color:blue" %)**AT+RX2DR=xxxx** (%%) **~-~->** Set xxxx to your wanted DataRate 1318 - 1319 - 1320 1320 == 8.2 Use Downlink Command to set a fix uplink DR == 1321 1321 1322 1322 1323 1323 (% style="color:blue" %)**Downlink Command: 0x22000500** 1324 1324 1325 -**Same as:** 1326 1326 1327 -* AT+ADR=0 [[Reference>>||anchor="H7.1AdaptiveDataRate"]] 1328 -* AT+DR=5 [[Reference>>||anchor="H7.4DataRate"]] 1329 -* AT+TXP=0 [[Reference>>||anchor="H7.14TransmitPower"]] 1327 +Same as: 1330 1330 1331 - 1329 +* AT+ADR=0 [[Reference>>||anchor="H7.1AdaptiveDataRate"]] 1330 +* AT+DR=5 [[Reference>>||anchor="H7.4DataRate"]] 1331 +* AT+TXP=0 [[Reference>>||anchor="H7.14TransmitPower"]]