Changes for page End Device AT Commands and Downlink Command
Last modified by kai on 2024/09/06 10:00
Summary
-
Page properties (1 modified, 0 added, 0 removed)
Details
- Page properties
-
- Content
-
... ... @@ -1,4 +1,4 @@ 1 - ** Table of** **Contents:**1 + **Contents:** 2 2 3 3 {{toc/}} 4 4 ... ... @@ -6,39 +6,37 @@ 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: 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]]? 21 +* For AT Command , See Devices User Manual for Device. The user manual can be found in each product page of [[Dragino Official Website>>url:http://www.dragino.com/]] 22 +* For LoRaWAN Downlink: The gateway transfer downlink command in HEX format. This page shows the HEX format downlink code for each command. but some servers use base64 as downlink code. Below are reference for how to use downlink command: 23 +** Use HEX format to send a downlink: [[TTN v3>>doc:Main.Notes for TTN.WebHome]] 24 +** Use Base64 format to send a downlink: [[Chirpstack>>doc:Main.Notes for ChirpStack.WebHome]]. 27 27 ** See use note for more serves [[Servers Note>>doc:Main.WebHome]](IoT LoRaWAN Server) 28 28 29 -(% style="display:none" %) (%%) 30 30 28 + 31 31 = 3. Support End Node and firmware version = 32 32 33 - 31 +(% border="1" style="background-color:#ffffcc; color:green; width:966px" %) 32 +|=(% 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" %)((( 34 +))) 35 +|(% style="width:187px" %)((( 38 38 **Model** 39 -)))|(% style=" background-color:#4f81bd; color:white; width:330px" %)(((37 +)))|(% style="width:330px" %)((( 40 40 **Description** 41 -)))|(% style=" background-color:#4f81bd; color:white; width:445px" %)(((39 +)))|(% style="width:445px" %)((( 42 42 **Firmware Version <~-~-> Stack Version** 43 43 ))) 44 44 |(% style="width:187px" %)((( ... ... @@ -101,20 +101,21 @@ 101 101 ))) 102 102 ))) 103 103 104 -(% style="display:none" %) (%%) 105 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 109 +(% class="box infomessage" %) 110 +((( 111 +**AT Command: AT+TDC** 112 +))) 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** 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** 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,34 @@ 124 124 Set transmit interval to 60000ms = 60 seconds 125 125 ))) 126 126 127 -((( 128 -(% style="color:blue" %)**Downlink Command: 0x01** 126 +{{info}} 127 +**Downlink Command: 0x01** 128 +{{/info}} 129 129 130 +((( 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.135 +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** 138 +* **Example 1**: Downlink Payload:** 0100001E** ~/~/ Set Transmit Interval (TDC) = 30 seconds 139 +* **Example 2**: Downlink Payload:** 0100003C** ~/~/ Set Transmit Interval (TDC) = 60 seconds 139 139 140 -(% style="display:none" %) (%%) 141 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 146 +{{info}} 147 +**AT Command: ATZ** 148 +{{/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" %)((( 150 +(% border="1" style="background-color:#ffffcc; color:green; width:727.222px" %) 151 +|=(% colspan="3" %)ATZ: Trig a reset of the MCU 152 +|**Command Example**|**Function**|**Response** 153 +|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** 167 +{{info}} 168 +**Downlink Command: 0x04** 169 +{{/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. 176 +If the downlink payload=**04FF**, the end node will reboot. 177 + 178 + 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 185 +{{info}} 186 +**AT Command: AT+FDR** 187 +{{/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" %)((( 189 +(% border="1" style="background-color:#ffffcc; color:green; width:831.222px" %) 190 +|=(% colspan="3" style="width: 828px;" %)Reset to factory default 191 +|(% style="width:181px" %)**Command Example**|(% style="width:181px" %)**Function**|(% style="width:465px" %)**Response** 192 +|(% 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** 206 +{{info}} 207 +**Downlink Command: 0x04** 208 +{{/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 223 +{{info}} 224 +**AT Command: AT+VER** 225 +{{/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" %)((( 227 +(% border="1" style="background-color:#ffffcc; color:green; width:586px" %) 228 +|=(% colspan="3" style="width: 583px;" %)AT+VER: Image Version and Frequency Band 229 +|(% style="width:170px" %)**Command Example**|(% style="width:300px" %)**Function**|(% style="width:113px" %)**Response** 230 +|(% 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)** 236 +{{info}} 237 +**Downlink Command: 0x26 (Valid in 006 stack)** 238 +{{/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:** 249 +**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:** 257 +**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** 272 +**zz: Subband** 269 269 ))) 270 270 271 271 firmware version: v1.1.0 ~-~-> 110 ... ... @@ -273,71 +273,78 @@ 273 273 274 274 == 4.5 Show System Configure == 275 275 276 - 277 277 Feature: Show All configure. No downlink command yet. 278 278 282 +{{info}} 283 +**AT Command: AT+CFG** 284 +{{/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** 286 +(% border="1" style="background-color:#ffffcc; color:green; width:599.222px" %) 287 +|=(% colspan="3" style="width: 596px;" %)AT+CFG: Print all configurations 288 +|(% 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 291 + 286 286 AT+DADDR=XXXXXXXX 293 + 287 287 ………. 295 + 288 288 AT+RX2WTO=X 297 + 289 289 AT+CHS=868100000 299 + 290 290 OK 291 291 ))) 292 292 293 -(% style="display:none" %) (%%) 294 294 304 + 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 311 +{{info}} 312 +**AT Command: AT+APPEUI** 313 +{{/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** 315 +(% border="1" style="background-color:#ffffcc; color:green; width:686.222px" %) 316 +|=(% colspan="3" style="width: 683px;" %)AT+APPEUI 317 +|(% 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 313 314 314 == 5.2 Application Key == 315 315 316 - 317 317 Feature: Get or Set the Application Key. 318 318 328 +{{info}} 329 +**AT Command: AT+APPKEY** 330 +{{/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** 332 +(% border="1" style="background-color:#ffffcc; color:green; width:976.222px" %) 333 +|=(% colspan="3" style="width: 973px;" %)AT+APPKEY 334 +|(% 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 330 331 331 == 5.3 Application Session Key == 332 332 333 - 334 334 Feature: Get or Set the Application Session Key. 335 335 345 +{{info}} 346 +**AT Command: AT+APPSKEY** 347 +{{/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** 349 +(% border="1" style="background-color:#ffffcc; color:green; width:1040.22px" %) 350 +|=(% colspan="3" style="width: 1037px;" %)AT+APPSKEY 351 +|(% 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,19 @@ 345 345 OK 346 346 ))) 347 347 348 -(% style="display:none" %) (%%) 349 349 360 + 350 350 == 5.4 Device Address == 351 351 352 - 353 353 Feature: Get or Set the Device Address. 354 354 365 +{{info}} 366 +**AT Command: AT+DADDR** 367 +{{/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** 369 +(% border="1" style="background-color:#ffffcc; color:green; width:795.222px" %) 370 +|=(% colspan="3" style="width: 792px;" %)AT+DADDR 371 +|(% 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,19 @@ 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 368 380 + 369 369 == 5.5 Device EUI == 370 370 371 - 372 372 Feature: Get or Set the Device EUI. 373 373 385 +{{info}} 386 +**AT Command: AT+DEUI** 387 +{{/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** 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** 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 387 400 + 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 405 +{{info}} 406 +**AT Command: AT+NWKID** 407 +{{/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** 409 +(% border="1" style="background-color:#ffffcc; color:green; width:448.222px" %) 410 +|=(% colspan="3" style="width: 445px;" %)AT+NWKID 411 +|(% 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 421 +{{info}} 422 +**AT Command: AT+NWKSKEY** 423 +{{/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** 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** 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.1 AT+CFM command before DR-LWS007 software stack === 427 - 428 - 429 429 Feature: Get or Set the confirmation mode (0-1). 430 430 439 +{{info}} 440 +**AT Command: AT+CFM** 441 +{{/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** 443 +(% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 444 +|=(% colspan="3" style="width: 707px;" %)AT+CFM 445 +|(% 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,106 +439,58 @@ 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**452 +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: 0500458 +* Example 1: Downlink Payload: 0501 ~/~/ Set AT+CFM=1 459 +* Example 2: Downlink Payload: 0500 ~/~/ Set AT+CFM=0 450 450 451 -(% style="display:none" %) (%%) 452 - 453 -=== 6.1.2 AT+CFM command since DR-LWS007 software stack === 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** 460 -|(% style="width:160px" %)((( 461 -AT+CFM=1,0,0 462 - 463 -value1 464 -)))|(% style="width:198px" %)confirmed uplink|(% style="width:349px" %)((( 465 -1 466 - 467 -OK 468 -))) 469 -|(% style="width:160px" %)((( 470 -AT+CFM=0,?,0 471 - 472 -value2 473 -)))|(% style="width:198px" %)set max retry , range: 0 ~~ 7|(% style="width:349px" %)((( 474 -0~~7 475 - 476 -OK 477 -))) 478 -|(% style="width:160px" %)((( 479 -AT+CFM=0,0,1 480 - 481 -value3 482 -)))|(% style="width:198px" %)uplink fcnt increase by 1 for each retry|(% style="width:349px" %)((( 483 -1 484 - 485 -OK 486 -))) 487 - 488 -(% style="color:blue" %)**Downlink Command: 0x05** 489 - 490 -Format: Command Code (0x05) followed by 2 bytes mode value. 491 - 492 -If the downlink payload=05010101, it means set end node to use confirm mode, while type code is 05. 493 - 494 -* **Example 1:** Downlink Payload: 05010101 ~/~/ Set AT+CFM=1,1,1 495 -* **Example 2:** Downlink Payload: 05000700 ~/~/ Set AT+CFM=0,7,0 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 465 +{{info}} 466 +**AT Command: AT+CFS** 467 +{{/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((( 469 +(% border="1" style="background-color:#ffffcc; color:green; width:534.222px" %) 470 +|=(% colspan="3" style="width: 531px;" %)AT+CFS 471 +|(% style="width:156px" %)**Command Example**|(% style="width:193px" %)**Function**|(% style="width:178px" %)**Response** 472 +|(% 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 480 +{{info}} 481 +**AT Command: AT+JOIN** 482 +{{/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** 484 +(% border="1" style="background-color:#ffffcc; color:green; width:647.222px" %) 485 +|=(% colspan="3" style="width: 644px;" %)AT+JOIN 486 +|(% style="width:163px" %)**Command Example**|(% style="width:147px" %)**Function**|(% style="width:334px" %)**Response** 525 525 |(% style="width:163px" %)AT+JOIN ?|(% style="width:147px" %)Get imformation.|(% style="width:334px" %)AT+JOIN: Join network((( 526 526 OK 489 + 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 497 +{{info}} 498 +**AT Command: AT+NJM** 499 +{{/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** 501 +(% border="1" style="background-color:#ffffcc; color:green; width:753.222px" %) 502 +|=(% colspan="3" style="width: 750px;" %)AT+NJM 503 +|(% 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** 510 +{{info}} 511 +**Downlink Command: 0x20** 512 +{{/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 0555 -* **Example 2:** Downlink Payload: **2001** 518 +* **Example 1: **Downlink Payload: **2000** ~/~/ Set AT+NJM=O 519 +* **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 525 +{{info}} 526 +**AT Command: AT+NJS** 527 +{{/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** 529 +(% border="1" style="background-color:#ffffcc; color:green; width:498.222px" %) 530 +|=(% colspan="3" style="width: 495px;" %)AT+NJS 531 +|(% 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 540 +{{info}} 541 +**AT Command: AT+RECV** 542 +{{/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** 544 +(% border="1" style="background-color:#ffffcc; color:green; width:587.222px" %) 545 +|=(% colspan="3" style="width: 584px;" %)AT+RECV 546 +|(% 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 555 +{{info}} 556 +**AT Command: AT+RECVB** 557 +{{/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** 559 +(% border="1" style="background-color:#ffffcc; color:green; width:793.222px" %) 560 +|=(% colspan="3" style="width: 790px;" %)AT+RECVB 561 +|(% 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 570 +{{info}} 571 +**AT Command: AT+SEND** 572 +{{/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** 574 +(% border="1" style="background-color:#ffffcc; color:green; width:991.222px" %) 575 +|=(% colspan="3" style="width: 988px;" %)AT+SEND 576 +|(% 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 579 + 619 619 AT_BUSY_ERROR/AT_BUSY_ERROR/AT_NO_NETWORK_JOINED 581 + 582 + 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 589 +{{info}} 590 +**AT Command: AT+SENDB** 591 +{{/info}} 629 629 630 -(% style="color:blue" %)**AT Command: AT+SENDB** 593 +(% border="1" style="background-color:#ffffcc; color:green; width:1120.22px" %) 594 +|=(% colspan="3" style="width: 1117px;" %)AT+SENDB 595 +|(% style="width:257px" %)**Command Example**|(% style="width:406px" %)**Function**|(% style="width:453px" %)**Response** 596 +|(% style="width:257px" %)AT+SENDB=12:abcdef0123456789|(% style="width:406px" %)Send hexadecimal data along with the application port.|(% style="width:453px" %)OK 597 +|(% 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((( 598 +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 600 + 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 609 +{{info}} 610 +**AT Command: AT+ADR** 611 +{{/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((( 613 +(% border="1" style="background-color:#ffffcc; color:green; width:683.222px" %) 614 +|=(% colspan="3" style="width: 680px;" %)AT+ADR 615 +|(% style="width:162px" %)**Command Example**|(% style="width:266px" %)**Function**|(% style="width:250px" %)**Response** 616 +|(% 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(((619 +|(% style="width:162px" %)AT+ADR=0|(% style="width:266px" %)Set the Adaptive Data Rate setting.|(% style="width:250px" %)OK 620 +|(% 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** 624 +{{info}} 625 +**Downlink Command: 0x22** 626 +{{/info}} 662 662 628 + 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** 631 +* **Example 1**: Downlink Payload: **2201** ~/~/ Set AT+ADR=1. 632 +* **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 638 +{{info}} 639 +**AT Command:AT+CLASS** 640 +{{/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** 642 +(% border="1" style="background-color:#ffffcc; color:green; width:507.222px" %) 643 +|=(% colspan="3" style="width: 504px;" %)AT+CLASS 644 +|(% 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 654 +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. 656 +{{info}} 657 +**AT Command:AT+DCS** 658 +{{/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** 660 +(% border="1" style="background-color:#ffffcc; color:green; width:515.222px" %) 661 +|=(% colspan="3" style="width: 512px;" %)AT+DCS 662 +|(% 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 672 +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) . 674 +{{info}} 675 +**AT Command: AT+DR** 676 +{{/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** 678 +(% border="1" style="background-color:#ffffcc; color:green; width:466.222px" %) 679 +|=(% colspan="3" style="width: 463px;" %)AT+DR 680 +|(% 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** 688 +{{info}} 689 +**Downlink Command: 0x2200aaFF** 690 +{{/info}} 736 736 692 + 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** 695 +* **Example 1**: Downlink Payload: **220001FF** ~/~/ Set AT+DR=1. 696 +* **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 702 +{{info}} 703 +**AT Command:AT+FCD** 704 +{{/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** 706 +(% border="1" style="background-color:#ffffcc; color:green; width:693.222px" %) 707 +|=(% colspan="3" style="width: 690px;" %)AT+FCD 708 +|(% 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 714 + 715 + 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 722 +{{info}} 723 +**AT Command:AT+FCU** 724 +{{/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** 726 +(% border="1" style="background-color:#ffffcc; color:green; width:534.222px" %) 727 +|=(% colspan="3" style="width: 531px;" %)AT+FCU 728 +|(% 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 740 +{{info}} 741 +**AT Command:AT+JN1DL** 742 +{{/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** 744 +(% border="1" style="background-color:#ffffcc; color:green; width:537.222px" %) 745 +|=(% colspan="3" style="width: 534px;" %)AT+JN1DL 746 +|(% 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 758 +{{info}} 759 +**AT Command:AT+JN2DL** 760 +{{/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** 762 +(% border="1" style="background-color:#ffffcc; color:green; width:538.222px" %) 763 +|=(% colspan="3" style="width: 535px;" %)AT+JN2DL 764 +|(% 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,46 +814,37 @@ 814 814 815 815 ))) 816 816 817 -(% style="display:none" %) (%%) 818 - 819 819 == 7.9 Public Network Mode == 820 820 774 +Feature: Get or Set the public network mode. (0: off, 1: on) 821 821 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 776 +{{info}} 777 +**AT Command:AT+PNM** 778 +{{/info}} 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.** 825 - 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** 780 +(% border="1" style="background-color:#ffffcc; color:green; width:667.222px" %) 781 +|=(% colspan="3" style="width: 664px;" %)AT+PNM 782 +|(% 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 ))) 834 -|(% style="width:166px" %)AT+PNM=1|(% style="width:225px" %)((( 835 -Set the public network mode. 836 - 837 -Set syncword=0x34 838 -)))|(% style="width:272px" %)(System will write new value to PNM)((( 786 +|(% style="width:166px" %)AT+PNM=1|(% style="width:225px" %)Set the public network mode.|(% style="width:272px" %)(System will write new value to PNM)((( 839 839 OK 840 840 841 841 842 842 ))) 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 796 +{{info}} 797 +**AT Command:AT+RX1DL** 798 +{{/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** 800 +(% border="1" style="background-color:#ffffcc; color:green; width:408.222px" %) 801 +|=(% colspan="3" style="width: 405px;" %)AT+RX1DL 802 +|(% 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 814 +{{info}} 815 +**AT Command:AT+RX2DL** 816 +{{/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** 818 +(% border="1" style="background-color:#ffffcc; color:green; width:481.222px" %) 819 +|=(% colspan="3" style="width: 478px;" %)AT+RX2DL 820 +|(% 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 832 +{{info}} 833 +**AT Command:AT+RX2DR** 834 +{{/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** 836 +(% border="1" style="background-color:#ffffcc; color:green; width:525.222px" %) 837 +|=(% colspan="3" style="width: 522px;" %)AT+RX2DR 838 +|(% 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 850 +{{info}} 851 +**AT Command:AT+RX2FQ** 852 +{{/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** 854 +(% border="1" style="background-color:#ffffcc; color:green; width:587.222px" %) 855 +|=(% colspan="3" style="width: 584px;" %)AT+RX2FQ 856 +|(% 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** 868 +{{info}} 869 +**AT Command:AT+TXP** 870 +{{/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** 872 +(% border="1" style="background-color:#ffffcc; color:green; width:465.222px" %) 873 +|=(% colspan="3" style="width: 462px;" %)AT+TXP 874 +|(% 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**886 +* **Example 1**: Downlink Payload: **22000102** ~/~/ Set AT+TXP=2. 887 +* **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 893 +{{info}} 894 +**AT Command:AT+RSSI** 895 +{{/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** 897 +(% border="1" style="background-color:#ffffcc; color:green; width:557.222px" %) 898 +|=(% colspan="3" style="width: 554px;" %)AT+RSSI 899 +|(% 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 908 +{{info}} 909 +**AT Command:AT+SNR** 910 +{{/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** 912 +(% border="1" style="background-color:#ffffcc; color:green; width:571.222px" %) 913 +|=(% colspan="3" style="width: 568px;" %)AT+SNR 914 +|(% 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 923 +{{info}} 924 +**AT Command: AT+PORT** 925 +{{/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** 927 +(% border="1" style="background-color:#ffffcc; color:green; width:500.222px" %) 928 +|=(% colspan="3" style="width: 497px;" %)AT+PORT 929 +|(% 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** 935 +{{info}} 936 +**Downlink Command: 0x23** 937 +{{/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** 943 +* **Example 1**: Downlink Payload: **2301** ~/~/ set the application port to 1 944 +* **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 950 +{{info}} 951 +**AT Command: AT+CHS** 952 +{{/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** 954 +(% border="1" style="background-color:#ffffcc; color:green; width:603.222px" %) 955 +|=(% colspan="3" style="width: 600px;" %)AT+CHS 956 +|(% 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 966 +{{info}} 967 +**AT Command: AT+CHE** 968 +{{/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** 970 +(% border="1" style="background-color:#ffffcc; color:green; width:710.222px" %) 971 +|=(% colspan="3" style="width: 707px;" %)AT+CHE 972 +|(% 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)** 980 +{{info}} 981 +**Downlink Command: 0x24** 982 +{{/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 988 +* **Example 1**: Downlink Payload: 2401 ~/~/ set channel mode to 1 989 +* **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 993 +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). 995 +{{info}} 996 +**AT Command: AT+RX1WTO** 997 +{{/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** 999 +(% border="1" style="background-color:#ffffcc; color:green; width:460.222px" %) 1000 +|=(% colspan="3" style="width: 457px;" %)AT+ RX1WTO 1001 +|(% 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.1008 +**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. 1015 + 1016 + 1079 1079 ))) 1080 1080 1081 - 1082 1082 == 7.21 Get or Set RXwindows2 timeout == 1083 1083 1021 +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). 1023 +{{info}} 1024 +**AT Command: AT+RX2WTO** 1025 +{{/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** 1027 +(% border="1" style="background-color:#ffffcc; color:green; width:497.222px" %) 1028 +|=(% colspan="3" style="width: 494px;" %)AT+ RX2WTO 1029 +|(% 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 1039 +{{info}} 1040 +**AT Command: AT+DWELLT** 1041 +{{/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** 1043 +(% border="1" style="background-color:#ffffcc; color:green; width:497.222px" %) 1044 +|=(% colspan="3" style="width: 494px;" %)AT+DWELLT 1045 +|(% 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** 1051 +{{info}} 1052 +**Downlink Command: 0x25** 1053 +{{/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** 1059 +* **Example 1**: Downlink Payload: **2501** ~/~/ set uplinkdwelltime to 1 1060 +* **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 1066 +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,183 +1136,50 @@ 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:**1074 +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** 1080 +{{info}} 1081 +**AT Command: AT+RPL** 1082 +{{/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** 1084 +(% border="1" style="background-color:#ffffcc; color:green; width:536.222px" %) 1085 +|=(% colspan="3" style="width: 533px;" %)AT+RPL 1086 +|(% 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** 1092 +{{info}} 1093 +**Downlink Command: 0x21** 1094 +{{/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** 1100 +* **Example 1**: Downlink Payload: **2101** ~/~/ set packet receiving response level to 1 1101 +* **Example 2**: Downlink Payload: **2102** ~/~/ set packet receiving response level to 2 1162 1162 1163 -(% style="display:none" %) (%%) 1164 - 1165 -== 7.24 Controls NBTrans in unconfirmed uplink mode(LWS007 NBTrans:Set retransmission packets) == 1166 - 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((( 1173 -OK 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" %)((( 1180 -1 1181 - 1182 -OK 1183 -))) 1184 - 1185 -(% style="color:blue" %)**Downlink Command: 0x33** 1186 - 1187 -Format: Command Code (0x33) followed by 2 bytes mode value. 1188 - 1189 -If the downlink payload=330100, it means set end node to use confirm mode, while type code is 33. 1190 - 1191 -* Example 1: Downlink Payload: 330100 ~/~/ Set AT+SETMAXNBTRANS=1,0 1192 -* Example 2: Downlink Payload: 330201 ~/~/ Set AT+SETMAXNBTRANS=2,1 1193 - 1194 -(% style="display:none" %) (%%) 1195 - 1196 -== 7.25 Device offline rejoining (LWS007) == 1197 - 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** 1208 -|(% style="width:160px" %)((( 1209 -AT+DDETECT=1,1440,2880 1210 - 1211 -value1 1212 -)))|(% style="width:198px" %)Enable online detect|(% style="width:349px" %)((( 1213 -1 1214 - 1215 -OK 1216 -))) 1217 -|(% style="width:160px" %)((( 1218 -AT+DDETECT=1,?,2880 1219 - 1220 -value2 1221 -)))|(% style="width:198px" %)Online detection packet sending time|(% style="width:349px" %)((( 1222 - 1223 - 1224 -OK 1225 -))) 1226 -|(% style="width:160px" %)((( 1227 -AT+DDETECT=1,1440,? 1228 - 1229 -value3 1230 -)))|(% style="width:198px" %)Process rejoin|(% style="width:349px" %)((( 1231 - 1232 - 1233 -OK 1234 -))) 1235 - 1236 -(% style="color:blue" %)**Downlink Command: 0x32** 1237 - 1238 -Format: Command Code (0x32) followed by 2 bytes mode value. 1239 - 1240 -If the downlink payload=320105A00B40, it means set end node to use confirm mode, while type code is 32. 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. 1247 - 1248 -(% style="display:none" %) (%%) 1249 - 1250 -== 7.26 Request the server to send an ACK == 1251 - 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((( 1258 -OK 1259 -))) 1260 -|(% style="width:160px" %)AT+PNACKMD=0|(% style="width:263px" %)off request the server to send an ACK|(% style="width:109px" %)((( 1261 -0 1262 -OK 1263 -))) 1264 - 1265 -(% style="display:none" %) (%%) 1266 - 1267 -== 7.27 Adjust network rejoining interval == 1268 - 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((( 1275 -OK 1276 - 1277 -the interval is 30 min 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 min 1281 -))) 1282 - 1283 -(% style="color:blue" %)**Downlink Command: 0x26** 1284 - 1285 -Format: Command Code (0x26) followed by 2 bytes mode value. 1286 - 1287 -If the downlink payload=26000A, it means set end node to use confirm mode, while type code is 26. 1288 - 1289 -* **Example 1:** Downlink Payload: 26000A ~/~/ Set AT+RJTDC=10 1290 -* **Example 2: **Downlink Payload: 260002 ~/~/ Set AT+RJTDC=2 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 1107 +* **AT+ADR=0 **~-~-> Disable ADR first 1108 +* **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 1112 +{{info}} 1113 +**Downlink Command: 0x22000500** 1114 +{{/info}} 1307 1307 1308 - (% style="color:blue"%)**Downlink Command:0x22000500**1116 +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 - 1118 +* AT+ADR=0 [[Reference>>||anchor="H7.1AdaptiveDataRate"]] 1119 +* AT+DR=5 [[Reference>>||anchor="H7.4DataRate"]] 1120 +* AT+TXP=0 [[Reference>>||anchor="H7.14TransmitPower"]]