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