Version 38.75 by Xiaoling on 2022/05/31 09:18

Show last authors
1 **Contents:**
2
3 {{toc/}}
4
5
6
7 = 1. Introduction =
8
9 Dragino LoRaWAN End Node support two types of AT Commands and Downlink Commands:
10
11 * **Common Commands:** They should be available for each sensor, such as: change uplink interval, reset device.
12 * **Sensor Related Commands:** Only for special sensor, such as control relay, poll RS485 device.
13
14 (((
15 **This page shows the common commands since Dragino LoRaWAN stack DR-LWS-005. Make sure the end node support stack higher than DR-LWS-005 before checking this page.**
16
17 )))
18
19 = 2. How to use AT Commands or Downlink command =
20
21 * For AT Command , See Devices User Manual for Device. The user manual can be found in each product page of [[Dragino Official Website>>url:http://www.dragino.com/]]
22 * For LoRaWAN Downlink: The gateway transfer downlink command in HEX format. This page shows the HEX format downlink code for each command. but some servers use base64 as downlink code. Below are reference for how to use downlink command:
23 ** Use HEX format to send a downlink: [[TTN v3>>Notes for TTN]]
24 ** Use Base64 format to send a downlink: [[Chirpstack>>Notes for ChirpStack]]
25 ** See use note for more serves [[Servers Note>>doc:Main.WebHome]](IoT LoRaWAN Server)
26
27 = 3. Support End Node and firmware version =
28
29 (% border="1" style="background-color:#ffffcc; color:green; width:966px" %)
30 |=(% colspan="3" style="width: 963px;" %)(((
31 Dragino STM32 base hardware Firmware / LoRaWAN stack list
32 )))
33 |(% style="width:187px" %)(((
34 **Model**
35 )))|(% style="width:330px" %)(((
36 **Description**
37 )))|(% style="width:445px" %)(((
38 **Firmware Version <~-~-> Stack Version**
39 )))
40 |(% style="width:187px" %)(((
41 [[LSN50-v1>>url:http://www.dragino.com/products/lora-lorawan-end-node/item/128-lsn50.html]], [[LSN50-V2>>url:http://www.dragino.com/products/lora-lorawan-end-node/item/155-lsn50-v2.html]],
42 )))|(% style="width:330px" %)(((
43 Open Source Generic LoRaWAN Sensor Node
44 )))|(% style="width:445px" %)(((
45 (((
46 LSN50 v1.6.0 <~-~-> DR-LWS-003;
47 )))
48
49 (((
50 (((
51 LSN50 v1.7.0 <~-~-> DR-LWS-005; ~-~-> Support since this version
52 )))
53 )))
54 )))
55 |(% style="width:187px" %)(((
56 [[LGT92>>url:http://www.dragino.com/products/lora-lorawan-end-node/item/142-lgt-92.html]],
57 )))|(% style="width:330px" %)(((
58 LoRaWAN GPS Tracker
59 )))|(% style="width:445px" %)(((
60 (((
61 LGT92 v1.6.3 <~-~-> DR-LWS-003;
62 )))
63
64 (((
65 (((
66 LGT92 v1.6.4 <~-~-> DR-LWS-005;~-~-> Support since this version
67 )))
68 )))
69 )))
70 |(% style="width:187px" %)(((
71 [[LBT1>>url:http://www.dragino.com/products/lora-lorawan-end-node/item/165-lbt1.html]],
72 )))|(% style="width:330px" %)(((
73 LoRaWAN BLE Indoor Tracker
74 )))|(% style="width:445px" %)(((
75 LBT1 v1.0 <~-~-> DR-LWS-005;
76 )))
77 |(% style="width:187px" %)(((
78 [[RS485-LN>>url:http://www.dragino.com/products/lora-lorawan-end-node/item/154-rs485-ln.html]],
79 )))|(% style="width:330px" %)(((
80 LoRaWAN RS485 Modbus Converter
81 )))|(% style="width:445px" %)(((
82 RS485-LN v1.3 <~-~-> DR-LWS-005;
83 )))
84 |(% style="width:187px" %)(((
85 [[LHT65>>url:http://www.dragino.com/products/lora-lorawan-end-node/item/151-lht65.html]],
86 )))|(% style="width:330px" %)(((
87 LoRaWAN Temperature & Humidity Sensor
88 )))|(% style="width:445px" %)(((
89 (((
90 LHT65 v1.7 <~-~-> DR-LWS-003;
91 )))
92
93 (((
94 (((
95 LHT65 v1.8.0 <~-~-> DR-LWS-005;~-~-> Support since this version
96 )))
97 )))
98 )))
99
100
101 = 4. System Management Commands =
102
103 == 4.1 Change Uplink Interval ==
104
105 Feature: Change LoRaWAN End Node Transmit Interval.
106
107 (% class="box infomessage" %)
108 (((
109 **AT Command: AT+TDC**
110 )))
111
112 (% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %)
113 |=(% colspan="3" style="width: 724px;" %)AT+TDC
114 |(% style="width:165px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:329px" %)**Response**
115 |(% style="width:165px" %)AT+TDC=?|(% style="width:227px" %)Show current transmit Interval|(% style="width:329px" %)30000(((
116 OK
117
118 the interval is 30000ms = 30s
119 )))
120 |(% style="width:165px" %)AT+TDC=60000|(% style="width:227px" %)Set Transmit Interval|(% style="width:329px" %)OK(((
121 Set transmit interval to 60000ms = 60 seconds
122 )))
123
124 {{info}}
125 **Downlink Command: 0x01**
126 {{/info}}
127
128 (((
129 Format: Command Code (0x01) followed by 3 bytes time value.
130 )))
131
132 (((
133 If the downlink payload=0100003C, it means set the END Node’s Transmit Interval to 0x00003C=60(S), while type code is 01.
134 )))
135
136 * **Example 1**: Downlink Payload:** 0100001E** ~/~/ Set Transmit Interval (TDC) = 30 seconds
137 * **Example 2**: Downlink Payload:** 0100003C** ~/~/ Set Transmit Interval (TDC) = 60 seconds
138
139
140 == 4.2 Reboot End Node ==
141
142 Feature: Reboot End Node to perform a new OTAA or ABP Join.
143
144 {{info}}
145 **AT Command: ATZ**
146 {{/info}}
147
148 (% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %)
149 |=(% colspan="3" %)ATZ: Trig a reset of the MCU
150 |**Command Example**|**Function**|**Response**
151 |ATZ|Reset MCU|(((
152 Device reset and show booting info
153
154 LSN50 Device/LoRa ST Module
155
156 Image Version: XX
157
158 Frequency Band: XX
159
160 DevEui= XX XX XX XX XX XX XX XX
161
162 <followed by the Tx and Rx information>
163 )))
164
165 {{info}}
166 **Downlink Command: 0x04**
167 {{/info}}
168
169 (((
170 Format: Command Code (0x04) followed by FF.
171 )))
172
173 (((
174 If the downlink payload=**04FF**, the end node will reboot.
175
176
177 )))
178
179 == 4.3 Reset to factory Default ==
180
181 Feature: Reset the parameters to Factory Default, factory default value depends on the firmware settings, the OTAA and ABP keys will reserve after this command.
182
183 {{info}}
184 **AT Command: AT+FDR**
185 {{/info}}
186
187 (% border="1" style="background-color:#ffffcc; color:green; width:831.222px" %)
188 |=(% colspan="3" style="width: 828px;" %)Reset to factory default
189 |(% style="width:181px" %)**Command Example**|(% style="width:181px" %)**Function**|(% style="width:465px" %)**Response**
190 |(% style="width:181px" %)AT+FDR|(% style="width:181px" %)Reset to factory default|(% style="width:465px" %)(((
191 Device reset to factory default parameters and show booting info
192
193 LSN50 Device/LoRa ST Module
194
195 Image Version: XX
196
197 Frequency Band: XX
198
199 DevEui= XX XX XX XX XX XX XX XX
200
201 Please set the parameters or reset Device to apply change
202 )))
203
204 {{info}}
205 **Downlink Command: 0x04**
206 {{/info}}
207
208 (((
209 Format: Command Code (0x04) followed by FE.
210 )))
211
212 (((
213 If the downlink payload=**04FE**, Reset Parameters to Factory Default, Keys Reserve.
214 )))
215
216
217 == 4.4 Show Firmware Version ==
218
219 Feature: Show firmware version. No downlink command yet.
220
221 {{info}}
222 **AT Command: AT+VER**
223 {{/info}}
224
225 (% border="1" style="background-color:#ffffcc; color:green; width:586px" %)
226 |=(% colspan="3" style="width: 583px;" %)AT+VER: Image Version and Frequency Band
227 |(% style="width:170px" %)**Command Example**|(% style="width:300px" %)**Function**|(% style="width:113px" %)**Response**
228 |(% style="width:170px" %)AT+VER=?|(% style="width:300px" %)Show Image version and Frequency Band|(% style="width:113px" %)(((
229 1.3 EU868
230
231 OK
232 )))
233
234 {{info}}
235 **Downlink Command: 0x26 (Valid in 006 stack)**
236 {{/info}}
237
238 (((
239 Downlink Format: 0x26
240 )))
241
242 (((
243 Device will reply with firmware version info, device info. frequency band info. detail please check device user manual. Total 5 bytes Example: If device is of firmware version 1.1.0 Upload: xx ~-~- yy ~-~- zz ~-~- 110 total 5 bytes
244 )))
245
246 (((
247 **xx: Software Type:**
248 )))
249
250 * 0x00 01: LGT92 Version
251 * 0x00 02: LBT1
252 * 0x00 03: LSE01/LDDS75/LDDS20/LSPH01/LLMS01/LSNPK01
253
254 (((
255 **yy: Frequency Band:**
256 )))
257
258 * 0x01: EU868
259 * 0x02: US915
260 * 0x03: IN865
261 * 0x04: AU915
262 * 0x05: KZ865
263 * 0x06: RU864
264 * 0x07: AS923
265 * 0x08: AS923-1
266 * 0x09: AS923-2
267 * 0xa0: AS923-3
268
269 (((
270 **zz: Subband**
271 )))
272
273 firmware version: v1.1.0 ~-~-> 110
274
275
276 == 4.5 Show System Configure ==
277
278 Feature: Show All configure. No downlink command yet.
279
280 {{info}}
281 **AT Command: AT+CFG**
282 {{/info}}
283
284 (% border="1" style="background-color:#ffffcc; color:green; width:599.222px" %)
285 |=(% colspan="3" style="width: 596px;" %)AT+CFG: Print all configurations
286 |(% style="width:160px" %)**Command Example**|(% style="width:154px" %)**Function**|(% style="width:280px" %)**Response**
287 |(% style="width:160px" %)AT+CFG|(% style="width:154px" %)Show all configures|(% style="width:280px" %)(((
288 AT+DEUI = XX XX XX XX XX XX XX XX
289
290 AT+DADDR=XXXXXXXX
291
292 ……….
293
294 AT+RX2WTO=X
295
296 AT+CHS=868100000
297
298 OK
299 )))
300
301
302 = 5. Keys, IDs and EUIs management =
303
304 == 5.1 Application EUI ==
305
306 Feature: Get or Set the Application EUI.
307
308 {{info}}
309 **AT Command: AT+APPEUI**
310 {{/info}}
311
312 (% border="1" style="background-color:#ffffcc; color:green; width:686.222px" %)
313 |=(% colspan="3" style="width: 683px;" %)AT+APPEUI
314 |(% style="width:305px" %)**Command Example**|(% style="width:186px" %)**Function**|(% style="width:191px" %)**Response**
315 |(% style="width:305px" %)AT+APPEUI=?|(% style="width:186px" %)Get the Application EUI|(% style="width:191px" %)00 b3 d5 00 00 00 00 00(((
316 OK
317 )))
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
320
321 == 5.2 Application Key ==
322
323 Feature: Get or Set the Application Key.
324
325 {{info}}
326 **AT Command: AT+APPKEY**
327 {{/info}}
328
329 (% border="1" style="background-color:#ffffcc; color:green; width:976.222px" %)
330 |=(% colspan="3" style="width: 973px;" %)AT+APPKEY
331 |(% style="width:441px" %)**Command Example**|(% style="width:180px" %)**Function**|(% style="width:350px" %)**Response**
332 |(% style="width:441px" %)AT+APPKEY=?|(% style="width:180px" %)Get the Application Key|(% style="width:350px" %)00 35 55 55 22 23 55 53 43 24 23 42 34 35 35 35(((
333 OK
334 )))
335 |(% style="width:441px" %)AT+APPKEY=00 35 55 55 22 23 55 53 43 24 23 42 34 35 35 35|(% style="width:180px" %)Set the Application Key|(% style="width:350px" %)OK
336
337 == 5.3 Application Session Key ==
338
339 Feature: Get or Set the Application Session Key.
340
341 {{info}}
342 **AT Command: AT+APPSKEY**
343 {{/info}}
344
345 (% border="1" style="background-color:#ffffcc; color:green; width:1040.22px" %)
346 |=(% colspan="3" style="width: 1037px;" %)AT+APPSKEY
347 |(% style="width:451px" %)**Command Example**|(% style="width:231px" %)**Function**|(% style="width:354px" %)**Response**
348 |(% style="width:451px" %)AT+APPSKEY=?|(% style="width:231px" %)Get the Application Session Key|(% style="width:354px" %)00 7d dc 73 33 d3 eb 9e 14 38 d5 a4 3e 62 5b e2(((
349 OK
350 )))
351 |(% style="width:451px" %)AT+APPSKEY=00 7d dc 73 33 d3 eb 9e 14 38 d5 a4 3e 62 5b e2|(% style="width:231px" %)Set the Application Session Key|(% style="width:354px" %)(While Error in format, return AT_PARAM_ERROR)(((
352 OK
353 )))
354
355 == 5.4 Device Address ==
356
357 Feature: Get or Set the Device Address.
358
359 {{info}}
360 **AT Command: AT+DADDR**
361 {{/info}}
362
363 (% border="1" style="background-color:#ffffcc; color:green; width:795.222px" %)
364 |=(% colspan="3" style="width: 792px;" %)AT+DADDR
365 |(% style="width:192px" %)**Command Example**|(% style="width:241px" %)**Function**|(% style="width:359px" %)**Response**
366 |(% style="width:192px" %)AT+DADDR=?|(% style="width:241px" %)Get the Application Session Key.|(% style="width:359px" %)(While Error in format, return AT_PARAM_ERROR)(((
367 A8 40 41 FF
368
369 OK
370 )))
371 |(% style="width:192px" %)AT+DADDR=A8 40 41 FF|(% style="width:241px" %)Set the Application Session Key.|(% style="width:359px" %)OK
372
373 == 5.5 Device EUI ==
374
375 Feature: Get or Set the Device EUI.
376
377 {{info}}
378 **AT Command: AT+DEUI**
379 {{/info}}
380
381 (% border="1" style="background-color:#ffffcc; color:green; width:1035.22px" %)
382 |=(% colspan="3" style="width: 1032px;" %)AT+DEUI
383 |(% style="width:250px" %)**Command Example**|(% style="width:147px" %)**Function**|(% style="width:634px" %)**Response**
384 |(% style="width:250px" %)AT+DEUI=?|(% style="width:147px" %)Get the Device EUI.|(% style="width:634px" %)00 44 34 22 33 45 55 55(((
385 OK
386 )))
387 |(% style="width:250px" %)AT+DEUI=A8 40 41 FF FF 12 34 56|(% style="width:147px" %)Set the Device EUI.|(% style="width:634px" %)(System will write new value to Device EUI,While Error in format, return AT_PARAM_ERROR)(((
388 OK
389 )))
390
391
392
393 == 5.6 Network ID ==
394
395 Feature: Get or Set the Network ID.(You can enter this command change only after successful network connection)
396
397 {{info}}
398 **AT Command: AT+NWKID**
399 {{/info}}
400
401 (% border="1" style="background-color:#ffffcc; color:green; width:448.222px" %)
402 |=(% colspan="3" style="width: 445px;" %)AT+NWKID
403 |(% style="width:191px" %)**Command Example**|(% style="width:153px" %)**Function**|(% style="width:101px" %)**Response**
404 |(% style="width:191px" %)AT+NWKID=?|(% style="width:153px" %)Get the Network ID.|(% style="width:101px" %)a8 40 41 ff(((
405 OK
406 )))
407 |(% style="width:191px" %)AT+NWKID=A8 40 41 FF|(% style="width:153px" %)Set the Network ID.|(% style="width:101px" %)OK
408
409
410
411 == 5.7 Network Session Key ==
412
413 Feature: Get or Set the Network Session Key
414
415 {{info}}
416 **AT Command: AT+NWKSKEY**
417 {{/info}}
418
419 (% border="1" style="background-color:#ffffcc; color:green; width:1017.22px" %)
420 |=(% colspan="3" style="width: 1014px;" %)AT+NWKSKEY
421 |(% style="width:455px" %)**Command Example**|(% style="width:215px" %)**Function**|(% style="width:343px" %)**Response**
422 |(% style="width:455px" %)AT+NWKSKEY=?|(% style="width:215px" %)Get the Network Session Key.|(% style="width:343px" %)00 4f 19 25 52 ce 97 09 d7 fa 84 71 db 51 02 92(((
423 OK
424 )))
425 |(% 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
426
427
428
429 = 6. Joining and sending date on LoRaWAN network =
430
431 == 6.1 Confirm Mode ==
432
433 Feature: Get or Set the confirmation mode (0-1).
434
435 {{info}}
436 **AT Command: AT+CFM**
437 {{/info}}
438
439 (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %)
440 |=(% colspan="3" style="width: 707px;" %)AT+CFM
441 |(% style="width:155px" %)**Command Example**|(% style="width:205px" %)**Function**|(% style="width:346px" %)**Response**
442 |(% style="width:155px" %)AT+CFM=?|(% style="width:205px" %)Get the confirmation mode|(% style="width:346px" %)0(((
443 OK
444 )))
445 |(% style="width:155px" %)AT+CFM=1|(% style="width:205px" %)Set the confirmation mode|(% style="width:346px" %)OK
446 |(% style="width:155px" %)AT+CFM=2|(% style="width:205px" %)Set the confirmation mode|(% style="width:346px" %)While Error in format, return AT_PARAM_ERROR
447
448 Downlink Command: 0x05
449
450 Format: Command Code (0x05) followed by 2 bytes mode value.
451
452 If the downlink payload=0501, it means set end node to use confirm mode, while type code is 05.
453
454 * Example 1: Downlink Payload: 0501 ~/~/ Set AT+CFM=1
455 * Example 2: Downlink Payload: 0500 ~/~/ Set AT+CFM=0
456
457
458
459 == 6.2 Confirm Status ==
460
461 Feature: Get confirmation status of the last AT+SEND (0-1).
462
463 {{info}}
464 **AT Command: AT+CFS**
465 {{/info}}
466
467 (% border="1" style="background-color:#ffffcc; color:green; width:534.222px" %)
468 |=(% colspan="3" style="width: 531px;" %)AT+CFS
469 |(% style="width:156px" %)**Command Example**|(% style="width:193px" %)**Function**|(% style="width:178px" %)**Response**
470 |(% style="width:156px" %)AT+CFS=?|(% style="width:193px" %)Get confirmation status|(% style="width:178px" %)0(((
471 OK
472 )))
473
474
475
476 == 6.3 Join LoRa® Network ==
477
478 Feature: Join network.
479
480 {{info}}
481 **AT Command: AT+JOIN**
482 {{/info}}
483
484 (% border="1" style="background-color:#ffffcc; color:green; width:647.222px" %)
485 |=(% colspan="3" style="width: 644px;" %)AT+JOIN
486 |(% style="width:163px" %)**Command Example**|(% style="width:147px" %)**Function**|(% style="width:334px" %)**Response**
487 |(% style="width:163px" %)AT+JOIN ?|(% style="width:147px" %)Get imformation.|(% style="width:334px" %)AT+JOIN: Join network(((
488 OK
489
490 While Error in format, return AT_BUSY_ERROR
491 )))
492
493
494 == 6.4 LoRa® Network Join Mode ==
495
496 Feature: Get or Set the Network Join Mode. (0: ABP, 1: OTAA).
497
498 {{info}}
499 **AT Command: AT+NJM**
500 {{/info}}
501
502 (% border="1" style="background-color:#ffffcc; color:green; width:753.222px" %)
503 |=(% colspan="3" style="width: 750px;" %)AT+NJM
504 |(% style="width:162px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:361px" %)**Response**
505 |(% style="width:162px" %)AT+NJM=?|(% style="width:227px" %)Get the Network Join Mode|(% style="width:361px" %)1(((
506 OK
507 )))
508 |(% style="width:162px" %)AT+NJM=0|(% style="width:227px" %)Set the Network Join Mode|(% style="width:361px" %)OK
509 |(% 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
510
511 {{info}}
512 **Downlink Command: 0x20**
513 {{/info}}
514
515 Format: Command Code (0x20) followed by 1 bytes mode value.
516
517 If the downlink payload=2000, it means set the Network Join Mode, while type code is 20.
518
519 * **Example 1: **Downlink Payload: **2000** ~/~/ Set AT+NJM=O
520 * **Example 2:** Downlink Payload: **2001** ~/~/ Set AT+NJM=1
521
522
523 == 6.5 LoRa® Network Join Status ==
524
525 Feature: LoRa® Network Join Status.
526
527 {{info}}
528 **AT Command: AT+NJS**
529 {{/info}}
530
531 (% border="1" style="background-color:#ffffcc; color:green; width:498.222px" %)
532 |=(% colspan="3" style="width: 495px;" %)AT+NJS
533 |(% style="width:169px" %)**Command Example**|(% style="width:164px" %)**Function**|(% style="width:161px" %)**Response**
534 |(% style="width:169px" %)AT+NJS=?|(% style="width:164px" %)Get the join status.|(% style="width:161px" %)0(((
535 OK
536 )))
537
538
539 == 6.6 Print Last Received Data in Raw Format ==
540
541 Feature: Print Last Received Data in Raw Format<port:data>.
542
543 {{info}}
544 **AT Command: AT+RECV**
545 {{/info}}
546
547 (% border="1" style="background-color:#ffffcc; color:green; width:587.222px" %)
548 |=(% colspan="3" style="width: 584px;" %)AT+RECV
549 |(% style="width:161px" %)**Command Example**|(% style="width:272px" %)**Function**|(% style="width:150px" %)**Response**
550 |(% style="width:161px" %)AT+RECV=?|(% style="width:272px" %)print last received data in raw format.|(% style="width:150px" %)0:(((
551 OK
552 )))
553
554
555 == 6.7 Print Last Received Data in Binary Format ==
556
557 Feature: Print Last Received Data in Binary Format<port:data>.
558
559 {{info}}
560 **AT Command: AT+RECVB**
561 {{/info}}
562
563 (% border="1" style="background-color:#ffffcc; color:green; width:793.222px" %)
564 |=(% colspan="3" style="width: 790px;" %)AT+RECVB
565 |(% style="width:173px" %)**Command Example**|(% style="width:497px" %)**Function**|(% style="width:120px" %)**Response**
566 |(% style="width:173px" %)AT+RECVB=?|(% style="width:497px" %)print last received data in binary format (with hexadecimal values).|(% style="width:120px" %)2: 0010(((
567 OK
568 )))
569
570
571 == 6.8 Send Text Data ==
572
573 Feature: Send Text Data<port:data>.
574
575 {{info}}
576 **AT Command: AT+SEND**
577 {{/info}}
578
579 (% border="1" style="background-color:#ffffcc; color:green; width:991.222px" %)
580 |=(% colspan="3" style="width: 988px;" %)AT+SEND
581 |(% style="width:201px" %)**Command Example**|(% style="width:340px" %)**Function**|(% style="width:446px" %)**Response**
582 |(% style="width:201px" %)AT+SEND=12:hello world|(% style="width:340px" %)Send text data along with the application port.|(% style="width:446px" %)OK(((
583 While Error in format, return
584
585 AT_BUSY_ERROR/AT_BUSY_ERROR/AT_NO_NETWORK_JOINED
586
587
588 )))
589
590
591 == 6.9 Send Hexadecimal Data ==
592
593 Feature: Send hexadecimal data along with the application port.
594
595 {{info}}
596 **AT Command: AT+SENDB**
597 {{/info}}
598
599 (% border="1" style="background-color:#ffffcc; color:green; width:1120.22px" %)
600 |=(% colspan="3" style="width: 1117px;" %)AT+SENDB
601 |(% style="width:257px" %)**Command Example**|(% style="width:406px" %)**Function**|(% style="width:453px" %)**Response**
602 |(% style="width:257px" %)AT+SENDB=12:abcdef0123456789|(% style="width:406px" %)Send hexadecimal data along with the application port.|(% style="width:453px" %)OK
603 |(% 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(((
604 AT_PARAM_ERROR AT_BUSY_ERROR/AT_NO_NETWORK_JOINED
605
606
607 )))
608
609
610 = 7. LoRaWAN network management =
611
612 == 7.1 Adaptive Data Rate ==
613
614 Feature: Get or Set the Adaptive Data Rate setting. (0: off, 1: on).
615
616 {{info}}
617 **AT Command: AT+ADR**
618 {{/info}}
619
620 (% border="1" style="background-color:#ffffcc; color:green; width:683.222px" %)
621 |=(% colspan="3" style="width: 680px;" %)AT+ADR
622 |(% style="width:162px" %)**Command Example**|(% style="width:266px" %)**Function**|(% style="width:250px" %)**Response**
623 |(% style="width:162px" %)AT+ADR=?|(% style="width:266px" %)Get the Adaptive Data Rate setting.|(% style="width:250px" %)1(((
624 OK
625 )))
626 |(% style="width:162px" %)AT+ADR=0|(% style="width:266px" %)Set the Adaptive Data Rate setting.|(% style="width:250px" %)OK
627 |(% style="width:162px" %)AT+ADR=2|(% style="width:266px" %)Set the Adaptive Data Rate setting.|(% style="width:250px" %)While Error in format, return(((
628 AT_PARAM_ERROR
629 )))
630
631 {{info}}
632 **Downlink Command: 0x22**
633 {{/info}}
634
635
636 If the downlink payload=2201, it means setting the adaptive data rate to 1, while type code is 22.
637
638 * **Example 1**: Downlink Payload: **2201** ~/~/ Set AT+ADR=1.
639 * **Example 2**: Downlink Payload: **2200FFFF** ~/~/ Set AT+ADR=0.
640
641
642 == 7.2 LoRa® Class ==
643
644 Feature: Get or Set the Device Class(Currently only support class A, class C).
645
646 {{info}}
647 **AT Command:AT+CLASS**
648 {{/info}}
649
650 (% border="1" style="background-color:#ffffcc; color:green; width:507.222px" %)
651 |=(% colspan="3" style="width: 504px;" %)AT+CLASS
652 |(% style="width:163px" %)**Command Example**|(% style="width:166px" %)**Function**|(% style="width:175px" %)**Response**
653 |(% style="width:163px" %)AT+CLASS=?|(% style="width:166px" %)Get the Device Class.|(% style="width:175px" %)A(((
654 OK
655 )))
656 |(% style="width:163px" %)AT+CLASS=C|(% style="width:166px" %)Set the Device Class.|(% style="width:175px" %)OK(((
657
658 )))
659
660
661 == 7.3 Duty Cycle Setting ==
662
663 Feature: Get or Set the ETSI Duty Cycle setting - 0=disable, 1=enable - Only for testing.
664
665 {{info}}
666 **AT Command:AT+DCS**
667 {{/info}}
668
669 (% border="1" style="background-color:#ffffcc; color:green; width:515.222px" %)
670 |=(% colspan="3" style="width: 512px;" %)AT+DCS
671 |(% style="width:165px" %)**Command Example**|(% style="width:239px" %)**Function**|(% style="width:107px" %)**Response**
672 |(% style="width:165px" %)AT+DCS=?|(% style="width:239px" %)Get the ETSI Duty Cycle setting.|(% style="width:107px" %)1(((
673 OK
674 )))
675 |(% style="width:165px" %)AT+DCS=1|(% style="width:239px" %)Set the ETSI Duty Cycle setting.|(% style="width:107px" %)OK(((
676
677 )))
678
679
680 == 7.4 Data Rate ==
681
682 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
683
684 {{info}}
685 **AT Command: AT+DR**
686 {{/info}}
687
688 (% border="1" style="background-color:#ffffcc; color:green; width:466.222px" %)
689 |=(% colspan="3" style="width: 463px;" %)AT+DR
690 |(% style="width:156px" %)**Command Example**|(% style="width:167px" %)**Function**|(% style="width:140px" %)**Response**
691 |(% style="width:156px" %)AT+DR=?|(% style="width:167px" %)Get the Data Rate.|(% style="width:140px" %)5(((
692 OK
693 )))
694 |(% style="width:156px" %)AT+DR=2|(% style="width:167px" %)Set the Data Rate.|(% style="width:140px" %)OK(((
695
696 )))
697
698 {{info}}
699 **Downlink Command: 0x2200aaFF**
700 {{/info}}
701
702
703 If the downlink payload=220001FF, it means setting the data rate to 1, while type code is 22 00 aa FF.
704
705 * **Example 1**: Downlink Payload: **220001FF** ~/~/ Set AT+DR=1.
706 * **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+DR=0.
707
708
709 == 7.5 Frame Counter Downlink ==
710
711 Feature: Get or Set the Frame Counter Downlink.
712
713 {{info}}
714 **AT Command:AT+FCD**
715 {{/info}}
716
717 (% border="1" style="background-color:#ffffcc; color:green; width:693.222px" %)
718 |=(% colspan="3" style="width: 690px;" %)AT+FCD
719 |(% style="width:162px" %)**Command Example**|(% style="width:258px" %)**Function**|(% style="width:269px" %)**Response**
720 |(% style="width:162px" %)AT+FCD=?|(% style="width:258px" %)Get the Frame Counter Downlink.|(% style="width:269px" %)0(((
721 OK
722 )))
723 |(% style="width:162px" %)AT+FCD=10|(% style="width:258px" %)Set the Frame Counter Downlink.|(% style="width:269px" %)(System will write new value to FCD)(((
724 OK
725
726
727 )))
728
729
730 == 7.6 Frame Counter Uplink ==
731
732 Feature: Get or Set the Frame Counter Uplink.
733
734 {{info}}
735 **AT Command:AT+FCU**
736 {{/info}}
737
738 (% border="1" style="background-color:#ffffcc; color:green; width:534.222px" %)
739 |=(% colspan="3" style="width: 531px;" %)AT+FCU
740 |(% style="width:177px" %)**Command Example**|(% style="width:239px" %)**Function**|(% style="width:113px" %)**Response**
741 |(% style="width:177px" %)AT+FCU=?|(% style="width:239px" %)Get the Frame Counter Uplink.|(% style="width:113px" %)0(((
742 OK
743 )))
744 |(% style="width:177px" %)AT+FCU=10|(% style="width:239px" %)Set the Frame Counter Uplink.|(% style="width:113px" %)OK(((
745
746 )))
747
748
749 == 7.7 Join Accept Delay1 ==
750
751 Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 1 in ms.
752
753 {{info}}
754 **AT Command:AT+JN1DL**
755 {{/info}}
756
757 (% border="1" style="background-color:#ffffcc; color:green; width:537.222px" %)
758 |=(% colspan="3" style="width: 534px;" %)AT+JN1DL
759 |(% style="width:164px" %)**Command Example**|(% style="width:229px" %)**Function**|(% style="width:140px" %)**Response**
760 |(% style="width:164px" %)AT+JN1DL=?|(% style="width:229px" %)Get the Join Accept Delay.|(% style="width:140px" %)5000(((
761 OK
762 )))
763 |(% style="width:164px" %)AT+JN1DL=10000|(% style="width:229px" %)Set the Join Accept Delay.|(% style="width:140px" %)OK(((
764
765 )))
766
767
768 == 7.8 Join Accept Delay2 ==
769
770 Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 2 in ms.
771
772 {{info}}
773 **AT Command:AT+JN2DL**
774 {{/info}}
775
776 (% border="1" style="background-color:#ffffcc; color:green; width:538.222px" %)
777 |=(% colspan="3" style="width: 535px;" %)AT+JN2DL
778 |(% style="width:160px" %)**Command Example**|(% style="width:228px" %)**Function**|(% style="width:146px" %)**Response**
779 |(% style="width:160px" %)AT+JN2DL=?|(% style="width:228px" %)Get the Join Accept Delay.|(% style="width:146px" %)6000(((
780 OK
781 )))
782 |(% style="width:160px" %)AT+JN2DL=20000|(% style="width:228px" %)Set the Join Accept Delay.|(% style="width:146px" %)OK(((
783
784 )))
785
786
787 == 7.9 Public Network Mode ==
788
789 Feature: Get or Set the public network mode. (0: off, 1: on)
790
791 {{info}}
792 **AT Command:AT+PNM**
793 {{/info}}
794
795 (% border="1" style="background-color:#ffffcc; color:green; width:667.222px" %)
796 |=(% colspan="3" style="width: 664px;" %)AT+PNM
797 |(% style="width:166px" %)**Command Example**|(% style="width:225px" %)**Function**|(% style="width:272px" %)**Response**
798 |(% style="width:166px" %)AT+PNM=?|(% style="width:225px" %)Get the public network mode.|(% style="width:272px" %)1(((
799 OK
800 )))
801 |(% style="width:166px" %)AT+PNM=1|(% style="width:225px" %)Set the public network mode.|(% style="width:272px" %)(System will write new value to PNM)(((
802 OK
803
804
805 )))
806
807
808 == 7.10 Receive Delay1 ==
809
810 Feature: Get or Set the delay between the end of the Tx and the Rx Window 1 in ms
811
812 {{info}}
813 **AT Command:AT+RX1DL**
814 {{/info}}
815
816 (% border="1" style="background-color:#ffffcc; color:green; width:408.222px" %)
817 |=(% colspan="3" style="width: 405px;" %)AT+RX1DL
818 |(% style="width:155px" %)**Command Example**|(% style="width:128px" %)**Function**|(% style="width:122px" %)**Response**
819 |(% style="width:155px" %)AT+RX1DL=?|(% style="width:128px" %)Get the delay.|(% style="width:122px" %)1000(((
820 OK
821 )))
822 |(% style="width:155px" %)AT+RX1DL=1500|(% style="width:128px" %)Set the delay.|(% style="width:122px" %)OK(((
823
824 )))
825
826
827 == 7.11 Receive Delay2 ==
828
829 Feature: Get or Set the delay between the end of the Tx and the Rx Window 2 in ms
830
831 {{info}}
832 **AT Command:AT+RX2DL**
833 {{/info}}
834
835 (% border="1" style="background-color:#ffffcc; color:green; width:481.222px" %)
836 |=(% colspan="3" style="width: 478px;" %)AT+RX2DL
837 |(% style="width:175px" %)**Command Example**|(% style="width:152px" %)**Function**|(% style="width:150px" %)**Response**
838 |(% style="width:175px" %)AT+RX2DL=?|(% style="width:152px" %)Get the delay.|(% style="width:150px" %)2000(((
839 OK
840 )))
841 |(% style="width:175px" %)AT+RX2DL=2500|(% style="width:152px" %)Set the delay.|(% style="width:150px" %)OK(((
842
843 )))
844
845
846 == 7.12 Rx2 Window Data Rate ==
847
848 Feature: Get or Set the Rx2 window data rate (0-7 corresponding to DR_X)
849
850 {{info}}
851 **AT Command:AT+RX2DR**
852 {{/info}}
853
854 (% border="1" style="background-color:#ffffcc; color:green; width:525.222px" %)
855 |=(% colspan="3" style="width: 522px;" %)AT+RX2DR
856 |(% style="width:160px" %)**Command Example**|(% style="width:232px" %)**Function**|(% style="width:130px" %)**Response**
857 |(% style="width:160px" %)AT+RX2DR=?|(% style="width:232px" %)Get the Rx2 window data rate.|(% style="width:130px" %)2(((
858 OK
859 )))
860 |(% style="width:160px" %)AT+RX2DR=6|(% style="width:232px" %)Set the Rx2 window data rate.|(% style="width:130px" %)OK(((
861
862 )))
863
864
865 == 7.13 Rx2 Window Frequency ==
866
867 Feature: Get or Set the Rx2 window frequency
868
869 {{info}}
870 **AT Command:AT+RX2FQ**
871 {{/info}}
872
873 (% border="1" style="background-color:#ffffcc; color:green; width:587.222px" %)
874 |=(% colspan="3" style="width: 584px;" %)AT+RX2FQ
875 |(% style="width:183px" %)**Command Example**|(% style="width:240px" %)**Function**|(% style="width:160px" %)**Response**
876 |(% style="width:183px" %)AT+RX2FQ=?|(% style="width:240px" %)Get the Rx2 window frequency.|(% style="width:160px" %)434665000(((
877 OK
878 )))
879 |(% style="width:183px" %)AT+RX2FQ=434665000|(% style="width:240px" %)Set the Rx2 window frequency.|(% style="width:160px" %)OK(((
880
881 )))
882
883
884 == 7.14 Transmit Power ==
885
886 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. )
887
888 {{info}}
889 **AT Command:AT+TXP**
890 {{/info}}
891
892 (% border="1" style="background-color:#ffffcc; color:green; width:465.222px" %)
893 |=(% colspan="3" style="width: 462px;" %)AT+TXP
894 |(% style="width:161px" %)**Command Example**|(% style="width:189px" %)**Function**|(% style="width:112px" %)**Response**
895 |(% style="width:161px" %)AT+TXP=?|(% style="width:189px" %)Get the Transmit Power.|(% style="width:112px" %)0(((
896 OK
897 )))
898 |(% style="width:161px" %)AT+TXP=1|(% style="width:189px" %)Set the Transmit Power.|(% style="width:112px" %)OK(((
899
900 )))
901
902 Downlink Payload. The 4th byte of 0x22 downlink.
903
904 If the downlink payload=22000100, it means setting the TXP to 0.
905
906 * **Example 1**: Downlink Payload: **22000102** ~/~/ Set AT+TXP=2.
907 * **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+TXP=0.
908
909
910 == 7.15 RSSI of the Last Received Packet ==
911
912 Feature: Get or Set the Rx2 window frequency
913
914 {{info}}
915 **AT Command:AT+RSSI**
916 {{/info}}
917
918 (% border="1" style="background-color:#ffffcc; color:green; width:557.222px" %)
919 |=(% colspan="3" style="width: 554px;" %)AT+RSSI
920 |(% style="width:164px" %)**Command Example**|(% style="width:289px" %)**Function**|(% style="width:100px" %)**Response**
921 |(% style="width:164px" %)AT+RSSI=?|(% style="width:289px" %)Get the RSSI of the last received packet.|(% style="width:100px" %)0(((
922 OK
923 )))
924
925
926 == 7.16 SNR of the Last Received Packet ==
927
928 Feature: Get the SNR of the last received packet
929
930 {{info}}
931 **AT Command:AT+SNR**
932 {{/info}}
933
934 (% border="1" style="background-color:#ffffcc; color:green; width:571.222px" %)
935 |=(% colspan="3" style="width: 568px;" %)AT+SNR
936 |(% style="width:164px" %)**Command Example**|(% style="width:290px" %)**Function**|(% style="width:113px" %)**Response**
937 |(% style="width:164px" %)AT+SNR=?|(% style="width:290px" %)Get the RSSI of the last received packet.|(% style="width:113px" %)0(((
938 OK
939 )))
940
941
942 == 7.17 Application Port ==
943
944 Feature: Get or set the application port.
945
946 {{info}}
947 **AT Command: AT+PORT**
948 {{/info}}
949
950 (% border="1" style="background-color:#ffffcc; color:green; width:500.222px" %)
951 |=(% colspan="3" style="width: 497px;" %)AT+PORT
952 |(% style="width:157px" %)**Command Example**|(% style="width:204px" %)**Function**|(% style="width:135px" %)**Response**
953 |(% style="width:157px" %)AT+PORT=?|(% style="width:204px" %)Get the application port|(% style="width:135px" %)21(((
954 OK
955 )))
956 |(% style="width:157px" %)AT+PORT=21|(% style="width:204px" %)Set the application port|(% style="width:135px" %)OK
957
958 {{info}}
959 **Downlink Command: 0x23**
960 {{/info}}
961
962 Format: Command Code (0x23) followed by 1 bytes port value.
963
964 If the downlink payload=2301, it means set the application port to 1, while type code is 23.
965
966 * **Example 1**: Downlink Payload: **2301** ~/~/ set the application port to 1
967 * **Example 2**: Downlink Payload:** 2305** ~/~/ set the application port to 5
968
969
970 == 7.18 Single Channel Mode ==
971
972 Feature:Get or Set Frequency (Unit: Hz) for Single Channel Mode.
973
974 {{info}}
975 **AT Command: AT+CHS**
976 {{/info}}
977
978 (% border="1" style="background-color:#ffffcc; color:green; width:603.222px" %)
979 |=(% colspan="3" style="width: 600px;" %)AT+CHS
980 |(% style="width:182px" %)**Command Example**|(% style="width:295px" %)**Function**|(% style="width:122px" %)**Response**
981 |(% style="width:182px" %)AT+CHS=?|(% style="width:295px" %)Get Frequency for Single Channel Mode|(% style="width:122px" %)0(((
982 OK
983 )))
984 |(% style="width:182px" %)AT+CHS=868100000|(% style="width:295px" %)Set Frequency for Single Channel Mode|(% style="width:122px" %)OK
985
986
987 == 7.19 Eight Channel Mode ==
988
989 Feature: Get or Set eight channels mode,Only for US915,AU915,CN470.
990
991 {{info}}
992 **AT Command: AT+CHE**
993 {{/info}}
994
995 (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %)
996 |=(% colspan="3" style="width: 707px;" %)AT+CHE
997 |(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response**
998 |(% style="width:160px" %)AT+CHE=?|(% style="width:198px" %)Get eight channels mode|(% style="width:349px" %)1(((
999 902.3 902.5 902.7 902.9 903.1 903.3 903.5 903.7
1000
1001 OK
1002 )))
1003 |(% style="width:160px" %)AT+CHE=1|(% style="width:198px" %)Set eight channels mode|(% style="width:349px" %)OK
1004
1005 {{info}}
1006 **Downlink Command: 0x24**
1007 {{/info}}
1008
1009 Format: Command Code (0x24) followed by 1 bytes channel value.
1010
1011 If the downlink payload=2401, it means set channel mode to 1, while type code is 24.
1012
1013 * **Example 1**: Downlink Payload: 2401 ~/~/ set channel mode to 1
1014 * **Example 2**: Downlink Payload: 2405 ~/~/ set channel mode to 5
1015
1016
1017 == 7.20 Get or Set RXwindows1 timeout ==
1018
1019 Feature:Get or Set the number of symbols to detect and timeout from RXwindow1(0 to 255).
1020
1021 {{info}}
1022 **AT Command: AT+RX1WTO**
1023 {{/info}}
1024
1025 (% border="1" style="background-color:#ffffcc; color:green; width:460.222px" %)
1026 |=(% colspan="3" style="width: 457px;" %)AT+ RX1WTO
1027 |(% style="width:163px" %)**Command Example**|(% style="width:201px" %)**Function**|(% style="width:93px" %)**Response**
1028 |(% style="width:163px" %)AT+RX1WTO=?|(% style="width:201px" %)Get RXwindows1 timeout|(% style="width:93px" %)14(((
1029 OK
1030 )))
1031 |(% style="width:163px" %)AT+RX1WTO=60|(% style="width:201px" %)Set RXwindows1 timeout|(% style="width:93px" %)OK
1032
1033 (((
1034 **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.
1035 )))
1036
1037 [[image:image-20220526162535-1.png]]
1038
1039 (((
1040 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.
1041
1042
1043 )))
1044
1045 == 7.21 Get or Set RXwindows2 timeout ==
1046
1047 Feature:Get or Set the number of symbols to detect and timeout from RXwindow2(0 to 255).
1048
1049 {{info}}
1050 **AT Command: AT+RX2WTO**
1051 {{/info}}
1052
1053 (% border="1" style="background-color:#ffffcc; color:green; width:497.222px" %)
1054 |=(% colspan="3" style="width: 494px;" %)AT+ RX2WTO
1055 |(% style="width:190px" %)**Command Example**|(% style="width:199px" %)**Function**|(% style="width:104px" %)**Response**
1056 |(% style="width:190px" %)AT+RX2WTO=?|(% style="width:199px" %)Get RXwindows2 timeout|(% style="width:104px" %)7(((
1057 OK
1058 )))
1059 |(% style="width:190px" %)AT+RX2WTO=20|(% style="width:199px" %)Set RXwindows2 timeout|(% style="width:104px" %)OK
1060
1061
1062 == 7.22 Setting up uplinkdwelltime (as923, au915) ==
1063
1064 Feature: Get or Set uplinkdwelltime
1065
1066 {{info}}
1067 **AT Command: AT+DWELLT**
1068 {{/info}}
1069
1070 (% border="1" style="background-color:#ffffcc; color:green; width:497.222px" %)
1071 |=(% colspan="3" style="width: 494px;" %)AT+DWELLT
1072 |(% style="width:183px" %)**Command Example**|(% style="width:179px" %)**Function**|(% style="width:131px" %)**Response**
1073 |(% style="width:183px" %)AT+DWELLT=?|(% style="width:179px" %)Get uplinkdwelltime|(% style="width:131px" %)1(((
1074 OK
1075 )))
1076 |(% style="width:183px" %)AT+DWELLT=0|(% style="width:179px" %)Set uplinkdwelltime|(% style="width:131px" %)OK
1077
1078 {{info}}
1079 **Downlink Command: 0x25**
1080 {{/info}}
1081
1082 Format: Command Code (0x25) followed by 1 bytes state value.
1083
1084 If the downlink payload=2501, it means set uplinkdwelltime to 1, while type code is 25.
1085
1086 * **Example 1**: Downlink Payload: **2501** ~/~/ set uplinkdwelltime to 1
1087 * **Example 2**: Downlink Payload: **2500** ~/~/ set uplinkdwelltime to 0
1088
1089
1090 == 7.23 Set Packet Receiving Response Level ==
1091
1092 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.
1093
1094 RPL value:
1095
1096 * **AT+RPL=0:** Device won't immediately reply any downlink commands from platform.
1097 * **AT+RPL=1:** Device will immediately reply message to Unconfirmed Data Down. Payload is 0x00.
1098 * **AT+RPL=2:** Device will immediately reply message to Confirmed Data Down. Payload is 0x00 and requied response header for this command.
1099 * **AT+RPL=3:** Device will immediately reply message to MAC Command. Payload is 0x00 and requied response header for this command.
1100 * **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.
1101
1102 Case Analyes:
1103
1104 * For Class A devices, AT+RPL=0 is ok. that is defaut settings in software.
1105 * For Class C devices used in ChirpStack, need to set AT+RPL=4 because Chirpstack require immedietely reply message to MAC Command.
1106 * 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.
1107
1108 {{info}}
1109 **AT Command: AT+RPL**
1110 {{/info}}
1111
1112 (% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %)
1113 |=(% colspan="3" style="width: 533px;" %)AT+RPL
1114 |(% style="width:160px" %)**Command Example**|(% style="width:263px" %)**Function**|(% style="width:109px" %)**Response**
1115 |(% style="width:160px" %)AT+RPL=?|(% style="width:263px" %)Get packet receiving response level|(% style="width:109px" %)1(((
1116 OK
1117 )))
1118 |(% style="width:160px" %)AT+RPL=0|(% style="width:263px" %)Set packet receiving response level|(% style="width:109px" %)OK
1119
1120 {{info}}
1121 **Downlink Command: 0x21**
1122 {{/info}}
1123
1124 Format: Command Code (0x21) followed by 1 bytes level value.
1125
1126 If the downlink payload=2101, it means set packet receiving response level to 1, while type code is 21.
1127
1128 * **Example 1**: Downlink Payload: **2101** ~/~/ set packet receiving response level to 1
1129 * **Example 2**: Downlink Payload: **2102** ~/~/ set packet receiving response level to 2
1130
1131
1132 = 8. AT Commands Combination =
1133
1134 == 8.1 Set a fix RX2DR for downlink window ==
1135
1136 * **AT+ADR=0 **~-~-> Disable ADR first
1137 * **AT+RX2DR=xxxx** ~-~-> Set xxxx to your wanted DataRate
1138
1139
1140 == 8.2 Use Downlink Command to set a fix uplink DR ==
1141
1142 {{info}}
1143 **Downlink Command: 0x22000500**
1144 {{/info}}
1145
1146 Same as:
1147
1148 * AT+ADR=0  [[Reference>>||anchor="H7.1AdaptiveDataRate"]]
1149 * AT+DR=5  [[Reference>>||anchor="H7.4DataRate"]]
1150 * AT+TXP=0  [[Reference>>||anchor="H7.14TransmitPower"]]