<
From version < 7.3 >
edited by Xiaoling
on 2022/05/11 09:19
To version < 15.5 >
edited by Xiaoling
on 2022/05/12 11:04
>
Change comment: There is no comment for this version

Summary

Details

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