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 - **Contents:** 1 + **Table of** **Contents:** 2 2 3 3 {{toc/}} 4 4 ... ... @@ -6,6 +6,7 @@ 6 6 7 7 = 1. Introduction = 8 8 9 + 9 9 Dragino LoRaWAN End Node support two types of AT Commands and Downlink Commands: 10 10 11 11 * **Common Commands:** They should be available for each sensor, such as: change uplink interval, reset device. ... ... @@ -18,6 +18,7 @@ 18 18 19 19 = 2. How to use AT Commands or Downlink command = 20 20 22 + 21 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 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: 23 23 ** Use HEX format to send a downlink: [[TTN v3>>Notes for TTN]] ... ... @@ -24,8 +24,11 @@ 24 24 ** Use Base64 format to send a downlink: [[Chirpstack>>Notes for ChirpStack]] 25 25 ** See use note for more serves [[Servers Note>>doc:Main.WebHome]](IoT LoRaWAN Server) 26 26 29 + 30 + 27 27 = 3. Support End Node and firmware version = 28 28 33 + 29 29 (% border="1" style="background-color:#ffffcc; color:green; width:966px" %) 30 30 |=(% colspan="3" style="width: 963px;" %)((( 31 31 Dragino STM32 base hardware Firmware / LoRaWAN stack list ... ... @@ -98,10 +98,13 @@ 98 98 ))) 99 99 100 100 106 + 101 101 = 4. System Management Commands = 102 102 109 + 103 103 == 4.1 Change Uplink Interval == 104 104 112 + 105 105 Feature: Change LoRaWAN End Node Transmit Interval. 106 106 107 107 (% class="box infomessage" %) ... ... @@ -137,6 +137,7 @@ 137 137 * **Example 2**: Downlink Payload:** 0100003C** ~/~/ Set Transmit Interval (TDC) = 60 seconds 138 138 139 139 148 + 140 140 == 4.2 Reboot End Node == 141 141 142 142 Feature: Reboot End Node to perform a new OTAA or ABP Join. ... ... @@ -298,7 +298,6 @@ 298 298 OK 299 299 ))) 300 300 301 - 302 302 = 5. Keys, IDs and EUIs management = 303 303 304 304 == 5.1 Application EUI == ... ... @@ -317,7 +317,6 @@ 317 317 ))) 318 318 |(% style="width:305px" %)AT+APPEUI=00 b3 d5 7e f0 00 4d 34|(% style="width:186px" %)Set the Application EUI|(% style="width:191px" %)OK 319 319 320 - 321 321 == 5.2 Application Key == 322 322 323 323 Feature: Get or Set the Application Key. ... ... @@ -424,6 +424,8 @@ 424 424 425 425 == 6.1 Confirm Mode == 426 426 434 +=== AT+CFM command before DR-LWS007 software stack === 435 + 427 427 Feature: Get or Set the confirmation mode (0-1). 428 428 429 429 {{info}} ... ... @@ -448,6 +448,54 @@ 448 448 * Example 1: Downlink Payload: 0501 ~/~/ Set AT+CFM=1 449 449 * Example 2: Downlink Payload: 0500 ~/~/ Set AT+CFM=0 450 450 460 +=== AT+CFM command since DR-LWS007 software stack === 461 + 462 +{{info}} 463 +**AT Command: AT+CFM** 464 +{{/info}} 465 + 466 +(% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 467 +|=(% colspan="3" style="width: 707px;" %)AT+CFM 468 +|(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response** 469 +|(% style="width:160px" %)((( 470 +AT+CFM=1,0,0 471 + 472 +value1 473 +)))|(% style="width:198px" %)confirmed uplink|(% style="width:349px" %)((( 474 +1 475 + 476 +OK 477 +))) 478 +|(% style="width:160px" %)((( 479 +AT+CFM=0,?,0 480 + 481 +value2 482 +)))|(% style="width:198px" %)set max retry , range: 0 ~~ 7|(% style="width:349px" %)((( 483 +0~~7 484 + 485 +OK 486 +))) 487 +|(% style="width:160px" %)((( 488 +AT+CFM=0,0,1 489 + 490 +value3 491 +)))|(% style="width:198px" %)uplink fcnt increase by 1 for each retry|(% style="width:349px" %)((( 492 +1 493 + 494 +OK 495 +))) 496 + 497 +{{info}} 498 +**Downlink Command: 0x05** 499 +{{/info}} 500 + 501 +Format: Command Code (0x05) followed by 2 bytes mode value. 502 + 503 +If the downlink payload=05010101, it means set end node to use confirm mode, while type code is 05. 504 + 505 +* Example 1: Downlink Payload: 05010101 ~/~/ Set AT+CFM=1,1,1 506 +* Example 2: Downlink Payload: 05000700 ~/~/ Set AT+CFM=0,7,0 507 + 451 451 == 6.2 Confirm Status == 452 452 453 453 Feature: Get confirmation status of the last AT+SEND (0-1). ... ... @@ -463,8 +463,6 @@ 463 463 OK 464 464 ))) 465 465 466 - 467 - 468 468 == 6.3 Join LoRa® Network == 469 469 470 470 Feature: Join network. ... ... @@ -482,7 +482,6 @@ 482 482 While Error in format, return AT_BUSY_ERROR 483 483 ))) 484 484 485 - 486 486 == 6.4 LoRa® Network Join Mode == 487 487 488 488 Feature: Get or Set the Network Join Mode. (0: ABP, 1: OTAA). ... ... @@ -508,10 +508,9 @@ 508 508 509 509 If the downlink payload=2000, it means set the Network Join Mode, while type code is 20. 510 510 511 -* **Example 1: **Downlink Payload: **2000** ~/~/ Set AT+NJM= O565 +* **Example 1: **Downlink Payload: **2000** ~/~/ Set AT+NJM=0 512 512 * **Example 2:** Downlink Payload: **2001** ~/~/ Set AT+NJM=1 513 513 514 - 515 515 == 6.5 LoRa® Network Join Status == 516 516 517 517 Feature: LoRa® Network Join Status. ... ... @@ -527,7 +527,6 @@ 527 527 OK 528 528 ))) 529 529 530 - 531 531 == 6.6 Print Last Received Data in Raw Format == 532 532 533 533 Feature: Print Last Received Data in Raw Format<port:data>. ... ... @@ -543,7 +543,6 @@ 543 543 OK 544 544 ))) 545 545 546 - 547 547 == 6.7 Print Last Received Data in Binary Format == 548 548 549 549 Feature: Print Last Received Data in Binary Format<port:data>. ... ... @@ -559,7 +559,6 @@ 559 559 OK 560 560 ))) 561 561 562 - 563 563 == 6.8 Send Text Data == 564 564 565 565 Feature: Send Text Data<port:data>. ... ... @@ -579,7 +579,6 @@ 579 579 580 580 ))) 581 581 582 - 583 583 == 6.9 Send Hexadecimal Data == 584 584 585 585 Feature: Send hexadecimal data along with the application port. ... ... @@ -598,7 +598,6 @@ 598 598 599 599 ))) 600 600 601 - 602 602 = 7. LoRaWAN network management = 603 603 604 604 == 7.1 Adaptive Data Rate == ... ... @@ -630,7 +630,6 @@ 630 630 * **Example 1**: Downlink Payload: **2201** ~/~/ Set AT+ADR=1. 631 631 * **Example 2**: Downlink Payload: **2200FFFF** ~/~/ Set AT+ADR=0. 632 632 633 - 634 634 == 7.2 LoRa® Class == 635 635 636 636 Feature: Get or Set the Device Class(Currently only support class A, class C). ... ... @@ -649,7 +649,6 @@ 649 649 650 650 ))) 651 651 652 - 653 653 == 7.3 Duty Cycle Setting == 654 654 655 655 Feature: Get or Set the ETSI Duty Cycle setting - 0=disable, 1=enable - Only for testing. ... ... @@ -668,7 +668,6 @@ 668 668 669 669 ))) 670 670 671 - 672 672 == 7.4 Data Rate == 673 673 674 674 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 ... ... @@ -697,7 +697,6 @@ 697 697 * **Example 1**: Downlink Payload: **220001FF** ~/~/ Set AT+DR=1. 698 698 * **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+DR=0. 699 699 700 - 701 701 == 7.5 Frame Counter Downlink == 702 702 703 703 Feature: Get or Set the Frame Counter Downlink. ... ... @@ -718,7 +718,6 @@ 718 718 719 719 ))) 720 720 721 - 722 722 == 7.6 Frame Counter Uplink == 723 723 724 724 Feature: Get or Set the Frame Counter Uplink. ... ... @@ -737,7 +737,6 @@ 737 737 738 738 ))) 739 739 740 - 741 741 == 7.7 Join Accept Delay1 == 742 742 743 743 Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 1 in ms. ... ... @@ -756,7 +756,6 @@ 756 756 757 757 ))) 758 758 759 - 760 760 == 7.8 Join Accept Delay2 == 761 761 762 762 Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 2 in ms. ... ... @@ -775,11 +775,12 @@ 775 775 776 776 ))) 777 777 778 - 779 779 == 7.9 Public Network Mode == 780 780 781 -Feature: Get or Set the public network mode. (0: off, 1: on) 821 +Feature: Get or Set the public network mode. (0: off, 1: on). A Public LoRaWAN network use 0x34 as syncword. Default Settings; PNM=1 782 782 823 +Notice: If user build their own LoRaWAN server but still use syncword=0x34, this is still considered a public LoRaWAN network 824 + 783 783 {{info}} 784 784 **AT Command:AT+PNM** 785 785 {{/info}} ... ... @@ -790,13 +790,17 @@ 790 790 |(% style="width:166px" %)AT+PNM=?|(% style="width:225px" %)Get the public network mode.|(% style="width:272px" %)1((( 791 791 OK 792 792 ))) 793 -|(% style="width:166px" %)AT+PNM=1|(% style="width:225px" %)Set the public network mode.|(% style="width:272px" %)(System will write new value to PNM)((( 835 +|(% style="width:166px" %)AT+PNM=1|(% style="width:225px" %)((( 836 +Set the public network mode. 837 + 838 +Set syncword=0x34 839 +)))|(% style="width:272px" %)(System will write new value to PNM)((( 794 794 OK 795 795 796 796 797 797 ))) 844 +|(% style="width:166px" %)AT+PNM=0|(% style="width:225px" %)Set to use private network autoset syncword=0x12|(% style="width:272px" %) 798 798 799 - 800 800 == 7.10 Receive Delay1 == 801 801 802 802 Feature: Get or Set the delay between the end of the Tx and the Rx Window 1 in ms ... ... @@ -815,7 +815,6 @@ 815 815 816 816 ))) 817 817 818 - 819 819 == 7.11 Receive Delay2 == 820 820 821 821 Feature: Get or Set the delay between the end of the Tx and the Rx Window 2 in ms ... ... @@ -834,7 +834,6 @@ 834 834 835 835 ))) 836 836 837 - 838 838 == 7.12 Rx2 Window Data Rate == 839 839 840 840 Feature: Get or Set the Rx2 window data rate (0-7 corresponding to DR_X) ... ... @@ -853,7 +853,6 @@ 853 853 854 854 ))) 855 855 856 - 857 857 == 7.13 Rx2 Window Frequency == 858 858 859 859 Feature: Get or Set the Rx2 window frequency ... ... @@ -872,7 +872,6 @@ 872 872 873 873 ))) 874 874 875 - 876 876 == 7.14 Transmit Power == 877 877 878 878 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. ) ... ... @@ -898,7 +898,6 @@ 898 898 * **Example 1**: Downlink Payload: **22000102** ~/~/ Set AT+TXP=2. 899 899 * **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+TXP=0. 900 900 901 - 902 902 == 7.15 RSSI of the Last Received Packet == 903 903 904 904 Feature: Get or Set the Rx2 window frequency ... ... @@ -914,7 +914,6 @@ 914 914 OK 915 915 ))) 916 916 917 - 918 918 == 7.16 SNR of the Last Received Packet == 919 919 920 920 Feature: Get the SNR of the last received packet ... ... @@ -930,7 +930,6 @@ 930 930 OK 931 931 ))) 932 932 933 - 934 934 == 7.17 Application Port == 935 935 936 936 Feature: Get or set the application port. ... ... @@ -958,7 +958,6 @@ 958 958 * **Example 1**: Downlink Payload: **2301** ~/~/ set the application port to 1 959 959 * **Example 2**: Downlink Payload:** 2305** ~/~/ set the application port to 5 960 960 961 - 962 962 == 7.18 Single Channel Mode == 963 963 964 964 Feature:Get or Set Frequency (Unit: Hz) for Single Channel Mode. ... ... @@ -975,7 +975,6 @@ 975 975 ))) 976 976 |(% style="width:182px" %)AT+CHS=868100000|(% style="width:295px" %)Set Frequency for Single Channel Mode|(% style="width:122px" %)OK 977 977 978 - 979 979 == 7.19 Eight Channel Mode == 980 980 981 981 Feature: Get or Set eight channels mode,Only for US915,AU915,CN470. ... ... @@ -1005,7 +1005,6 @@ 1005 1005 * **Example 1**: Downlink Payload: 2401 ~/~/ set channel mode to 1 1006 1006 * **Example 2**: Downlink Payload: 2405 ~/~/ set channel mode to 5 1007 1007 1008 - 1009 1009 == 7.20 Get or Set RXwindows1 timeout == 1010 1010 1011 1011 Feature:Get or Set the number of symbols to detect and timeout from RXwindow1(0 to 255). ... ... @@ -1050,7 +1050,6 @@ 1050 1050 ))) 1051 1051 |(% style="width:190px" %)AT+RX2WTO=20|(% style="width:199px" %)Set RXwindows2 timeout|(% style="width:104px" %)OK 1052 1052 1053 - 1054 1054 == 7.22 Setting up uplinkdwelltime (as923, au915) == 1055 1055 1056 1056 Feature: Get or Set uplinkdwelltime ... ... @@ -1078,7 +1078,6 @@ 1078 1078 * **Example 1**: Downlink Payload: **2501** ~/~/ set uplinkdwelltime to 1 1079 1079 * **Example 2**: Downlink Payload: **2500** ~/~/ set uplinkdwelltime to 0 1080 1080 1081 - 1082 1082 == 7.23 Set Packet Receiving Response Level == 1083 1083 1084 1084 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. ... ... @@ -1120,7 +1120,129 @@ 1120 1120 * **Example 1**: Downlink Payload: **2101** ~/~/ set packet receiving response level to 1 1121 1121 * **Example 2**: Downlink Payload: **2102** ~/~/ set packet receiving response level to 2 1122 1122 1157 +== 7.24 Controls NBTrans in unconfirmed uplink mode(LWS007 NBTrans:Set retransmission packets) == 1123 1123 1159 +{{info}} 1160 +**AT Command: AT+SETMAXNBTRANS ** 1161 +{{/info}} 1162 + 1163 +(% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %) 1164 +|=(% colspan="3" style="width: 533px;" %)AT+**SETMAXNBTRANS** 1165 +|(% style="width:160px" %)**Command Example**|(% style="width:263px" %)**Function**|(% style="width:109px" %)**Response** 1166 +|(% style="width:160px" %)**AT+SETMAXNBTRANS=1,0**|(% style="width:263px" %)Value1: set the maximum NBTrans.|(% style="width:109px" %)1((( 1167 +OK 1168 +))) 1169 +|(% 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" %)((( 1170 +1 1171 + 1172 +OK 1173 +))) 1174 + 1175 +{{info}} 1176 +**Downlink Command: 0x33** 1177 +{{/info}} 1178 + 1179 +Format: Command Code (0x33) followed by 2 bytes mode value. 1180 + 1181 +If the downlink payload=330100, it means set end node to use confirm mode, while type code is 33. 1182 + 1183 +* Example 1: Downlink Payload: 330100 ~/~/ Set AT+SETMAXNBTRANS=1,0 1184 +* Example 2: Downlink Payload: 330201 ~/~/ Set AT+SETMAXNBTRANS=2,1 1185 + 1186 +== 7.25 Device offline rejoining (LWS007) == 1187 + 1188 +{{info}} 1189 +**AT Command: AT+DDETECT** 1190 +{{/info}} 1191 + 1192 +(% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 1193 +|=(% colspan="3" style="width: 707px;" %)AT+**DDETECT** 1194 +|(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response** 1195 +|(% style="width:160px" %)((( 1196 +AT+DDETECT=1,1440,2880 1197 + 1198 +value1 1199 +)))|(% style="width:198px" %)Enable online detect|(% style="width:349px" %)((( 1200 +1 1201 + 1202 +OK 1203 +))) 1204 +|(% style="width:160px" %)((( 1205 +AT+DDETECT=1,?,2880 1206 + 1207 +value2 1208 +)))|(% style="width:198px" %)Online detection packet sending time|(% style="width:349px" %)((( 1209 + 1210 + 1211 +OK 1212 +))) 1213 +|(% style="width:160px" %)((( 1214 +AT+DDETECT=1,1440,? 1215 + 1216 +value3 1217 +)))|(% style="width:198px" %)Process rejoin|(% style="width:349px" %)((( 1218 + 1219 + 1220 +OK 1221 +))) 1222 + 1223 +{{info}} 1224 +**Downlink Command: 0x33** 1225 +{{/info}} 1226 + 1227 +Format: Command Code (0x32) followed by 2 bytes mode value. 1228 + 1229 +If the downlink payload=320105A00B40, it means set end node to use confirm mode, while type code is 33. 1230 + 1231 +* Example 1: Downlink Payload: 320105A00B40 ~/~/ Set AT+DDETECT=1,1440,2880 1232 + 1233 +== 7.26 Request the server to send an ACK == 1234 + 1235 +{{info}} 1236 +**AT Command: AT+PNACKMD** 1237 +{{/info}} 1238 + 1239 +(% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %) 1240 +|=(% colspan="3" style="width: 533px;" %)**AT+PNACKMD** 1241 +|(% style="width:160px" %)**Command Example**|(% style="width:263px" %)**Function**|(% style="width:109px" %)**Response** 1242 +|(% 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((( 1243 +OK 1244 +))) 1245 +|(% style="width:160px" %)**AT+PNACKMD=0**|(% style="width:263px" %)off request the server to send an ACK|(% style="width:109px" %)((( 1246 +0 1247 + 1248 +OK 1249 +))) 1250 + 1251 +== 7.27 Adjust network rejoining interval == 1252 + 1253 +{{info}} 1254 +**AT Command: AT+RJTDC** 1255 +{{/info}} 1256 + 1257 +(% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %) 1258 +|=(% colspan="3" style="width: 724px;" %)AT+RJTDC 1259 +|(% style="width:165px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:329px" %)**Response** 1260 +|(% style="width:165px" %)AT+RJTDC=?|(% style="width:227px" %)Show the ReJoin data transmission interval in min|(% style="width:329px" %)30000((( 1261 +OK 1262 + 1263 +the interval is 30000ms = 30s 1264 +))) 1265 +|(% style="width:165px" %)AT+RJTDC=60000|(% style="width:227px" %)Set the ReJoin data transmission interval in min|(% style="width:329px" %)OK((( 1266 +Set the ReJoin data transmission interval to 60000ms = 60 seconds 1267 +))) 1268 + 1269 +{{info}} 1270 +**Downlink Command: 0x26** 1271 +{{/info}} 1272 + 1273 +Format: Command Code (0x26) followed by 2 bytes mode value. 1274 + 1275 +If the downlink payload=26000A, it means set end node to use confirm mode, while type code is 26. 1276 + 1277 +* Example 1: Downlink Payload: 26000A ~/~/ Set AT+RJTDC=10 1278 +* Example 2: Downlink Payload: 260002 ~/~/ Set AT+RJTDC=2 1279 + 1124 1124 = 8. AT Commands Combination = 1125 1125 1126 1126 == 8.1 Set a fix RX2DR for downlink window == ... ... @@ -1128,7 +1128,6 @@ 1128 1128 * **AT+ADR=0 **~-~-> Disable ADR first 1129 1129 * **AT+RX2DR=xxxx** ~-~-> Set xxxx to your wanted DataRate 1130 1130 1131 - 1132 1132 == 8.2 Use Downlink Command to set a fix uplink DR == 1133 1133 1134 1134 {{info}} ... ... @@ -1140,3 +1140,4 @@ 1140 1140 * AT+ADR=0 [[Reference>>||anchor="H7.1AdaptiveDataRate"]] 1141 1141 * AT+DR=5 [[Reference>>||anchor="H7.4DataRate"]] 1142 1142 * AT+TXP=0 [[Reference>>||anchor="H7.14TransmitPower"]] 1298 +~)~)~)