<
From version < 63.38 >
edited by Xiaoling
on 2023/05/29 14:24
To version < 38.59 >
edited by Xiaoling
on 2022/05/31 09:14
>
Change comment: There is no comment for this version

Summary

Details

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