<
From version < 50.4 >
edited by Xiaoling
on 2022/07/13 11:50
To version < 63.7 >
edited by Xiaoling
on 2023/04/19 14:42
>
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -9,37 +9,37 @@
9 9  
10 10  Dragino LoRaWAN End Node support two types of AT Commands and Downlink Commands:
11 11  
12 -* **Common Commands:** They should be available for each sensor, such as: change uplink interval, reset device.
13 -* **Sensor Related Commands:** Only for special sensor, such as control relay, poll RS485 device.
12 +* (% style="color:blue" %)**Common Commands:** (%%) They should be available for each sensor, such as: change uplink interval, reset device.
13 +* (% style="color:blue" %)**Sensor Related Commands:** (%%) Only for special sensor, such as control relay, poll RS485 device.
14 14  
15 15  (((
16 16  **This page shows the common commands since Dragino LoRaWAN stack DR-LWS-005. Make sure the end node support stack higher than DR-LWS-005 before checking this page.**
17 -
18 18  )))
19 19  
19 +
20 20  = 2. How to use AT Commands or Downlink command =
21 21  
22 22  
23 -* 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/]]
24 -* 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 +* **AT Command** See Devices User Manual for how to connect to device via USB TTL adapter and use. The user manual can be found in each product page of [[Dragino Official Website>>url:http://www.dragino.com/]]
24 +* **LoRaWAN Downlink Command**: The gateway transfer downlink command in HEX format. This page shows the Downlink Command In HEX format. Please note some LoRaWAN servers use base64 as downlink code so user need to convert HEX to Base64 and use. Below are references for how to use downlink command:
25 25  ** Use HEX format to send a downlink: [[TTN v3>>Notes for TTN]]
26 -** Use Base64 format to send a downlink: [[Chirpstack>>Notes for ChirpStack]]
26 +** Use Base64 format to send a downlink: [[Chirpstack>>Notes for ChirpStack]], [[How to Convert>>http://wiki.dragino.com/xwiki/bin/view/Main/Notes%20for%20ChirpStack/#H4.1ConvertHEXtoBase64]]?
27 27  ** See use note for more serves [[Servers Note>>doc:Main.WebHome]](IoT LoRaWAN Server)
28 28  
29 +(% style="display:none" %) (%%)
29 29  
30 -
31 31  = 3. Support End Node and firmware version =
32 32  
33 33  
34 -(% border="1" style="background-color:#ffffcc; color:green; width:966px" %)
35 -|=(% colspan="3" style="width: 963px;" %)(((
34 +(% border="1" style="background-color:#F2F2F2; width:966px" %)
35 +|=(% colspan="3" style="width: 963px;background-color:#D9E2F3" %)(((
36 36  Dragino STM32 base hardware Firmware / LoRaWAN stack list
37 37  )))
38 -|(% style="width:187px" %)(((
38 +|(% style="width:187px;color:#0070C0" %)(((
39 39  **Model**
40 -)))|(% style="width:330px" %)(((
40 +)))|(% style="width:330px;color:#0070C0" %)(((
41 41  **Description**
42 -)))|(% style="width:445px" %)(((
42 +)))|(% style="width:445px;color:#0070C0" %)(((
43 43  **Firmware Version <~-~-> Stack Version**
44 44  )))
45 45  |(% style="width:187px" %)(((
... ... @@ -102,24 +102,21 @@
102 102  )))
103 103  )))
104 104  
105 +(% style="display:none" %) (%%)
105 105  
106 -
107 107  = 4. System Management Commands =
108 108  
109 -
110 110  == 4.1 Change Uplink Interval ==
111 111  
112 112  
113 113  Feature: Change LoRaWAN End Node Transmit Interval.
114 114  
115 -(% class="box infomessage" %)
116 -(((
117 -**AT Command: AT+TDC**
118 -)))
119 119  
120 -(% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %)
121 -|=(% colspan="3" style="width: 724px;" %)AT+TDC
122 -|(% style="width:165px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:329px" %)**Response**
115 +(% style="color:blue" %)**AT Command: AT+TDC**
116 +
117 +(% border="1" style="background-color:#F2F2F2; width:727.222px" %)
118 +|=(% colspan="3" style="width: 724px;background-color:#D9E2F3" %)AT+TDC
119 +|(% style="width:165px;color:#0070C0" %)**Command Example**|(% style="width:227px;color:#0070C0" %)**Function**|(% style="width:329px;color:#0070C0" %)**Response**
123 123  |(% style="width:165px" %)AT+TDC=?|(% style="width:227px" %)Show current transmit Interval|(% style="width:329px" %)30000(((
124 124  OK
125 125  
... ... @@ -129,35 +129,35 @@
129 129  Set transmit interval to 60000ms = 60 seconds
130 130  )))
131 131  
132 -{{info}}
133 -**Downlink Command: 0x01**
134 -{{/info}}
135 -
136 136  (((
130 +
131 +
132 +(% style="color:blue" %)**Downlink Command: 0x01**
133 +
137 137  Format: Command Code (0x01) followed by 3 bytes time value.
138 138  )))
139 139  
140 140  (((
141 -If the downlink payload=0100003C, it means set the END Nodes Transmit Interval to 0x00003C=60(S), while type code is 01.
138 +If the downlink payload=0100003C, it means set the END Node's Transmit Interval to 0x00003C=60(S), while type code is 01.
142 142  )))
143 143  
144 -* **Example 1**: Downlink Payload:** 0100001E** ~/~/ Set Transmit Interval (TDC) = 30 seconds
145 -* **Example 2**: Downlink Payload:** 0100003C** ~/~/ Set Transmit Interval (TDC) = 60 seconds
141 +* **Example 1**: Downlink Payload:** 0100001E**  ~/~/ Set Transmit Interval (TDC) = 30 seconds
142 +* **Example 2**: Downlink Payload:** 0100003C**  ~/~/ Set Transmit Interval (TDC) = 60 seconds
146 146  
144 +(% style="display:none" %) (%%)
147 147  
148 -
149 149  == 4.2 Reboot End Node ==
150 150  
148 +
151 151  Feature: Reboot End Node to perform a new OTAA or ABP Join.
152 152  
153 -{{info}}
154 -**AT Command: ATZ**
155 -{{/info}}
156 156  
157 -(% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %)
158 -|=(% colspan="3" %)ATZ: Trig a reset of the MCU
159 -|**Command Example**|**Function**|**Response**
160 -|ATZ|Reset MCU|(((
152 +(% style="color:blue" %)**AT Command: ATZ**
153 +
154 +(% border="1" style="background-color:#ffffcc; color:green; width:546px" %)
155 +|=(% colspan="3" style="width: 543px;" %)ATZ: Trig a reset of the MCU
156 +|(% style="width:157px" %)**Command Example**|(% style="width:92px" %)**Function**|(% style="width:294px" %)**Response**
157 +|(% style="width:157px" %)ATZ|(% style="width:92px" %)Reset MCU|(% style="width:294px" %)(((
161 161  Device reset and show booting info
162 162  
163 163  LSN50 Device/LoRa ST Module
... ... @@ -171,9 +171,7 @@
171 171  <followed by the Tx and Rx information>
172 172  )))
173 173  
174 -{{info}}
175 -**Downlink Command: 0x04**
176 -{{/info}}
171 +(% style="color:blue" %)**Downlink Command: 0x04**
177 177  
178 178  (((
179 179  Format: Command Code (0x04) followed by FF.
... ... @@ -180,23 +180,22 @@
180 180  )))
181 181  
182 182  (((
183 -If the downlink payload=**04FF**, the end node will reboot.
184 -
185 -
178 +If the downlink payload=**04FF**, the end node will reboot.
186 186  )))
187 187  
181 +
188 188  == 4.3 Reset to factory Default ==
189 189  
184 +
190 190  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.
191 191  
192 -{{info}}
193 -**AT Command: AT+FDR**
194 -{{/info}}
195 195  
196 -(% border="1" style="background-color:#ffffcc; color:green; width:831.222px" %)
197 -|=(% colspan="3" style="width: 828px;" %)Reset to factory default
198 -|(% style="width:181px" %)**Command Example**|(% style="width:181px" %)**Function**|(% style="width:465px" %)**Response**
199 -|(% style="width:181px" %)AT+FDR|(% style="width:181px" %)Reset to factory default|(% style="width:465px" %)(((
188 +(% style="color:blue" %)**AT Command: AT+FDR**
189 +
190 +(% border="1" style="background-color:#ffffcc; color:green; width:789px" %)
191 +|=(% colspan="3" style="width: 786px;" %)Reset to factory default
192 +|(% style="width:154px" %)**Command Example**|(% style="width:175px" %)**Function**|(% style="width:456px" %)**Response**
193 +|(% style="width:154px" %)AT+FDR|(% style="width:175px" %)Reset to factory default|(% style="width:456px" %)(((
200 200  Device reset to factory default parameters and show booting info
201 201  
202 202  LSN50 Device/LoRa ST Module
... ... @@ -210,9 +210,7 @@
210 210  Please set the parameters or reset Device to apply change
211 211  )))
212 212  
213 -{{info}}
214 -**Downlink Command: 0x04**
215 -{{/info}}
207 +(% style="color:blue" %)**Downlink Command: 0x04**
216 216  
217 217  (((
218 218  Format: Command Code (0x04) followed by FE.
... ... @@ -225,24 +225,22 @@
225 225  
226 226  == 4.4 Show Firmware Version ==
227 227  
220 +
228 228  Feature: Show firmware version. No downlink command yet.
229 229  
230 -{{info}}
231 -**AT Command: AT+VER**
232 -{{/info}}
233 233  
234 -(% border="1" style="background-color:#ffffcc; color:green; width:586px" %)
235 -|=(% colspan="3" style="width: 583px;" %)AT+VER: Image Version and Frequency Band
236 -|(% style="width:170px" %)**Command Example**|(% style="width:300px" %)**Function**|(% style="width:113px" %)**Response**
237 -|(% style="width:170px" %)AT+VER=?|(% style="width:300px" %)Show Image version and Frequency Band|(% style="width:113px" %)(((
224 +(% style="color:blue" %)**AT Command: AT+VER**
225 +
226 +(% border="1" style="background-color:#ffffcc; color:green; width:542px" %)
227 +|=(% colspan="3" style="width: 539px;" %)AT+VER: Image Version and Frequency Band
228 +|(% style="width:157px" %)**Command Example**|(% style="width:295px" %)**Function**|(% style="width:86px" %)**Response**
229 +|(% style="width:157px" %)AT+VER=?|(% style="width:295px" %)Show Image version and Frequency Band|(% style="width:86px" %)(((
238 238  1.3 EU868
239 239  
240 240  OK
241 241  )))
242 242  
243 -{{info}}
244 -**Downlink Command: 0x26 (Valid in 006 stack)**
245 -{{/info}}
235 +(% style="color:blue" %)**Downlink Command: 0x26 (Valid in 006 stack)**
246 246  
247 247  (((
248 248  Downlink Format: 0x26
... ... @@ -253,6 +253,8 @@
253 253  )))
254 254  
255 255  (((
246 +
247 +
256 256  **xx: Software Type:**
257 257  )))
258 258  
... ... @@ -261,6 +261,8 @@
261 261  * 0x00 03: LSE01/LDDS75/LDDS20/LSPH01/LLMS01/LSNPK01
262 262  
263 263  (((
256 +
257 +
264 264  **yy: Frequency Band:**
265 265  )))
266 266  
... ... @@ -276,6 +276,8 @@
276 276  * 0xa0: AS923-3
277 277  
278 278  (((
273 +
274 +
279 279  **zz: Subband**
280 280  )))
281 281  
... ... @@ -284,39 +284,36 @@
284 284  
285 285  == 4.5 Show System Configure ==
286 286  
283 +
287 287  Feature: Show All configure. No downlink command yet.
288 288  
289 -{{info}}
290 -**AT Command: AT+CFG**
291 -{{/info}}
292 292  
287 +(% style="color:blue" %)**AT Command: AT+CFG**
288 +
293 293  (% border="1" style="background-color:#ffffcc; color:green; width:599.222px" %)
294 294  |=(% colspan="3" style="width: 596px;" %)AT+CFG: Print all configurations
295 295  |(% style="width:160px" %)**Command Example**|(% style="width:154px" %)**Function**|(% style="width:280px" %)**Response**
296 296  |(% style="width:160px" %)AT+CFG|(% style="width:154px" %)Show all configures|(% style="width:280px" %)(((
297 297  AT+DEUI = XX XX XX XX XX XX XX XX
298 -
299 299  AT+DADDR=XXXXXXXX
300 -
301 301  ……….
302 -
303 303  AT+RX2WTO=X
304 -
305 305  AT+CHS=868100000
306 -
307 307  OK
308 308  )))
309 309  
301 +(% style="display:none" %) (%%)
302 +
310 310  = 5. Keys, IDs and EUIs management =
311 311  
312 312  == 5.1 Application EUI ==
313 313  
307 +
314 314  Feature: Get or Set the Application EUI.
315 315  
316 -{{info}}
317 -**AT Command: AT+APPEUI**
318 -{{/info}}
319 319  
311 +(% style="color:blue" %)**AT Command: AT+APPEUI**
312 +
320 320  (% border="1" style="background-color:#ffffcc; color:green; width:686.222px" %)
321 321  |=(% colspan="3" style="width: 683px;" %)AT+APPEUI
322 322  |(% style="width:305px" %)**Command Example**|(% style="width:186px" %)**Function**|(% style="width:191px" %)**Response**
... ... @@ -325,14 +325,16 @@
325 325  )))
326 326  |(% style="width:305px" %)AT+APPEUI=00 b3 d5 7e f0 00 4d 34|(% style="width:186px" %)Set the Application EUI|(% style="width:191px" %)OK
327 327  
321 +(% style="display:none" %) (%%)
322 +
328 328  == 5.2 Application Key ==
329 329  
325 +
330 330  Feature: Get or Set the Application Key.
331 331  
332 -{{info}}
333 -**AT Command: AT+APPKEY**
334 -{{/info}}
335 335  
329 +(% style="color:blue" %)**AT Command: AT+APPKEY**
330 +
336 336  (% border="1" style="background-color:#ffffcc; color:green; width:976.222px" %)
337 337  |=(% colspan="3" style="width: 973px;" %)AT+APPKEY
338 338  |(% style="width:441px" %)**Command Example**|(% style="width:180px" %)**Function**|(% style="width:350px" %)**Response**
... ... @@ -341,14 +341,16 @@
341 341  )))
342 342  |(% 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
343 343  
339 +(% style="display:none" %) (%%)
340 +
344 344  == 5.3 Application Session Key ==
345 345  
343 +
346 346  Feature: Get or Set the Application Session Key.
347 347  
348 -{{info}}
349 -**AT Command: AT+APPSKEY**
350 -{{/info}}
351 351  
347 +(% style="color:blue" %)**AT Command: AT+APPSKEY**
348 +
352 352  (% border="1" style="background-color:#ffffcc; color:green; width:1040.22px" %)
353 353  |=(% colspan="3" style="width: 1037px;" %)AT+APPSKEY
354 354  |(% style="width:451px" %)**Command Example**|(% style="width:231px" %)**Function**|(% style="width:354px" %)**Response**
... ... @@ -359,14 +359,16 @@
359 359  OK
360 360  )))
361 361  
359 +(% style="display:none" %) (%%)
360 +
362 362  == 5.4 Device Address ==
363 363  
363 +
364 364  Feature: Get or Set the Device Address.
365 365  
366 -{{info}}
367 -**AT Command: AT+DADDR**
368 -{{/info}}
369 369  
367 +(% style="color:blue" %)**AT Command: AT+DADDR**
368 +
370 370  (% border="1" style="background-color:#ffffcc; color:green; width:795.222px" %)
371 371  |=(% colspan="3" style="width: 792px;" %)AT+DADDR
372 372  |(% style="width:192px" %)**Command Example**|(% style="width:241px" %)**Function**|(% style="width:359px" %)**Response**
... ... @@ -377,14 +377,16 @@
377 377  )))
378 378  |(% style="width:192px" %)AT+DADDR=A8 40 41 FF|(% style="width:241px" %)Set the Application Session Key.|(% style="width:359px" %)OK
379 379  
379 +(% style="display:none" %) (%%)
380 +
380 380  == 5.5 Device EUI ==
381 381  
383 +
382 382  Feature: Get or Set the Device EUI.
383 383  
384 -{{info}}
385 -**AT Command: AT+DEUI**
386 -{{/info}}
387 387  
387 +(% style="color:blue" %)**AT Command: AT+DEUI**
388 +
388 388  (% border="1" style="background-color:#ffffcc; color:green; width:1035.22px" %)
389 389  |=(% colspan="3" style="width: 1032px;" %)AT+DEUI
390 390  |(% style="width:250px" %)**Command Example**|(% style="width:147px" %)**Function**|(% style="width:634px" %)**Response**
... ... @@ -395,14 +395,16 @@
395 395  OK
396 396  )))
397 397  
399 +(% style="display:none" %) (%%)
400 +
398 398  == 5.6 Network ID ==
399 399  
403 +
400 400  Feature: Get or Set the Network ID.(You can enter this command change only after successful network connection)
401 401  
402 -{{info}}
403 -**AT Command: AT+NWKID**
404 -{{/info}}
405 405  
407 +(% style="color:blue" %)**AT Command: AT+NWKID**
408 +
406 406  (% border="1" style="background-color:#ffffcc; color:green; width:448.222px" %)
407 407  |=(% colspan="3" style="width: 445px;" %)AT+NWKID
408 408  |(% style="width:191px" %)**Command Example**|(% style="width:153px" %)**Function**|(% style="width:101px" %)**Response**
... ... @@ -411,14 +411,16 @@
411 411  )))
412 412  |(% style="width:191px" %)AT+NWKID=A8 40 41 FF|(% style="width:153px" %)Set the Network ID.|(% style="width:101px" %)OK
413 413  
417 +(% style="display:none" %) (%%)
418 +
414 414  == 5.7 Network Session Key ==
415 415  
421 +
416 416  Feature: Get or Set the Network Session Key
417 417  
418 -{{info}}
419 -**AT Command: AT+NWKSKEY**
420 -{{/info}}
421 421  
425 +(% style="color:blue" %)**AT Command: AT+NWKSKEY**
426 +
422 422  (% border="1" style="background-color:#ffffcc; color:green; width:1017.22px" %)
423 423  |=(% colspan="3" style="width: 1014px;" %)AT+NWKSKEY
424 424  |(% style="width:455px" %)**Command Example**|(% style="width:215px" %)**Function**|(% style="width:343px" %)**Response**
... ... @@ -427,18 +427,20 @@
427 427  )))
428 428  |(% 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
429 429  
435 +(% style="display:none" %) (%%)
436 +
430 430  = 6. Joining and sending date on LoRaWAN network =
431 431  
432 432  == 6.1 Confirm Mode ==
433 433  
434 -=== AT+CFM command before DR-LWS007 software stack ===
441 +=== 6.1.1  AT+CFM command before DR-LWS007 software stack ===
435 435  
443 +
436 436  Feature: Get or Set the confirmation mode (0-1).
437 437  
438 -{{info}}
439 -**AT Command: AT+CFM**
440 -{{/info}}
441 441  
447 +(% style="color:blue" %)**AT Command: AT+CFM**
448 +
442 442  (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %)
443 443  |=(% colspan="3" style="width: 707px;" %)AT+CFM
444 444  |(% style="width:155px" %)**Command Example**|(% style="width:205px" %)**Function**|(% style="width:346px" %)**Response**
... ... @@ -448,21 +448,22 @@
448 448  |(% style="width:155px" %)AT+CFM=1|(% style="width:205px" %)Set the confirmation mode|(% style="width:346px" %)OK
449 449  |(% style="width:155px" %)AT+CFM=2|(% style="width:205px" %)Set the confirmation mode|(% style="width:346px" %)While Error in format, return AT_PARAM_ERROR
450 450  
451 -Downlink Command: 0x05
458 +(% style="color:blue" %)**Downlink Command: 0x05**
452 452  
453 453  Format: Command Code (0x05) followed by 2 bytes mode value.
454 454  
455 455  If the downlink payload=0501, it means set end node to use confirm mode, while type code is 05.
456 456  
457 -* Example 1: Downlink Payload: 0501 ~/~/ Set AT+CFM=1
458 -* Example 2: Downlink Payload: 0500 ~/~/ Set AT+CFM=0
464 +* **Example 1:** Downlink Payload: 0501  ~/~/ Set AT+CFM=1
465 +* **Example 2:** Downlink Payload: 0500  ~/~/ Set AT+CFM=0
459 459  
460 -=== AT+CFM command since DR-LWS007 software stack ===
467 +(% style="display:none" %) (%%)
461 461  
462 -{{info}}
463 -**AT Command: AT+CFM**
464 -{{/info}}
469 +=== 6.1.2  AT+CFM command since DR-LWS007 software stack ===
465 465  
471 +
472 +(% style="color:blue" %)**AT Command: AT+CFM**
473 +
466 466  (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %)
467 467  |=(% colspan="3" style="width: 707px;" %)AT+CFM
468 468  |(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response**
... ... @@ -494,57 +494,60 @@
494 494  OK
495 495  )))
496 496  
497 -{{info}}
498 -**Downlink Command: 0x05**
499 -{{/info}}
505 +(% style="color:blue" %)**Downlink Command: 0x05**
500 500  
501 501  Format: Command Code (0x05) followed by 2 bytes mode value.
502 502  
503 503  If the downlink payload=05010101, it means set end node to use confirm mode, while type code is 05.
504 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
511 +* **Example 1:** Downlink Payload: 05010101  ~/~/ Set AT+CFM=1,1,1
512 +* **Example 2:** Downlink Payload: 05000700  ~/~/ Set AT+CFM=0,7,0
507 507  
514 +(% style="display:none" %) (%%)
515 +
508 508  == 6.2 Confirm Status ==
509 509  
518 +
510 510  Feature: Get confirmation status of the last AT+SEND (0-1).
511 511  
512 -{{info}}
513 -**AT Command: AT+CFS**
514 -{{/info}}
515 515  
516 -(% border="1" style="background-color:#ffffcc; color:green; width:534.222px" %)
517 -|=(% colspan="3" style="width: 531px;" %)AT+CFS
518 -|(% style="width:156px" %)**Command Example**|(% style="width:193px" %)**Function**|(% style="width:178px" %)**Response**
519 -|(% style="width:156px" %)AT+CFS=?|(% style="width:193px" %)Get confirmation status|(% style="width:178px" %)0(((
522 +(% style="color:blue" %)**AT Command: AT+CFS**
523 +
524 +(% border="1" style="background-color:#ffffcc; color:green; width:463px" %)
525 +|=(% colspan="3" style="width: 460px;" %)AT+CFS
526 +|(% style="width:156px" %)**Command Example**|(% style="width:193px" %)**Function**|(% style="width:107px" %)**Response**
527 +|(% style="width:156px" %)AT+CFS=?|(% style="width:193px" %)Get confirmation status|(% style="width:107px" %)0(((
520 520  OK
521 521  )))
522 522  
531 +(% style="display:none" %) (%%)
532 +
523 523  == 6.3 Join LoRa® Network ==
524 524  
535 +
525 525  Feature: Join network.
526 526  
527 -{{info}}
528 -**AT Command: AT+JOIN**
529 -{{/info}}
530 530  
539 +(% style="color:blue" %)**AT Command: AT+JOIN**
540 +
531 531  (% border="1" style="background-color:#ffffcc; color:green; width:647.222px" %)
532 532  |=(% colspan="3" style="width: 644px;" %)AT+JOIN
533 533  |(% style="width:163px" %)**Command Example**|(% style="width:147px" %)**Function**|(% style="width:334px" %)**Response**
534 534  |(% style="width:163px" %)AT+JOIN ?|(% style="width:147px" %)Get imformation.|(% style="width:334px" %)AT+JOIN: Join network(((
535 535  OK
536 -
537 537  While Error in format, return AT_BUSY_ERROR
538 538  )))
539 539  
549 +(% style="display:none" %) (%%)
550 +
540 540  == 6.4 LoRa® Network Join Mode ==
541 541  
553 +
542 542  Feature: Get or Set the Network Join Mode. (0: ABP, 1: OTAA).
543 543  
544 -{{info}}
545 -**AT Command: AT+NJM**
546 -{{/info}}
547 547  
557 +(% style="color:blue" %)**AT Command: AT+NJM**
558 +
548 548  (% border="1" style="background-color:#ffffcc; color:green; width:753.222px" %)
549 549  |=(% colspan="3" style="width: 750px;" %)AT+NJM
550 550  |(% style="width:162px" %)**Command Example**|(% style="width:227px" %)**Function**|(% style="width:361px" %)**Response**
... ... @@ -554,25 +554,25 @@
554 554  |(% style="width:162px" %)AT+NJM=0|(% style="width:227px" %)Set the Network Join Mode|(% style="width:361px" %)OK
555 555  |(% 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
556 556  
557 -{{info}}
558 -**Downlink Command: 0x20**
559 -{{/info}}
568 +(% style="color:blue" %)**Downlink Command: 0x20**
560 560  
561 561  Format: Command Code (0x20) followed by 1 bytes mode value.
562 562  
563 563  If the downlink payload=2000, it means set the Network Join Mode, while type code is 20.
564 564  
565 -* **Example 1: **Downlink Payload: **2000** ~/~/ Set AT+NJM=0
566 -* **Example 2:** Downlink Payload: **2001** ~/~/ Set AT+NJM=1
574 +* **Example 1: **Downlink Payload: **2000                  ** ~/~/ Set AT+NJM=0
575 +* **Example 2:** Downlink Payload: **2001**  ~/~/ Set AT+NJM=1
567 567  
577 +(% style="display:none" %) (%%)
578 +
568 568  == 6.5 LoRa® Network Join Status ==
569 569  
581 +
570 570  Feature: LoRa® Network Join Status.
571 571  
572 -{{info}}
573 -**AT Command: AT+NJS**
574 -{{/info}}
575 575  
585 +(% style="color:blue" %)**AT Command: AT+NJS**
586 +
576 576  (% border="1" style="background-color:#ffffcc; color:green; width:498.222px" %)
577 577  |=(% colspan="3" style="width: 495px;" %)AT+NJS
578 578  |(% style="width:169px" %)**Command Example**|(% style="width:164px" %)**Function**|(% style="width:161px" %)**Response**
... ... @@ -580,14 +580,16 @@
580 580  OK
581 581  )))
582 582  
594 +(% style="display:none" %) (%%)
595 +
583 583  == 6.6 Print Last Received Data in Raw Format ==
584 584  
598 +
585 585  Feature: Print Last Received Data in Raw Format<port:data>.
586 586  
587 -{{info}}
588 -**AT Command: AT+RECV**
589 -{{/info}}
590 590  
602 +(% style="color:blue" %)**AT Command: AT+RECV**
603 +
591 591  (% border="1" style="background-color:#ffffcc; color:green; width:587.222px" %)
592 592  |=(% colspan="3" style="width: 584px;" %)AT+RECV
593 593  |(% style="width:161px" %)**Command Example**|(% style="width:272px" %)**Function**|(% style="width:150px" %)**Response**
... ... @@ -595,14 +595,16 @@
595 595  OK
596 596  )))
597 597  
611 +(% style="display:none" %) (%%)
612 +
598 598  == 6.7 Print Last Received Data in Binary Format ==
599 599  
615 +
600 600  Feature: Print Last Received Data in Binary Format<port:data>.
601 601  
602 -{{info}}
603 -**AT Command: AT+RECVB**
604 -{{/info}}
605 605  
619 +(% style="color:blue" %)**AT Command: AT+RECVB**
620 +
606 606  (% border="1" style="background-color:#ffffcc; color:green; width:793.222px" %)
607 607  |=(% colspan="3" style="width: 790px;" %)AT+RECVB
608 608  |(% style="width:173px" %)**Command Example**|(% style="width:497px" %)**Function**|(% style="width:120px" %)**Response**
... ... @@ -610,53 +610,54 @@
610 610  OK
611 611  )))
612 612  
628 +(% style="display:none" %) (%%)
629 +
613 613  == 6.8 Send Text Data ==
614 614  
632 +
615 615  Feature: Send Text Data<port:data>.
616 616  
617 -{{info}}
618 -**AT Command: AT+SEND**
619 -{{/info}}
620 620  
636 +(% style="color:blue" %)**AT Command: AT+SEND**
637 +
621 621  (% border="1" style="background-color:#ffffcc; color:green; width:991.222px" %)
622 622  |=(% colspan="3" style="width: 988px;" %)AT+SEND
623 623  |(% style="width:201px" %)**Command Example**|(% style="width:340px" %)**Function**|(% style="width:446px" %)**Response**
624 624  |(% style="width:201px" %)AT+SEND=12:hello world|(% style="width:340px" %)Send text data along with the application port.|(% style="width:446px" %)OK(((
625 625  While Error in format, return
626 -
627 627  AT_BUSY_ERROR/AT_BUSY_ERROR/AT_NO_NETWORK_JOINED
628 -
629 -
630 630  )))
631 631  
646 +(% style="display:none" %) (%%)
647 +
632 632  == 6.9 Send Hexadecimal Data ==
633 633  
650 +
634 634  Feature: Send hexadecimal data along with the application port.
635 635  
636 -{{info}}
637 -**AT Command: AT+SENDB**
638 -{{/info}}
639 639  
640 -(% border="1" style="background-color:#ffffcc; color:green; width:1120.22px" %)
641 -|=(% colspan="3" style="width: 1117px;" %)AT+SENDB
642 -|(% style="width:257px" %)**Command Example**|(% style="width:406px" %)**Function**|(% style="width:453px" %)**Response**
643 -|(% style="width:257px" %)AT+SENDB=12:abcdef0123456789|(% style="width:406px" %)Send hexadecimal data along with the application port.|(% style="width:453px" %)OK
644 -|(% 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(((
645 -AT_PARAM_ERROR AT_BUSY_ERROR/AT_NO_NETWORK_JOINED
654 +(% style="color:blue" %)**AT Command: AT+SENDB**
646 646  
647 -
656 +(% border="1" style="background-color:#ffffcc; color:green; width:1101px" %)
657 +|=(% colspan="3" style="width: 1098px;" %)AT+SENDB
658 +|(% style="width:257px" %)**Command Example**|(% style="width:394px" %)**Function**|(% style="width:446px" %)**Response**
659 +|(% style="width:257px" %)AT+SENDB=12:abcdef0123456789|(% style="width:394px" %)Send hexadecimal data along with the application port.|(% style="width:446px" %)OK
660 +|(% style="width:257px" %)AT+SENDB=abcdef0123456789|(% style="width:394px" %)Send hexadecimal data along with the application port.|(% style="width:446px" %)While Error in format, return(((
661 +AT_PARAM_ERROR AT_BUSY_ERROR/AT_NO_NETWORK_JOINED
648 648  )))
649 649  
664 +(% style="display:none" %) (%%)
665 +
650 650  = 7. LoRaWAN network management =
651 651  
652 652  == 7.1 Adaptive Data Rate ==
653 653  
670 +
654 654  Feature: Get or Set the Adaptive Data Rate setting. (0: off, 1: on).
655 655  
656 -{{info}}
657 -**AT Command: AT+ADR**
658 -{{/info}}
659 659  
674 +(% style="color:blue" %)**AT Command: AT+ADR**
675 +
660 660  (% border="1" style="background-color:#ffffcc; color:green; width:683.222px" %)
661 661  |=(% colspan="3" style="width: 680px;" %)AT+ADR
662 662  |(% style="width:162px" %)**Command Example**|(% style="width:266px" %)**Function**|(% style="width:250px" %)**Response**
... ... @@ -668,24 +668,23 @@
668 668  AT_PARAM_ERROR
669 669  )))
670 670  
671 -{{info}}
672 -**Downlink Command: 0x22**
673 -{{/info}}
687 +(% style="color:blue" %)**Downlink Command: 0x22**
674 674  
675 -
676 676  If the downlink payload=2201, it means setting the adaptive data rate to 1, while type code is 22.
677 677  
678 -* **Example 1**: Downlink Payload: **2201** ~/~/ Set AT+ADR=1.
679 -* **Example 2**: Downlink Payload: **2200FFFF** ~/~/ Set AT+ADR=0.
691 +* **Example 1**: Downlink Payload: **2201**  ~/~/ Set AT+ADR=1.
692 +* **Example 2**: Downlink Payload: **2200FFFF**  ~/~/ Set AT+ADR=0.
680 680  
694 +(% style="display:none" %) (%%)
695 +
681 681  == 7.2 LoRa® Class ==
682 682  
698 +
683 683  Feature: Get or Set the Device Class(Currently only support class A, class C).
684 684  
685 -{{info}}
686 -**AT Command:AT+CLASS**
687 -{{/info}}
688 688  
702 +(% style="color:blue" %)**AT Command:  AT+CLASS**
703 +
689 689  (% border="1" style="background-color:#ffffcc; color:green; width:507.222px" %)
690 690  |=(% colspan="3" style="width: 504px;" %)AT+CLASS
691 691  |(% style="width:163px" %)**Command Example**|(% style="width:166px" %)**Function**|(% style="width:175px" %)**Response**
... ... @@ -696,14 +696,21 @@
696 696  
697 697  )))
698 698  
714 +(% style="display:none" %)
715 +
716 +(% style="color:red" %)**Notice:**
717 +
718 +* Run AT+FDR before running AT+CLASS=C
719 +* After change to Class=C, Before OTAA Join Successfule, the end node will still shows to use CLASS=A for OTAA Joined. It will use CLASS=C after OTAA Join Succeccful.
720 +
699 699  == 7.3 Duty Cycle Setting ==
700 700  
701 -Feature: Get or Set the ETSI Duty Cycle setting - 0=disable, 1=enable - Only for testing.
702 702  
703 -{{info}}
704 -**AT Command:AT+DCS**
705 -{{/info}}
724 +Feature: Get or Set the ETSI Duty Cycle setting** - 0**=disable, **1**=enable - Only for testing.
706 706  
726 +
727 +(% style="color:blue" %)**AT Command:  AT+DCS**
728 +
707 707  (% border="1" style="background-color:#ffffcc; color:green; width:515.222px" %)
708 708  |=(% colspan="3" style="width: 512px;" %)AT+DCS
709 709  |(% style="width:165px" %)**Command Example**|(% style="width:239px" %)**Function**|(% style="width:107px" %)**Response**
... ... @@ -714,14 +714,21 @@
714 714  
715 715  )))
716 716  
739 +(% style="display:none" %) (%%)
740 +
717 717  == 7.4 Data Rate ==
718 718  
719 -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
720 720  
721 -{{info}}
722 -**AT Command: AT+DR**
723 -{{/info}}
744 +Feature: Get or Set the Data Rate. (0-7 corresponding to DR_X) .
724 724  
746 +(% style="color:red" %)
747 +**Notice:**
748 +
749 +* 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.
750 +* Data Rate specifies Spreading Factor. The mapping varies in different frequency bands. User can check this link for detail. [[rp2-1.0.3-lorawan-regional-parameters.pdf>>https://lora-alliance.org/resource_hub/rp2-1-0-3-lorawan-regional-parameters/]]
751 +
752 +(% style="color:blue" %)**AT Command: AT+DR**
753 +
725 725  (% border="1" style="background-color:#ffffcc; color:green; width:466.222px" %)
726 726  |=(% colspan="3" style="width: 463px;" %)AT+DR
727 727  |(% style="width:156px" %)**Command Example**|(% style="width:167px" %)**Function**|(% style="width:140px" %)**Response**
... ... @@ -732,24 +732,23 @@
732 732  
733 733  )))
734 734  
735 -{{info}}
736 -**Downlink Command: 0x2200aaFF**
737 -{{/info}}
764 +(% style="color:blue" %)**Downlink Command: 0x2200aaFF**
738 738  
739 -
740 740  If the downlink payload=220001FF, it means setting the data rate to 1, while type code is 22 00 aa FF.
741 741  
742 -* **Example 1**: Downlink Payload: **220001FF** ~/~/ Set AT+DR=1.
743 -* **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+DR=0.
768 +* **Example 1**: Downlink Payload: **220001FF**  ~/~/ Set AT+DR=1.
769 +* **Example 2**: Downlink Payload: **220000FF**  ~/~/ Set AT+DR=0.
744 744  
771 +(% style="display:none" %) (%%)
772 +
745 745  == 7.5 Frame Counter Downlink ==
746 746  
775 +
747 747  Feature: Get or Set the Frame Counter Downlink.
748 748  
749 -{{info}}
750 -**AT Command:AT+FCD**
751 -{{/info}}
752 752  
779 +(% style="color:blue" %)**AT Command:  AT+FCD**
780 +
753 753  (% border="1" style="background-color:#ffffcc; color:green; width:693.222px" %)
754 754  |=(% colspan="3" style="width: 690px;" %)AT+FCD
755 755  |(% style="width:162px" %)**Command Example**|(% style="width:258px" %)**Function**|(% style="width:269px" %)**Response**
... ... @@ -758,18 +758,17 @@
758 758  )))
759 759  |(% style="width:162px" %)AT+FCD=10|(% style="width:258px" %)Set the Frame Counter Downlink.|(% style="width:269px" %)(System will write new value to FCD)(((
760 760  OK
761 -
762 -
763 763  )))
764 764  
791 +(% style="display:none" %) (%%)
792 +
765 765  == 7.6 Frame Counter Uplink ==
766 766  
767 767  Feature: Get or Set the Frame Counter Uplink.
768 768  
769 -{{info}}
770 -**AT Command:AT+FCU**
771 -{{/info}}
772 772  
798 +(% style="color:blue" %)**AT Command:  AT+FCU**
799 +
773 773  (% border="1" style="background-color:#ffffcc; color:green; width:534.222px" %)
774 774  |=(% colspan="3" style="width: 531px;" %)AT+FCU
775 775  |(% style="width:177px" %)**Command Example**|(% style="width:239px" %)**Function**|(% style="width:113px" %)**Response**
... ... @@ -780,14 +780,16 @@
780 780  
781 781  )))
782 782  
810 +(% style="display:none" %) (%%)
811 +
783 783  == 7.7 Join Accept Delay1 ==
784 784  
814 +
785 785  Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 1 in ms.
786 786  
787 -{{info}}
788 -**AT Command:AT+JN1DL**
789 -{{/info}}
790 790  
818 +(% style="color:blue" %)**AT Command:  AT+JN1DL**
819 +
791 791  (% border="1" style="background-color:#ffffcc; color:green; width:537.222px" %)
792 792  |=(% colspan="3" style="width: 534px;" %)AT+JN1DL
793 793  |(% style="width:164px" %)**Command Example**|(% style="width:229px" %)**Function**|(% style="width:140px" %)**Response**
... ... @@ -798,14 +798,16 @@
798 798  
799 799  )))
800 800  
830 +(% style="display:none" %) (%%)
831 +
801 801  == 7.8 Join Accept Delay2 ==
802 802  
834 +
803 803  Feature: Get or Set the Join Accept Delay between the end of the Tx and the Join Rx Window 2 in ms.
804 804  
805 -{{info}}
806 -**AT Command:AT+JN2DL**
807 -{{/info}}
808 808  
838 +(% style="color:blue" %)**AT Command:  AT+JN2DL**
839 +
809 809  (% border="1" style="background-color:#ffffcc; color:green; width:538.222px" %)
810 810  |=(% colspan="3" style="width: 535px;" %)AT+JN2DL
811 811  |(% style="width:160px" %)**Command Example**|(% style="width:228px" %)**Function**|(% style="width:146px" %)**Response**
... ... @@ -816,16 +816,18 @@
816 816  
817 817  )))
818 818  
850 +(% style="display:none" %) (%%)
851 +
819 819  == 7.9 Public Network Mode ==
820 820  
854 +
821 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
822 822  
823 -Notice: If user build their own LoRaWAN server but still use syncword=0x34, this is still considered a public LoRaWAN network
857 +(% style="color:red" %)**Notice: If user build their own LoRaWAN server but still use syncword=0x34, this is still considered a public LoRaWAN network.**
824 824  
825 -{{info}}
826 -**AT Command:AT+PNM**
827 -{{/info}}
828 828  
860 +(% style="color:blue" %)**AT Command:  AT+PNM**
861 +
829 829  (% border="1" style="background-color:#ffffcc; color:green; width:667.222px" %)
830 830  |=(% colspan="3" style="width: 664px;" %)AT+PNM
831 831  |(% style="width:166px" %)**Command Example**|(% style="width:225px" %)**Function**|(% style="width:272px" %)**Response**
... ... @@ -843,14 +843,16 @@
843 843  )))
844 844  |(% style="width:166px" %)AT+PNM=0|(% style="width:225px" %)Set to use private network autoset syncword=0x12|(% style="width:272px" %)
845 845  
879 +(% style="display:none" %) (%%)
880 +
846 846  == 7.10 Receive Delay1 ==
847 847  
883 +
848 848  Feature: Get or Set the delay between the end of the Tx and the Rx Window 1 in ms
849 849  
850 -{{info}}
851 -**AT Command:AT+RX1DL**
852 -{{/info}}
853 853  
887 +(% style="color:blue" %)**AT Command: AT+RX1DL**
888 +
854 854  (% border="1" style="background-color:#ffffcc; color:green; width:408.222px" %)
855 855  |=(% colspan="3" style="width: 405px;" %)AT+RX1DL
856 856  |(% style="width:155px" %)**Command Example**|(% style="width:128px" %)**Function**|(% style="width:122px" %)**Response**
... ... @@ -861,14 +861,16 @@
861 861  
862 862  )))
863 863  
899 +(% style="display:none" %) (%%)
900 +
864 864  == 7.11 Receive Delay2 ==
865 865  
903 +
866 866  Feature: Get or Set the delay between the end of the Tx and the Rx Window 2 in ms
867 867  
868 -{{info}}
869 -**AT Command:AT+RX2DL**
870 -{{/info}}
871 871  
907 +(% style="color:blue" %)**AT Command: AT+RX2DL**
908 +
872 872  (% border="1" style="background-color:#ffffcc; color:green; width:481.222px" %)
873 873  |=(% colspan="3" style="width: 478px;" %)AT+RX2DL
874 874  |(% style="width:175px" %)**Command Example**|(% style="width:152px" %)**Function**|(% style="width:150px" %)**Response**
... ... @@ -879,14 +879,16 @@
879 879  
880 880  )))
881 881  
919 +(% style="display:none" %) (%%)
920 +
882 882  == 7.12 Rx2 Window Data Rate ==
883 883  
923 +
884 884  Feature: Get or Set the Rx2 window data rate (0-7 corresponding to DR_X)
885 885  
886 -{{info}}
887 -**AT Command:AT+RX2DR**
888 -{{/info}}
889 889  
927 +(% style="color:blue" %)**AT Command:  AT+RX2DR**
928 +
890 890  (% border="1" style="background-color:#ffffcc; color:green; width:525.222px" %)
891 891  |=(% colspan="3" style="width: 522px;" %)AT+RX2DR
892 892  |(% style="width:160px" %)**Command Example**|(% style="width:232px" %)**Function**|(% style="width:130px" %)**Response**
... ... @@ -897,14 +897,16 @@
897 897  
898 898  )))
899 899  
939 +(% style="display:none" %) (%%)
940 +
900 900  == 7.13 Rx2 Window Frequency ==
901 901  
943 +
902 902  Feature: Get or Set the Rx2 window frequency
903 903  
904 -{{info}}
905 -**AT Command:AT+RX2FQ**
906 -{{/info}}
907 907  
947 +(% style="color:blue" %)**AT Command:  AT+RX2FQ**
948 +
908 908  (% border="1" style="background-color:#ffffcc; color:green; width:587.222px" %)
909 909  |=(% colspan="3" style="width: 584px;" %)AT+RX2FQ
910 910  |(% style="width:183px" %)**Command Example**|(% style="width:240px" %)**Function**|(% style="width:160px" %)**Response**
... ... @@ -915,14 +915,18 @@
915 915  
916 916  )))
917 917  
959 +(% style="display:none" %) (%%)
960 +
918 918  == 7.14 Transmit Power ==
919 919  
963 +
920 920  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. )
921 921  
922 -{{info}}
923 -**AT Command:AT+TXP**
924 -{{/info}}
966 +(% 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**
925 925  
968 +
969 +(% style="color:blue" %)**AT Command:  AT+TXP**
970 +
926 926  (% border="1" style="background-color:#ffffcc; color:green; width:465.222px" %)
927 927  |=(% colspan="3" style="width: 462px;" %)AT+TXP
928 928  |(% style="width:161px" %)**Command Example**|(% style="width:189px" %)**Function**|(% style="width:112px" %)**Response**
... ... @@ -937,17 +937,19 @@
937 937  
938 938  If the downlink payload=22000100, it means setting the TXP to 0.
939 939  
940 -* **Example 1**: Downlink Payload: **22000102** ~/~/ Set AT+TXP=2.
941 -* **Example 2**: Downlink Payload: **220000FF** ~/~/ Set AT+TXP=0.
985 +* **Example 1**: Downlink Payload: **22000102**  ~/~/ Set AT+TXP=2.
986 +* **Example 2**: Downlink Payload: **22000000**  ~/~/ Set AT+TXP=0.
942 942  
988 +(% style="display:none" %) (%%)
989 +
943 943  == 7.15 RSSI of the Last Received Packet ==
944 944  
992 +
945 945  Feature: Get or Set the Rx2 window frequency
946 946  
947 -{{info}}
948 -**AT Command:AT+RSSI**
949 -{{/info}}
950 950  
996 +(% style="color:blue" %)**AT Command:AT+RSSI**
997 +
951 951  (% border="1" style="background-color:#ffffcc; color:green; width:557.222px" %)
952 952  |=(% colspan="3" style="width: 554px;" %)AT+RSSI
953 953  |(% style="width:164px" %)**Command Example**|(% style="width:289px" %)**Function**|(% style="width:100px" %)**Response**
... ... @@ -955,14 +955,16 @@
955 955  OK
956 956  )))
957 957  
1005 +(% style="display:none" %) (%%)
1006 +
958 958  == 7.16 SNR of the Last Received Packet ==
959 959  
1009 +
960 960  Feature: Get the SNR of the last received packet
961 961  
962 -{{info}}
963 -**AT Command:AT+SNR**
964 -{{/info}}
965 965  
1013 +(% style="color:blue" %)**AT Command:  AT+SNR**
1014 +
966 966  (% border="1" style="background-color:#ffffcc; color:green; width:571.222px" %)
967 967  |=(% colspan="3" style="width: 568px;" %)AT+SNR
968 968  |(% style="width:164px" %)**Command Example**|(% style="width:290px" %)**Function**|(% style="width:113px" %)**Response**
... ... @@ -970,14 +970,16 @@
970 970  OK
971 971  )))
972 972  
1022 +(% style="display:none" %) (%%)
1023 +
973 973  == 7.17 Application Port ==
974 974  
1026 +
975 975  Feature: Get or set the application port.
976 976  
977 -{{info}}
978 -**AT Command: AT+PORT**
979 -{{/info}}
980 980  
1030 +(% style="color:blue" %)**AT Command: AT+PORT**
1031 +
981 981  (% border="1" style="background-color:#ffffcc; color:green; width:500.222px" %)
982 982  |=(% colspan="3" style="width: 497px;" %)AT+PORT
983 983  |(% style="width:157px" %)**Command Example**|(% style="width:204px" %)**Function**|(% style="width:135px" %)**Response**
... ... @@ -986,25 +986,25 @@
986 986  )))
987 987  |(% style="width:157px" %)AT+PORT=21|(% style="width:204px" %)Set the application port|(% style="width:135px" %)OK
988 988  
989 -{{info}}
990 -**Downlink Command: 0x23**
991 -{{/info}}
1040 +(% style="color:blue" %)**Downlink Command: 0x23**
992 992  
993 993  Format: Command Code (0x23) followed by 1 bytes port value.
994 994  
995 995  If the downlink payload=2301, it means set the application port to 1, while type code is 23.
996 996  
997 -* **Example 1**: Downlink Payload: **2301** ~/~/ set the application port to 1
998 -* **Example 2**: Downlink Payload:** 2305** ~/~/ set the application port to 5
1046 +* **Example 1**: Downlink Payload: **2301**  ~/~/ set the application port to 1
1047 +* **Example 2**: Downlink Payload:** 2305**  ~/~/ set the application port to 5
999 999  
1049 +(% style="display:none" %) (%%)
1050 +
1000 1000  == 7.18 Single Channel Mode ==
1001 1001  
1053 +
1002 1002  Feature:Get or Set Frequency (Unit: Hz) for Single Channel Mode.
1003 1003  
1004 -{{info}}
1005 -**AT Command: AT+CHS**
1006 -{{/info}}
1007 1007  
1057 +(% style="color:blue" %)**AT Command: AT+CHS**
1058 +
1008 1008  (% border="1" style="background-color:#ffffcc; color:green; width:603.222px" %)
1009 1009  |=(% colspan="3" style="width: 600px;" %)AT+CHS
1010 1010  |(% style="width:182px" %)**Command Example**|(% style="width:295px" %)**Function**|(% style="width:122px" %)**Response**
... ... @@ -1013,14 +1013,16 @@
1013 1013  )))
1014 1014  |(% style="width:182px" %)AT+CHS=868100000|(% style="width:295px" %)Set Frequency for Single Channel Mode|(% style="width:122px" %)OK
1015 1015  
1067 +(% style="display:none" %) (%%)
1068 +
1016 1016  == 7.19 Eight Channel Mode ==
1017 1017  
1071 +
1018 1018  Feature: Get or Set eight channels mode,Only for US915,AU915,CN470.
1019 1019  
1020 -{{info}}
1021 -**AT Command: AT+CHE**
1022 -{{/info}}
1023 1023  
1075 +(% style="color:blue" %)**AT Command: AT+CHE**
1076 +
1024 1024  (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %)
1025 1025  |=(% colspan="3" style="width: 707px;" %)AT+CHE
1026 1026  |(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response**
... ... @@ -1031,25 +1031,25 @@
1031 1031  )))
1032 1032  |(% style="width:160px" %)AT+CHE=1|(% style="width:198px" %)Set eight channels mode|(% style="width:349px" %)OK
1033 1033  
1034 -{{info}}
1035 -**Downlink Command: 0x24**
1036 -{{/info}}
1087 +(% style="color:blue" %)**Downlink Command: 0x24 (LHT65,LHT65N Downlink Command:0x07)**
1037 1037  
1038 1038  Format: Command Code (0x24) followed by 1 bytes channel value.
1039 1039  
1040 1040  If the downlink payload=2401, it means set channel mode to 1, while type code is 24.
1041 1041  
1042 -* **Example 1**: Downlink Payload: 2401 ~/~/ set channel mode to 1
1043 -* **Example 2**: Downlink Payload: 2405 ~/~/ set channel mode to 5
1093 +* **Example 1**: Downlink Payload: 2401  ~/~/ set channel mode to 1
1094 +* **Example 2**: Downlink Payload: 2405  ~/~/ set channel mode to 5
1044 1044  
1096 +(% style="display:none" %) (%%)
1097 +
1045 1045  == 7.20 Get or Set RXwindows1 timeout ==
1046 1046  
1047 -Feature:Get or Set the number of symbols to detect and timeout from RXwindow1(0 to 255).
1048 1048  
1049 -{{info}}
1050 -**AT Command: AT+RX1WTO**
1051 -{{/info}}
1101 +Feature: Get or Set the number of symbols to detect and timeout from RXwindow1(0 to 255).
1052 1052  
1103 +
1104 +(% style="color:blue" %)**AT Command: AT+RX1WTO**
1105 +
1053 1053  (% border="1" style="background-color:#ffffcc; color:green; width:460.222px" %)
1054 1054  |=(% colspan="3" style="width: 457px;" %)AT+ RX1WTO
1055 1055  |(% style="width:163px" %)**Command Example**|(% style="width:201px" %)**Function**|(% style="width:93px" %)**Response**
... ... @@ -1058,8 +1058,10 @@
1058 1058  )))
1059 1059  |(% style="width:163px" %)AT+RX1WTO=60|(% style="width:201px" %)Set RXwindows1 timeout|(% style="width:93px" %)OK
1060 1060  
1114 +(% style="display:none" %) (%%)
1115 +
1061 1061  (((
1062 -**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.
1117 +(% 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.
1063 1063  )))
1064 1064  
1065 1065  [[image:image-20220526162535-1.png]]
... ... @@ -1066,18 +1066,17 @@
1066 1066  
1067 1067  (((
1068 1068  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.
1069 -
1070 -
1071 1071  )))
1072 1072  
1126 +
1073 1073  == 7.21 Get or Set RXwindows2 timeout ==
1074 1074  
1075 -Feature:Get or Set the number of symbols to detect and timeout from RXwindow2(0 to 255).
1076 1076  
1077 -{{info}}
1078 -**AT Command: AT+RX2WTO**
1079 -{{/info}}
1130 +Feature: Get or Set the number of symbols to detect and timeout from RXwindow2(0 to 255).
1080 1080  
1132 +
1133 +(% style="color:blue" %)**AT Command: AT+RX2WTO**
1134 +
1081 1081  (% border="1" style="background-color:#ffffcc; color:green; width:497.222px" %)
1082 1082  |=(% colspan="3" style="width: 494px;" %)AT+ RX2WTO
1083 1083  |(% style="width:190px" %)**Command Example**|(% style="width:199px" %)**Function**|(% style="width:104px" %)**Response**
... ... @@ -1086,14 +1086,16 @@
1086 1086  )))
1087 1087  |(% style="width:190px" %)AT+RX2WTO=20|(% style="width:199px" %)Set RXwindows2 timeout|(% style="width:104px" %)OK
1088 1088  
1143 +(% style="display:none" %) (%%)
1144 +
1089 1089  == 7.22 Setting up uplinkdwelltime (as923, au915) ==
1090 1090  
1147 +
1091 1091  Feature: Get or Set uplinkdwelltime
1092 1092  
1093 -{{info}}
1094 -**AT Command: AT+DWELLT**
1095 -{{/info}}
1096 1096  
1151 +(% style="color:blue" %)**AT Command: AT+DWELLT**
1152 +
1097 1097  (% border="1" style="background-color:#ffffcc; color:green; width:497.222px" %)
1098 1098  |=(% colspan="3" style="width: 494px;" %)AT+DWELLT
1099 1099  |(% style="width:183px" %)**Command Example**|(% style="width:179px" %)**Function**|(% style="width:131px" %)**Response**
... ... @@ -1102,23 +1102,25 @@
1102 1102  )))
1103 1103  |(% style="width:183px" %)AT+DWELLT=0|(% style="width:179px" %)Set uplinkdwelltime|(% style="width:131px" %)OK
1104 1104  
1105 -{{info}}
1106 -**Downlink Command: 0x25**
1107 -{{/info}}
1161 +(% style="color:blue" %)**Downlink Command: 0x25**
1108 1108  
1109 1109  Format: Command Code (0x25) followed by 1 bytes state value.
1110 1110  
1111 1111  If the downlink payload=2501, it means set uplinkdwelltime to 1, while type code is 25.
1112 1112  
1113 -* **Example 1**: Downlink Payload: **2501** ~/~/ set uplinkdwelltime to 1
1114 -* **Example 2**: Downlink Payload: **2500** ~/~/ set uplinkdwelltime to 0
1167 +* **Example 1**: Downlink Payload: **2501**  ~/~/ set uplinkdwelltime to 1
1168 +* **Example 2**: Downlink Payload: **2500**  ~/~/ set uplinkdwelltime to 0
1115 1115  
1170 +(% style="display:none" %) (%%)
1171 +
1116 1116  == 7.23 Set Packet Receiving Response Level ==
1117 1117  
1174 +
1118 1118  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.
1119 1119  
1120 -RPL value:
1121 1121  
1178 +**RPL value:**
1179 +
1122 1122  * **AT+RPL=0:** Device won't immediately reply any downlink commands from platform.
1123 1123  * **AT+RPL=1:** Device will immediately reply message to Unconfirmed Data Down. Payload is 0x00.
1124 1124  * **AT+RPL=2:** Device will immediately reply message to Confirmed Data Down. Payload is 0x00 and requied response header for this command.
... ... @@ -1125,15 +1125,13 @@
1125 1125  * **AT+RPL=3:** Device will immediately reply message to MAC Command. Payload is 0x00 and requied response header for this command.
1126 1126  * **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.
1127 1127  
1128 -Case Analyes:
1186 +**Case Analyes:**
1129 1129  
1130 1130  * For Class A devices, AT+RPL=0 is ok. that is defaut settings in software.
1131 1131  * For Class C devices used in ChirpStack, need to set AT+RPL=4 because Chirpstack require immedietely reply message to MAC Command.
1132 1132  * 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.
1133 1133  
1134 -{{info}}
1135 -**AT Command: AT+RPL**
1136 -{{/info}}
1192 +(% style="color:blue" %)**AT Command: AT+RPL**
1137 1137  
1138 1138  (% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %)
1139 1139  |=(% colspan="3" style="width: 533px;" %)AT+RPL
... ... @@ -1143,52 +1143,59 @@
1143 1143  )))
1144 1144  |(% style="width:160px" %)AT+RPL=0|(% style="width:263px" %)Set packet receiving response level|(% style="width:109px" %)OK
1145 1145  
1146 -{{info}}
1147 -**Downlink Command: 0x21**
1148 -{{/info}}
1202 +(% style="color:blue" %)**Downlink Command: 0x21**
1149 1149  
1150 1150  Format: Command Code (0x21) followed by 1 bytes level value.
1151 1151  
1152 1152  If the downlink payload=2101, it means set packet receiving response level to 1, while type code is 21.
1153 1153  
1154 -* **Example 1**: Downlink Payload: **2101** ~/~/ set packet receiving response level to 1
1155 -* **Example 2**: Downlink Payload: **2102** ~/~/ set packet receiving response level to 2
1208 +* **Example 1**: Downlink Payload: **2101**  ~/~/ set packet receiving response level to 1
1209 +* **Example 2**: Downlink Payload: **2102**  ~/~/ set packet receiving response level to 2
1156 1156  
1211 +(% style="display:none" %) (%%)
1212 +
1157 1157  == 7.24 Controls NBTrans in unconfirmed uplink mode(LWS007 NBTrans:Set retransmission packets) ==
1158 1158  
1159 -{{info}}
1160 -**AT Command: AT+SETMAXNBTRANS **
1161 -{{/info}}
1162 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(((
1216 +(% style="color:blue" %)**AT Command: AT+SETMAXNBTRANS **
1217 +
1218 +(% border="1" style="background-color:#ffffcc; color:green; width:589px" %)
1219 +|=(% colspan="3" style="width: 586px;" %)AT+**SETMAXNBTRANS**
1220 +|(% style="width:227px" %)**Command Example**|(% style="width:300px" %)**Function**|(% style="width:87px" %)**Response**
1221 +|(% style="width:227px" %)**AT+SETMAXNBTRANS=1,0**|(% style="width:300px" %)Value1: set the maximum NBTrans.|(% style="width:87px" %)1(((
1167 1167  OK
1168 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" %)(((
1224 +|(% style="width:227px" %)**AT+SETMAXNBTRANS=?,1**|(% style="width:300px" %)(((
1225 +value2: 0: uplink fcnt doesn't change for each NBTrans;
1226 +
1227 +1: uplink fcnt increase by 1 for each NBTrans.
1228 +)))|(% style="width:87px" %)(((
1170 1170  1
1171 1171  
1172 1172  OK
1173 1173  )))
1174 1174  
1175 -{{info}}
1176 -**Downlink Command: 0x33**
1177 -{{/info}}
1234 +(% style="color:blue" %)**Downlink Command: 0x33**
1178 1178  
1179 1179  Format: Command Code (0x33) followed by 2 bytes mode value.
1180 1180  
1181 1181  If the downlink payload=330100, it means set end node to use confirm mode, while type code is 33.
1182 1182  
1183 -* Example 1: Downlink Payload: 330100 ~/~/ Set AT+SETMAXNBTRANS=1,0
1184 -* Example 2: Downlink Payload: 330201 ~/~/ Set AT+SETMAXNBTRANS=2,1
1240 +* Example 1: Downlink Payload: 330100  ~/~/ Set AT+SETMAXNBTRANS=1,0
1241 +* Example 2: Downlink Payload: 330201  ~/~/ Set AT+SETMAXNBTRANS=2,1
1185 1185  
1243 +(% style="display:none" %) (%%)
1244 +
1186 1186  == 7.25 Device offline rejoining (LWS007) ==
1187 1187  
1188 -{{info}}
1189 -**AT Command: AT+DDETECT**
1190 -{{/info}}
1191 1191  
1248 +(% style="color:blue" %)**AT Command: AT+DDETECT**
1249 +
1250 +AT+DDETECT=<Flag>,<ACK_Timout_1>,<ACK_Timout_2> (Default Value: AT+DDETECT=1,1440,2880)
1251 +
1252 +* ACK_Timout_1: Unit: min
1253 +* ACK_Timout_2: Unit: min
1254 +
1192 1192  (% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %)
1193 1193  |=(% colspan="3" style="width: 707px;" %)AT+**DDETECT**
1194 1194  |(% style="width:160px" %)**Command Example**|(% style="width:198px" %)**Function**|(% style="width:349px" %)**Response**
... ... @@ -1220,22 +1220,25 @@
1220 1220  OK
1221 1221  )))
1222 1222  
1223 -{{info}}
1224 -**Downlink Command: 0x33**
1225 -{{/info}}
1286 +(% style="color:blue" %)**Downlink Command: 0x32**
1226 1226  
1227 1227  Format: Command Code (0x32) followed by 2 bytes mode value.
1228 1228  
1229 -If the downlink payload=320105A00B40, it means set end node to use confirm mode, while type code is 33.
1290 +If the downlink payload=320105A00B40, it means set end node to use confirm mode, while type code is 32.
1230 1230  
1231 -* Example 1: Downlink Payload: 320105A00B40 ~/~/ Set AT+DDETECT=1,1440,2880
1292 +* **Example 1:** Downlink Payload: 320105A00B40  ~/~/ Set AT+DDETECT=1,1440,2880
1293 +** 0x01 : Flag
1294 +** 0x05A0: ACK_Timout_1 : 1440minutes (24 hours)
1295 +** 0x0B40: ACK_Timout_2 : 2880minutes (48 hours)
1296 +** **Explain**: Enable Online Detect, if end node doesn't receive any downlink within ACK_Timout_1( 1440 minutes or 24 hours). End node will use confirmed uplink to send packets during ACK_Timout_1 (the 24th hour) to ACK_Timout_2 ( the 48th hour). If from the 24th to 48th hour, end node got an downlink from server, it will switch back to unconfirmed uplink. end node will restart ACK_Timout_1. If from the 24th to 48th hour, end node still not got any downlink, means device doesn't get ACK from server within last 48 hours. Device will process rejoin, rejoin request interval is AT+RJTDC period. For AU915/ US915, device will use the sub-band used for last join.
1232 1232  
1298 +(% style="display:none" %) (%%)
1299 +
1233 1233  == 7.26 Request the server to send an ACK ==
1234 1234  
1235 -{{info}}
1236 -**AT Command: AT+PNACKMD**
1237 -{{/info}}
1238 1238  
1303 +(% style="color:blue" %)**AT Command: AT+PNACKMD**
1304 +
1239 1239  (% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %)
1240 1240  |=(% colspan="3" style="width: 533px;" %)**AT+PNACKMD**
1241 1241  |(% style="width:160px" %)**Command Example**|(% style="width:263px" %)**Function**|(% style="width:109px" %)**Response**
... ... @@ -1244,55 +1244,61 @@
1244 1244  )))
1245 1245  |(% style="width:160px" %)**AT+PNACKMD=0**|(% style="width:263px" %)off request the server to send an ACK|(% style="width:109px" %)(((
1246 1246  0
1247 -
1248 1248  OK
1249 1249  )))
1250 1250  
1316 +(% style="display:none" %) (%%)
1317 +
1251 1251  == 7.27 Adjust network rejoining interval ==
1252 1252  
1253 -{{info}}
1254 -**AT Command: AT+RJTDC**
1255 -{{/info}}
1256 1256  
1321 +(% style="color:blue" %)**AT Command: AT+RJTDC**
1322 +
1257 1257  (% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %)
1258 1258  |=(% colspan="3" style="width: 724px;" %)AT+RJTDC
1259 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(((
1326 +|(% style="width:165px" %)AT+RJTDC=?|(% style="width:227px" %)Show the ReJoin data transmission interval in min|(% style="width:329px" %)30(((
1261 1261  OK
1262 1262  
1263 -the interval is 30000ms = 30s
1329 +the interval is 30 min
1264 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
1331 +|(% style="width:165px" %)AT+RJTDC=60|(% style="width:227px" %)Set the ReJoin data transmission interval in min|(% style="width:329px" %)OK(((
1332 +Set the ReJoin data transmission interval to 60 min
1267 1267  )))
1268 1268  
1269 -{{info}}
1270 -**Downlink Command: 0x26**
1271 -{{/info}}
1335 +(% style="color:blue" %)**Downlink Command: 0x26**
1272 1272  
1273 1273  Format: Command Code (0x26) followed by 2 bytes mode value.
1274 1274  
1275 1275  If the downlink payload=26000A, it means set end node to use confirm mode, while type code is 26.
1276 1276  
1277 -* Example 1: Downlink Payload: 26000A ~/~/ Set AT+RJTDC=10
1278 -* Example 2: Downlink Payload: 260002 ~/~/ Set AT+RJTDC=2
1341 +* **Example 1:** Downlink Payload: 26000A  ~/~/ Set AT+RJTDC=10
1342 +* **Example 2: **Downlink Payload: 260002  ~/~/ Set AT+RJTDC=2
1279 1279  
1344 +(% style="display:none" %) (%%)
1345 +
1280 1280  = 8. AT Commands Combination =
1281 1281  
1282 1282  == 8.1 Set a fix RX2DR for downlink window ==
1283 1283  
1284 -* **AT+ADR=0 **~-~-> Disable ADR first
1285 -* **AT+RX2DR=xxxx** ~-~-> Set xxxx to your wanted DataRate
1286 1286  
1351 +* (% style="color:blue" %)**AT+ADR=0             **(%%) **~-~->**  Disable ADR first
1352 +
1353 +* (% style="color:blue" %)**AT+RX2DR=xxxx**   (%%) **~-~->**  Set xxxx to your wanted DataRate
1354 +
1355 +(% style="display:none" %) (%%)
1356 +
1287 1287  == 8.2 Use Downlink Command to set a fix uplink DR ==
1288 1288  
1289 -{{info}}
1290 -**Downlink Command: 0x22000500**
1291 -{{/info}}
1292 1292  
1293 -Same as:
1360 +(% style="color:blue" %)**Downlink Command: 0x22000500**
1294 1294  
1295 -* AT+ADR=0  [[Reference>>||anchor="H7.1AdaptiveDataRate"]]
1296 -* AT+DR=5  [[Reference>>||anchor="H7.4DataRate"]]
1297 -* AT+TXP=0  [[Reference>>||anchor="H7.14TransmitPower"]]
1298 -~)~)~)
1362 +**Same as:**
1363 +
1364 +* AT+ADR=0  [[Reference>>||anchor="H7.1AdaptiveDataRate"]]
1365 +
1366 +* AT+DR=5  [[Reference>>||anchor="H7.4DataRate"]]
1367 +
1368 +* AT+TXP=0  [[Reference>>||anchor="H7.14TransmitPower"]]
1369 +
1370 +
Copyright ©2010-2024 Dragino Technology Co., LTD. All rights reserved
Dragino Wiki v2.0