<
From version < 75.2 >
edited by Xiaoling
on 2022/09/29 16:37
To version < 68.6 >
edited by Xiaoling
on 2022/08/18 14:42
>
Change comment: There is no comment for this version

Summary

Details

Page properties
Content
... ... @@ -30,7 +30,6 @@
30 30  
31 31  = 1.Introduction =
32 32  
33 -
34 34  == 1.1 What is RS485-LN RS485 to LoRaWAN Converter ==
35 35  
36 36  (((
... ... @@ -74,7 +74,7 @@
74 74  == 1.2 Specifications ==
75 75  
76 76  
77 -(% style="color:#037691" %)**Hardware System:**
76 +**(% style="color:#037691" %)Hardware System:**
78 78  
79 79  * STM32L072CZT6 MCU
80 80  * SX1276/78 Wireless Chip 
... ... @@ -82,13 +82,17 @@
82 82  ** Idle: 32mA@12v
83 83  ** 20dB Transmit: 65mA@12v
84 84  
85 -(% style="color:#037691" %)**Interface for Model:**
86 86  
85 +
86 +**(% style="color:#037691" %)Interface for Model:**
87 +
87 87  * RS485
88 88  * Power Input 7~~ 24V DC. 
89 89  
90 -(% style="color:#037691" %)**LoRa Spec:**
91 91  
92 +
93 +**(% style="color:#037691" %)LoRa Spec:**
94 +
92 92  * Frequency Range:
93 93  ** Band 1 (HF): 862 ~~ 1020 Mhz
94 94  ** Band 2 (LF): 410 ~~ 528 Mhz
... ... @@ -110,11 +110,12 @@
110 110  
111 111  
112 112  
116 +
113 113  == 1.3 Features ==
114 114  
115 115  
116 116  * LoRaWAN Class A & Class C protocol (default Class C)
117 -* Frequency Bands: CN470/EU433/KR920/US915/EU868/AS923/AU915/IN865/RU864/MA869
121 +* Frequency Bands: CN470/EU433/KR920/US915/EU868/AS923/AU915/IN865/RU864
118 118  * AT Commands to change parameters
119 119  * Remote configure parameters via LoRa Downlink
120 120  * Firmware upgradable via program port
... ... @@ -124,6 +124,7 @@
124 124  
125 125  
126 126  
131 +
127 127  == 1.4 Applications ==
128 128  
129 129  
... ... @@ -136,6 +136,7 @@
136 136  
137 137  
138 138  
144 +
139 139  == 1.5 Firmware Change log ==
140 140  
141 141  
... ... @@ -182,7 +182,6 @@
182 182  
183 183  = 3. Operation Mode =
184 184  
185 -
186 186  == 3.1 How it works? ==
187 187  
188 188  
... ... @@ -200,7 +200,6 @@
200 200  
201 201  Here shows an example for how to join the TTN V3 Network. Below is the network structure, we use [[LG308>>url:http://www.dragino.com/products/lora-lorawan-gateway/item/140-lg308.html]] as LoRaWAN gateway here. 
202 202  
203 -
204 204  (% aria-label="1653268155545-638.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:1653268155545-638.png||data-widget="image" height="334" width="724"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
205 205  
206 206  
... ... @@ -211,8 +211,6 @@
211 211  
212 212  (((
213 213  485A+ and 485B- of the sensor are connected to RS485A and RA485B of RS485-LN respectively.
214 -
215 -
216 216  )))
217 217  
218 218  (% aria-label="1653268227651-549.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:1653268227651-549.png||data-widget="image" height="592" width="720"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
... ... @@ -239,8 +239,6 @@
239 239  (((
240 240  (((
241 241  User can enter this key in their LoRaWAN Server portal. Below is TTN V3 screen shot:
242 -
243 -
244 244  )))
245 245  
246 246  (((
... ... @@ -254,11 +254,8 @@
254 254  
255 255  (% aria-label="image-20220519174512-3.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220519174512-3.png||data-widget="image" height="556" width="724"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
256 256  
257 -(% aria-label="image-20220519174512-4.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220519174512-4.png||data-widget="image"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]]
257 +(% aria-label="image-20220519174512-4.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220519174512-4.png||data-widget="image"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
258 258  
259 -
260 -(% title="Click and drag to resize" %)​
261 -
262 262  You can also choose to create the device manually.
263 263  
264 264  (% aria-label="1652953542269-423.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:1652953542269-423.png||data-widget="image" height="710" width="723"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
... ... @@ -270,11 +270,8 @@
270 270  (% aria-label="1652953553383-907.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:1652953553383-907.png||data-widget="image" height="514" width="724"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
271 271  
272 272  
273 -
274 274  (((
275 275  (% style="color:blue" %)**Step 2**(%%): Power on RS485-LN and it will auto join to the TTN V3 network. After join success, it will start to upload message to TTN V3 and user can see in the panel.
276 -
277 -
278 278  )))
279 279  
280 280  (% aria-label="1652953568895-172.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:1652953568895-172.png||data-widget="image" height="232" width="724"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
... ... @@ -288,8 +288,6 @@
288 288  (((
289 289  (((
290 290  There are plenty of RS485 devices in the market and each device has different command to read the valid data. To support these devices in flexible, RS485-LN supports flexible command set. User can use [[AT Commands>>||anchor="H3.5ConfigureRS485-LNviaATorDownlink"]] or LoRaWAN Downlink Command to configure what commands RS485-LN should send for each sampling and how to handle the return from RS485 devices.
291 -
292 -
293 293  )))
294 294  )))
295 295  
... ... @@ -308,7 +308,6 @@
308 308  
309 309  To use RS485-LN to read data from RS485 sensors, connect the RS485-LN A/B traces to the sensors. And user need to make sure RS485-LN use the match UART setting to access the sensors. The related commands for UART settings are:
310 310  
311 -
312 312  (% border="1" cellspacing="10" style="background-color:#ffffcc; color:green; width:510px" %)
313 313  |=(% style="width: 110px;" %)(((
314 314  **AT Commands**
... ... @@ -369,6 +369,7 @@
369 369  
370 370  
371 371  
363 +
372 372  === 3.3.2 Configure sensors ===
373 373  
374 374  
... ... @@ -398,6 +398,7 @@
398 398  
399 399  
400 400  
393 +
401 401  === 3.3.3 Configure read commands for each sampling ===
402 402  
403 403  
... ... @@ -413,7 +413,6 @@
413 413  
414 414  (% style="color:#037691" %)**Each RS485 commands include two parts:**
415 415  
416 -
417 417  ~1. What commands RS485-LN will send to the RS485 sensors. There are total 15 commands from **AT+COMMAD1**, **ATCOMMAND2**,…, to **AT+COMMANDF**. All commands are of same grammar.
418 418  
419 419  2. How to get wanted value the from RS485 sensors returns from by 1). There are total 15 AT Commands to handle the return, commands are **AT+DATACUT1**,**AT+DATACUT2**,…, **AT+DATACUTF** corresponding to the commands from 1). All commands are of same grammar.
... ... @@ -442,7 +442,7 @@
442 442  In the RS485-LN, we should use this command AT+COMMAND1=01 03 0B B8 00 02,1 for the same.
443 443  
444 444  
445 -(% style="color:#037691" %)**AT+DATACUTx **(%%)**: **This command defines how to handle the return from AT+COMMANDx, max return length is 100 bytes.
437 +(% style="color:#037691" %)**AT+DATACUTx **(%%)**: **This command defines how to handle the return from AT+COMMANDx, max return length is 45 bytes.
446 446  
447 447  (% border="1" style="background-color:#4bacc6; color:white; width:510px" %)
448 448  |(% style="width:510px" %)(((
... ... @@ -455,7 +455,6 @@
455 455  
456 456  **Examples:**
457 457  
458 -
459 459  * (% style="color:#037691" %)**Grab bytes**
460 460  
461 461  (% aria-label="image-20220602153621-1.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220602153621-1.png||data-widget="image"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
... ... @@ -496,16 +496,18 @@
496 496  )))
497 497  
498 498  (((
499 -Final Payload is (% style="color:#4f81bd" %)**Battery Info+PAYVER + VALID Value from RETURN1 + Valid Value from RETURN2 + … + RETURNx**
490 +Final Payload is
500 500  )))
501 501  
502 502  (((
503 -Where PAYVER is defined by AT+PAYVER, below is an example screen shot.
494 +(% style="color:#4f81bd" %)**Battery Info+PAYVER + VALID Value from RETURN1 + Valid Value from RETURN2 + … + RETURNx**
495 +)))
504 504  
505 -
497 +(((
498 +Where PAYVER is defined by AT+PAYVER, below is an example screen shot.
506 506  )))
507 507  
508 -[[image:image-20220929111027-1.png||height="509" width="685"]](% title="Click and drag to resize" %)​
501 +(% aria-label="1653269759169-150.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:1653269759169-150.png||data-widget="image" height="513" width="716"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
509 509  
510 510  
511 511  (% style="color:#037691" %)**Examples: AT+DATAUP=1**
... ... @@ -513,16 +513,16 @@
513 513  
514 514  Compose the uplink payload with value returns in sequence and send with (% style="color:red" %)**Multiply UPLINKs**.
515 515  
516 -Final Payload is (% style="color:#4f81bd" %)**PAYVER + PAYLOAD COUNT + PAYLOAD# + DATA**
509 +Final Payload is
517 517  
511 +(% style="color:#4f81bd" %)**Battery Info+PAYVER + PAYLOAD COUNT + PAYLOAD# + DATA**
518 518  
513 +
519 519  1. PAYVER: Defined by AT+PAYVER
520 520  1. PAYLOAD COUNT: Total how many uplinks of this sampling.
521 521  1. PAYLOAD#: Number of this uplink. (from 0,1,2,3…,to PAYLOAD COUNT)
522 522  1. DATA: Valid value: max 8 bytes for each uplink so each uplink <= 11 bytes. For the last uplink, DATA will might less than 8 bytes
523 523  
524 -
525 -
526 526  (% aria-label="image-20220602155039-4.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220602155039-4.png||data-widget="image"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
527 527  
528 528  
... ... @@ -537,7 +537,6 @@
537 537  
538 538  (% style="color:red" %)**Notice: In firmware v1.3, the Max bytes has been changed according to the max bytes in different Frequency Bands for lowest SF. As below:**
539 539  
540 -
541 541   ~* For AU915/AS923 bands, if UplinkDwell time=0, max 51 bytes for each uplink.
542 542  
543 543   * For AU915/AS923 bands, if UplinkDwell time=0, max 11 bytes for each uplink.
... ... @@ -547,15 +547,8 @@
547 547   ~* For all other bands: max 51 bytes for each uplink.
548 548  
549 549  
550 -(% style="color:red" %)** When AT+DATAUP=1, the maximum number of segments is 15, and the maximum total number of bytes is 1500;**
551 -
552 -(% style="color:red" %)** When AT+DATAUP=1 and AT+ADR=0, the maximum number of bytes of each payload is determined by the DR value. (Since v1.4.0)**
553 -
554 -
555 -
556 556  Below are the uplink payloads:
557 557  
558 -
559 559  (% aria-label="1654157178836-407.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:1654157178836-407.png||data-widget="image"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
560 560  
561 561  
... ... @@ -565,11 +565,11 @@
565 565  
566 566  Except uplink periodically, RS485-LN is able to uplink on demand. The server send downlink command to RS485-LN and RS485 will uplink data base on the command.
567 567  
568 -(% style="color:blue" %)**Downlink control command:**
553 +Downlink control command:
569 569  
570 -(% style="color:#4472c4" %)** 0x08 command**(%%): Poll an uplink with current command set in RS485-LN.
555 +**0x08 command**: Poll an uplink with current command set in RS485-LN.
571 571  
572 -(% style="color:#4472c4" %)** 0xA8 command**(%%): Send a command to RS485-LN and uplink the output from sensors.
557 +**0xA8 command**: Send a command to RS485-LN and uplink the output from sensors.
573 573  
574 574  
575 575  
... ... @@ -578,7 +578,6 @@
578 578  
579 579  RS485-LN support external Interrupt uplink since hardware v1.2 release.
580 580  
581 -
582 582  (% aria-label="1654157342174-798.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:1654157342174-798.png||data-widget="image"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
583 583  
584 584  Connect the Interrupt pin to RS485-LN INT port and connect the GND pin to V- port. When there is a high voltage (Max 24v) on INT pin. Device will send an uplink packet.
... ... @@ -588,10 +588,8 @@
588 588  == 3.4 Uplink Payload ==
589 589  
590 590  
591 -(% aria-label="image-20220606110929-1.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220606110929-1.png||data-widget="image"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]]
575 +(% aria-label="image-20220606110929-1.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220606110929-1.png||data-widget="image"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
592 592  
593 -(% title="Click and drag to resize" %)​
594 -
595 595  Below is the decoder for the first 3 bytes. The rest bytes are dynamic depends on different RS485 sensors.
596 596  
597 597  
... ... @@ -633,11 +633,8 @@
633 633  
634 634  Response feature is added to the server's downlink, a special package with a FPort of 200 will be uploaded immediately after receiving the data sent by the server.
635 635  
618 +(% aria-label="image-20220602163333-5.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220602163333-5.png||data-widget="image" height="263" width="1160"]](% title="Click and drag to resize" %)​
636 636  
637 -(% aria-label="image-20220602163333-5.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220602163333-5.png||data-widget="image" height="263" width="1160"]]
638 -
639 -(% title="Click and drag to resize" %)​
640 -
641 641  The first byte of this package represents whether the configuration is successful, 00 represents failure, 01 represents success. Except for the first byte, the other is the previous downlink. (All commands except A8 type commands are applicable)
642 642  
643 643  
... ... @@ -654,11 +654,11 @@
654 654  This command is used to configure the RS485 devices; they won't be used during sampling.
655 655  )))
656 656  
657 -(((
658 -* (% style="color:#037691" %)**AT Command**
636 +* (((
637 +(% style="color:#037691" %)**AT Command**
659 659  
660 660  (((
661 -(% style="color:#4472c4" %)** AT+CFGDEV=xx xx xx xx xx xx xx xx xx xx xx xx,m**  (%%) m: 0: no CRC, 1: add CRC-16/MODBUS in the end of this command
640 +**AT+CFGDEV=xx xx xx xx xx xx xx xx xx xx xx xx,m**  m: 0: no CRC, 1: add CRC-16/MODBUS in the end of this command
662 662  )))
663 663  )))
664 664  
... ... @@ -671,7 +671,7 @@
671 671  )))
672 672  
673 673  (((
674 -Format: (% style="color:#4472c4" %)** A8 MM NN XX XX XX XX YY**
653 +Format: A8 MM NN XX XX XX XX YY
675 675  )))
676 676  
677 677  (((
... ... @@ -777,42 +777,28 @@
777 777  This is the first byte of the uplink payload. RS485-LN can connect to different sensors. User can set the PAYVER field to tell server how to decode the current payload.
778 778  )))
779 779  
780 -(((
781 -* (% style="color:#037691" %)**AT Command:**
759 +* (((
760 +(% style="color:#037691" %)**AT Command:**
782 782  
783 -(% style="color:#4472c4" %)** AT+PAYVER:    ** (%%) Set PAYVER field = 1
762 +**AT+PAYVER:    **Set PAYVER field = 1
784 784  
785 785  
786 786  )))
787 -
788 788  * (((
789 789  (% style="color:#037691" %)**Downlink Payload:**
790 790  )))
791 791  
792 792  (((
793 -(% style="color:#4472c4" %)** 0xAE 01** (%%) ~-~->  Set PAYVER field =  0x01
771 +**0xAE 01**  ~-~->  Set PAYVER field =  0x01
794 794  )))
795 795  
796 796  (((
797 -(% style="color:#4472c4" %)** 0xAE 0F**   (%%) ~-~->  Set PAYVER field =  0x0F
775 +**0xAE 0F**   ~-~->  Set PAYVER field =  0x0F
798 798  )))
799 799  
800 800  
801 -**1 )  Add the interrupt flag at the highest bit of the Payver byte, that is, Byte7 of the first byte. (Since v1.4.0)**
802 802  
803 803  
804 -[[image:image-20220824145428-2.png||height="168" width="1300"]]
805 -
806 -
807 -
808 -**2 )  if the data intercepted by AT+DATACUT or AT+MBFUN is empty, it will display NULL, and the payload will be filled with n FFs.**
809 -
810 -
811 -[[image:image-20220824145428-3.png||height="308" width="1200"]]
812 -
813 -
814 -
815 -
816 816  ==== (% style="color:blue" %)**Set RS485 Sampling Commands**(%%) ====
817 817  
818 818  
... ... @@ -832,9 +832,9 @@
832 832  (% style="color:#037691" %)**AT Command:**
833 833  )))
834 834  
835 -(% style="color:#4472c4" %)** AT+COMMANDx:    ** (%%) Configure RS485 read command to sensor.
800 +**AT+COMMANDx:    **Configure RS485 read command to sensor.
836 836  
837 -(% style="color:#4472c4" %)** AT+DATACUTx:        **(%%) Configure how to handle return from RS485 devices.
802 +**AT+DATACUTx:        **Configure how to handle return from RS485 devices.
838 838  
839 839  
840 840  * (((
... ... @@ -842,19 +842,19 @@
842 842  )))
843 843  
844 844  (((
845 -(% style="color:#4472c4" %)** 0xAF**(%%) downlink command can be used to set AT+COMMANDx or AT+DATACUTx.
810 +**0xAF** downlink command can be used to set AT+COMMANDx or AT+DATACUTx.
846 846  
847 847  
848 848  )))
849 849  
850 850  (((
851 -(% style="color:red" %)**Note : if user use AT+COMMANDx to add a new command, he also need to send AT+DATACUTx downlink.**
816 +(% style="color:red" %)**Note**(%%): if user use AT+COMMANDx to add a new command, he also need to send AT+DATACUTx downlink.
852 852  
853 853  
854 854  )))
855 855  
856 856  (((
857 -Format: (% style="color:#4472c4" %)** AF MM NN LL XX XX XX XX YY**
822 +Format: AF MM NN LL XX XX XX XX YY
858 858  )))
859 859  
860 860  (((
... ... @@ -902,7 +902,7 @@
902 902  
903 903  
904 904  (((
905 -(% style="color:#4472c4" %)** AT+MBFUN**(%%) is valid since v1.3 firmware version. The command is for fast configure to read Modbus devices. It is only valid for the devices which follow the [[MODBUS-RTU protocol>>url:https://www.modbustools.com/modbus.html]].
870 +**AT+MBFUN** is valid since v1.3 firmware version. The command is for fast configure to read Modbus devices. It is only valid for the devices which follow the [[MODBUS-RTU protocol>>url:https://www.modbustools.com/modbus.html]].
906 906  )))
907 907  
908 908  (((
... ... @@ -933,10 +933,8 @@
933 933  
934 934  )))
935 935  
936 -(% aria-label="image-20220602165351-6.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220602165351-6.png||data-widget="image"]]
901 +(% aria-label="image-20220602165351-6.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220602165351-6.png||data-widget="image"]](% title="Click and drag to resize" %)​
937 937  
938 -(% title="Click and drag to resize" %)​
939 -
940 940  (% aria-label="image-20220602165351-7.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220602165351-7.png||data-widget="image"]](% title="Click and drag to resize" %)​
941 941  
942 942  
... ... @@ -953,10 +953,10 @@
953 953  Default value: 0, range:  0 ~~ 65 seconds
954 954  )))
955 955  
956 -(((
957 -* (% style="color:#037691" %)** AT Command:**
919 +* (((
920 +(% style="color:#037691" %)** AT Command:**
958 958  
959 -(% style="color:#4472c4" %)** AT+CMDDLaa=hex(bb cc)*1000**
922 +**AT+CMDDLaa=hex(bb cc)*1000**
960 960  )))
961 961  
962 962  (((
... ... @@ -966,7 +966,7 @@
966 966  )))
967 967  
968 968  (((
969 -(% style="color:#4472c4" %)** AT+CMDDL1=1000** (%%)to send the open time to 1000ms
932 +**AT+CMDDL1=1000** to send the open time to 1000ms
970 970  )))
971 971  
972 972  (((
... ... @@ -978,12 +978,14 @@
978 978  )))
979 979  
980 980  (((
981 -(% style="color:#4472c4" %)** 0x AA aa bb cc**(%%) Same as: AT+CMDDLaa=hex(bb cc)*1000
944 +**0x AA aa bb cc**
982 982  )))
983 983  
984 984  (((
985 -
948 +Same as: AT+CMDDLaa=hex(bb cc)*1000
949 +)))
986 986  
951 +(((
987 987  **Example:**
988 988  )))
989 989  
... ... @@ -1007,19 +1007,13 @@
1007 1007  
1008 1008  )))
1009 1009  
1010 -(((
1011 -* (% style="color:#037691" %)** AT Command:**
1012 -
1013 -(% style="color:#4472c4" %)** AT+DATAUP=0**
1014 -
1015 -(% style="color:#4472c4" %)** AT+DATAUP=1**
1016 -
1017 -
975 +* (((
976 +(% style="color:#037691" %)** AT Command:**
1018 1018  )))
1019 1019  
1020 -(% style="color:#4472c4" %)** 0xAD 01 00 00 14** (%%) **~-~->** Same as AT+DATAUP=1,20000  ~/~/  (00 00 14 is 20 seconds)
979 +**AT+DATAUP=0**
1021 1021  
1022 -Each uplink is sent to the server at 20-second intervals when segmented.
981 +**AT+DATAUP=1**
1023 1023  
1024 1024  
1025 1025  * (((
... ... @@ -1026,29 +1026,17 @@
1026 1026  (% style="color:#037691" %)** Downlink Payload:**
1027 1027  )))
1028 1028  
1029 -(% style="color:#4472c4" %)** 0xAD 00** (%%) **~-~->** Same as AT+DATAUP=0
1030 -
1031 -(% style="color:#4472c4" %)** 0xAD 01**  (%%) **~-~->** Same as AT+DATAUP=1  ~/~/Each uplink is sent to the server one after the other as it is segmented.
1032 -
1033 -
1034 -* (((
1035 -(% style="color:#037691" %)** AT Command:**
988 +(((
989 +**0xAD 00**  **~-~->** Same as AT+DATAUP=0
1036 1036  )))
1037 1037  
1038 -(% style="color:#4472c4" %)** AT+DATAUP=1,Timeout**
1039 -
1040 -
1041 -* (((
1042 -(% style="color:#037691" %)** Downlink Payload:**
992 +(((
993 +**0xAD 01**  **~-~->** Same as AT+DATAUP=1
1043 1043  )))
1044 1044  
1045 -(% style="color:#4472c4" %)** 0xAD 01 00 00 14** (%%) **~-~->** Same as AT+DATAUP=1,20000  ~/~/  (00 00 14 is 20 seconds)
1046 1046  
1047 -Each uplink is sent to the server at 20-second intervals when segmented.
1048 1048  
1049 1049  
1050 -
1051 -
1052 1052  ==== (% style="color:blue" %)**Manually trigger an Uplink**(%%) ====
1053 1053  
1054 1054  
... ... @@ -1073,7 +1073,7 @@
1073 1073  )))
1074 1074  
1075 1075  (((
1076 -(% style="color:#4472c4" %)** 0x08 FF**(%%), RS485-LN will immediately send an uplink.
1023 +**0x08 FF**, RS485-LN will immediately send an uplink.
1077 1077  )))
1078 1078  
1079 1079  
... ... @@ -1093,12 +1093,10 @@
1093 1093  )))
1094 1094  
1095 1095  (((
1096 -(% style="color:#4472c4" %)** AT+CMDEAR=mm,nn** (%%) mm: start position of erase ,nn: stop position of erase
1043 +**AT+CMDEAR=mm,nn**   mm: start position of erase ,nn: stop position of erase
1097 1097  )))
1098 1098  
1099 1099  (((
1100 -
1101 -
1102 1102  Etc. AT+CMDEAR=1,10 means erase AT+COMMAND1/AT+DATACUT1 to AT+COMMAND10/AT+DATACUT10
1103 1103  )))
1104 1104  
... ... @@ -1122,7 +1122,7 @@
1122 1122  )))
1123 1123  
1124 1124  (((
1125 -(% style="color:#4472c4" %)** 0x09 aa bb** (%%) same as AT+CMDEAR=aa,bb
1070 +**0x09 aa bb** same as AT+CMDEAR=aa,bb
1126 1126  )))
1127 1127  
1128 1128  
... ... @@ -1133,22 +1133,19 @@
1133 1133  
1134 1134  (((
1135 1135  Set the Rs485 serial communication parameters:
1136 -
1137 -
1138 1138  )))
1139 1139  
1140 1140  * (((
1141 1141  (% style="color:#037691" %)** AT Command:**
1142 -
1143 -
1144 -
1145 1145  )))
1146 1146  
1147 1147  (((
1088 +
1089 +
1148 1148  * Set Baud Rate
1149 1149  )))
1150 1150  
1151 -(% style="color:#4472c4" %)** AT+BAUDR=9600** (%%) ~/~/  Options: (200~~115200)  When using low baud rate or receiving multiple bytes, you need to use AT+CMDDL to increase the receive timeout (the default receive timeout is 400ms), otherwise data will be lost
1093 +**AT+BAUDR=9600**    ~/~/ Options: (1200,2400,4800,14400,19200,115200)
1152 1152  
1153 1153  
1154 1154  (((
... ... @@ -1155,7 +1155,7 @@
1155 1155  * Set UART Parity
1156 1156  )))
1157 1157  
1158 -(% style="color:#4472c4" %)** AT+PARITY=0** (%%) ~/~/  Option: 0: no parity, 1: odd parity, 2: even parity
1100 +**AT+PARITY=0**    ~/~/ Option: 0: no parity, 1: odd parity, 2: even parity
1159 1159  
1160 1160  
1161 1161  (((
... ... @@ -1162,7 +1162,7 @@
1162 1162  * Set STOPBIT
1163 1163  )))
1164 1164  
1165 -(% style="color:#4472c4" %)** AT+STOPBIT=0** (%%) ~/~/  Option: 0 for 1bit; 1 for 1.5 bit ; 2 for 2 bits
1107 +**AT+STOPBIT=0**    ~/~/ Option: 0 for 1bit; 1 for 1.5 bit ; 2 for 2 bits
1166 1166  
1167 1167  
1168 1168  
... ... @@ -1171,17 +1171,15 @@
1171 1171  )))
1172 1172  
1173 1173  (((
1174 -(% style="color:#4472c4" %)** A7 01 aa bb**:   (%%) Same  AT+BAUDR=hex(aa bb)*100
1116 +**A7 01 aa bb**:  Same  AT+BAUDR=hex(aa bb)*100
1175 1175  )))
1176 1176  
1177 1177  (((
1178 -
1179 -
1180 1180  **Example:**
1181 1181  )))
1182 1182  
1183 1183  * (((
1184 -A7 01 00 60  same as AT+BAUDR=9600
1124 +A7 01 00 60   same as AT+BAUDR=9600
1185 1185  )))
1186 1186  * (((
1187 1187  A7 01 04 80  same as AT+BAUDR=115200
... ... @@ -1188,153 +1188,16 @@
1188 1188  )))
1189 1189  
1190 1190  (((
1191 -* A7 02 aa:  Same as  AT+PARITY=aa  (aa value: 00 , 01 or 02)
1131 +A7 02 aa:  Same as  AT+PARITY=aa  (aa value: 00 , 01 or 02)
1192 1192  )))
1193 1193  
1194 1194  (((
1195 -* A7 03 aa:  Same as  AT+STOPBIT=aa  (aa value: 00 , 01 or 02)
1135 +A7 03 aa:  Same as  AT+STOPBIT=aa  (aa value: 00 , 01 or 02)
1196 1196  )))
1197 1197  
1198 1198  
1199 1199  
1200 1200  
1201 -
1202 -==== (% style="color:blue" %)**Encrypted payload**(%%) ====
1203 -
1204 -(((
1205 -
1206 -)))
1207 -
1208 -* (((
1209 -(% style="color:#037691" %)** AT Command:**
1210 -)))
1211 -
1212 -(% style="color:#4472c4" %)** AT+DECRYPT=1  ** (%%) ~/~/ The payload is uploaded without encryption
1213 -
1214 -(% style="color:#4472c4" %)** AT+DECRYPT=0  ** (%%) ~/~/ Encrypt when uploading payload (default)
1215 -
1216 -
1217 -
1218 -
1219 -==== (% style="color:blue" %)**Get sensor value**(%%) ====
1220 -
1221 -
1222 -* (((
1223 -(% style="color:#037691" %)** AT Command:**
1224 -)))
1225 -
1226 -(% style="color:#4472c4" %)** AT+GETSENSORVALUE=0  **(%%) ~/~/ The serial port gets the reading of the current sensor
1227 -
1228 -(% style="color:#4472c4" %)** AT+GETSENSORVALUE=1  **(%%) ~/~/ The serial port gets the current sensor reading and uploads it.
1229 -
1230 -
1231 -
1232 -
1233 -==== (% style="color:blue" %)**Resets the downlink packet count**(%%) ====
1234 -
1235 -
1236 -* (((
1237 -(% style="color:#037691" %)** AT Command:**
1238 -)))
1239 -
1240 -(% style="color:#4472c4" %)** AT+DISFCNTCHECK=0  **(%%) ~/~/  When the downlink packet count sent by the server is less than the node downlink packet count or exceeds 16384, the node will no longer receive downlink packets (default)
1241 -
1242 -(% style="color:#4472c4" %)** AT+DISFCNTCHECK=1  **(%%) ~/~/  When the downlink packet count sent by the server is less than the node downlink packet count or exceeds 16384, the node resets the downlink packet count and keeps it consistent with the server downlink packet count.
1243 -
1244 -
1245 -
1246 -
1247 -==== (% style="color:blue" %)**When the limit bytes are exceeded, upload in batches**(%%) ====
1248 -
1249 -
1250 -* (((
1251 -(% style="color:#037691" %)** AT Command:**
1252 -)))
1253 -
1254 - (% style="color:#4472c4" %)** AT+DISMACANS=0**  (%%) ~/~/  When the MACANS of the reply server plus the payload exceeds the maximum number of bytes of 11 bytes (DR0 of US915, DR2 of AS923, DR2 of AU195), the node will send a packet with a payload of 00 and a port of 4. (default)
1255 -
1256 - (% style="color:#4472c4" %)** AT+DISMACANS=1**   (%%) ~/~/  When the MACANS of the reply server plus the payload exceeds the maximum number of bytes of the DR, the node will ignore the MACANS and not reply, and only upload the payload part.
1257 -
1258 -
1259 -* (((
1260 -(% style="color:#037691" %)** Downlink Payload:**
1261 -)))
1262 -
1263 -(% style="color:#4472c4" %)** 0x21 00 01 ** (%%) ~/~/ Set  the DISMACANS=1
1264 -
1265 -
1266 -
1267 -
1268 -==== (% style="color:blue" %)** Copy downlink to uplink **(%%) ====
1269 -
1270 -
1271 -* (((
1272 -(% style="color:#037691" %)** AT Command:**
1273 -)))
1274 -
1275 -(% style="color:#4472c4" %)** AT+RPL=5**  (%%) ~/~/ After receiving the package from the server, it will immediately upload the content of the package to the server, the port number is 100.
1276 -
1277 -
1278 -Example:**aa xx xx xx xx**         ~/~/ aa indicates whether the configuration has changed, 00 is yes, 01 is no; xx xx xx xx are the bytes sent.
1279 -
1280 -
1281 -[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/image-20220823173747-6.png?width=1124&height=165&rev=1.1||alt="image-20220823173747-6.png"]]
1282 -
1283 -
1284 -
1285 -For example, sending 11 22 33 44 55 66 77 will return invalid configuration 00 11 22 33 44 55 66 77.
1286 -
1287 -
1288 -[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/image-20220823173833-7.png?width=1124&height=149&rev=1.1||alt="image-20220823173833-7.png"]]
1289 -
1290 -
1291 -For example, if 01 00 02 58 is issued, a valid configuration of 01 01 00 02 58 will be returned.
1292 -
1293 -
1294 -
1295 -
1296 -==== (% style="color:blue" %)**Query version number and frequency band 、TDC**(%%) ====
1297 -
1298 -
1299 -(((
1300 -* (% style="color:#037691" %)**Downlink Payload:**
1301 -
1302 -(% style="color:#4472c4" %)** 26 01  ** (%%) ~/~/  Downlink 26 01 can query device upload frequency, frequency band, software version number, TDC time.
1303 -)))
1304 -
1305 -
1306 -Example:
1307 -
1308 -
1309 -[[image:http://wiki.dragino.com/xwiki/bin/download/Main/User%20Manual%20for%20LoRaWAN%20End%20Nodes/LSN50%20%26%20LSN50-V2%20-%20LoRaWAN%20Sensor%20Node%20User%20Manual/WebHome/image-20220823173929-8.png?width=1205&height=76&rev=1.1||alt="image-20220823173929-8.png"]]
1310 -
1311 -
1312 -
1313 -
1314 -==== (% style="color:blue" %)** Monitor RS485 communication of other devices**(%%) ====
1315 -
1316 -
1317 -* (((
1318 -(% style="color:#037691" %)** AT Command:**
1319 -)))
1320 -
1321 -(% style="color:#4472c4" %)**AT+RXMODE=1,10**    (%%) ~/~/ When the RS485-LN receives more than 10 bytes from the RS485, it immediately sends the uplink of the received data.
1322 -
1323 -(% style="color:#4472c4" %)**AT+RXMODE=2,500    ** (%%) ~/~/  RS485-LN uploads data as uplink from the first byte received by RS485 to the data received within 500ms after that.
1324 -
1325 -(% style="color:#4472c4" %)**AT+RXMODE=0,0  ** (%%) ~/~/  Disable this mode (default)
1326 -
1327 -
1328 -* (((
1329 -(% style="color:#037691" %)**Downlink Payload:**
1330 -)))
1331 -
1332 -(% style="color:#4472c4" %)** A6 aa bb bb               ** (%%) ~/~/same as AT+RXMODE=aa,bb
1333 -
1334 -[[image:image-20220824144240-1.png]]
1335 -
1336 -
1337 -
1338 1338  == 3.6 Listening mode for RS485 network ==
1339 1339  
1340 1340  
... ... @@ -1348,12 +1348,10 @@
1348 1348  
1349 1349  )))
1350 1350  
1351 -(% aria-label="image-20220602171200-8.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220602171200-8.png||data-widget="image" height="567" width="1007"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]]
1154 +(% aria-label="image-20220602171200-8.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:image-20220602171200-8.png||data-widget="image" height="567" width="1007"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
1352 1352  
1353 -(% title="Click and drag to resize" %)​
1354 -
1355 1355  (((
1356 -To enable the listening mode, use can run the command (% style="color:#4472c4" %)** AT+RXMODE**.
1157 +To enable the listening mode, use can run the command AT+RXMODE.
1357 1357  )))
1358 1358  
1359 1359  (((
... ... @@ -1388,13 +1388,11 @@
1388 1388  )))
1389 1389  
1390 1390  (((
1391 -
1392 -
1393 -(% style="color:#037691" %)**Downlink Command:**
1192 +(% style="color:#037691" %)** Downlink Command:**
1394 1394  )))
1395 1395  
1396 1396  (((
1397 -(% style="color:#4472c4" %)** 0xA6 aa bb cc **(%%) same as AT+RXMODE=aa,(bb<<8 | cc)
1196 +**0xA6 aa bb cc ** same as AT+RXMODE=aa,(bb<<8 | cc)
1398 1398  )))
1399 1399  
1400 1400  (((
... ... @@ -1423,8 +1423,6 @@
1423 1423  
1424 1424  (((
1425 1425  RS485-LN will capture both and send the uplink: (% style="background-color:#ffc000" %)01 03 00 00 00 02 c4 0b  (% style="background-color:green" %)01 03 04 00 00 00 00 fa 33
1426 -
1427 -
1428 1428  )))
1429 1429  
1430 1430  (((
... ... @@ -1454,6 +1454,8 @@
1454 1454  
1455 1455  
1456 1456  
1254 +
1255 +
1457 1457  == 3.8 LEDs ==
1458 1458  
1459 1459  
... ... @@ -1464,6 +1464,8 @@
1464 1464  
1465 1465  
1466 1466  
1266 +
1267 +
1467 1467  = 4. Case Study =
1468 1468  
1469 1469  
... ... @@ -1479,18 +1479,13 @@
1479 1479  
1480 1480  (((
1481 1481  RS485-LN supports AT Command set. User can use a USB to TTL adapter plus the 3.5mm Program Cable to connect to RS485-LN to use AT command, as below.
1482 -
1483 -
1484 1484  )))
1485 1485  
1486 1486  (% aria-label="1654162355560-817.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:1654162355560-817.png||data-widget="image"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
1487 1487  
1488 1488  
1489 -
1490 1490  (((
1491 1491  In PC, User needs to set (% style="color:blue" %)**serial tool**(%%)(such as [[putty>>url:https://www.chiark.greenend.org.uk/~~sgtatham/putty/latest.html]], SecureCRT) baud rate to (% style="color:green" %)**9600**(%%) to access to access serial console of RS485-LN. The default password is 123456. Below is the output for reference:
1492 -
1493 -
1494 1494  )))
1495 1495  
1496 1496  (% aria-label="1654162368066-342.png image widget" contenteditable="false" role="region" tabindex="-1" %)[[image:1654162368066-342.png||data-widget="image"]](% style="background-image:url(http://wiki.dragino.com/xwiki/webjars/wiki%3Axwiki/application-ckeditor-webjar/1.61/plugins/widget/images/handle.png); background:rgba(220,220,220,0.5); display:none" %)[[image:||draggable="true" height="15" role="presentation" title="Click and drag to move" width="15"]](% title="Click and drag to resize" %)​
... ... @@ -1596,20 +1596,14 @@
1596 1596  
1597 1597  (((
1598 1598  (% style="color:blue" %)**Step1**(%%)**:** Download [[flash loader>>url:https://www.st.com/content/st_com/en/products/development-tools/software-development-tools/stm32-software-development-tools/stm32-programmers/flasher-stm32.html]].
1599 -
1600 -
1601 1601  )))
1602 1602  
1603 1603  (((
1604 -(% style="color:blue" %)**Step2**(%%)**:** Download the [[LT Image files>>url:https://www.dropbox.com/sh/g99v0fxcltn9r1y/AACP33wo_ZQLsxW2MJ70oUoba/RS485-LN/Firmware?dl=0&subfolder_nav_tracking=1]].
1605 -
1606 -
1398 +(% style="color:blue" %)**Step2**(%%)**:** Download the [[LT Image files>>url:https://www.dragino.com/downloads/index.php?dir=RS485-LN/Firmware/]].
1607 1607  )))
1608 1608  
1609 1609  (((
1610 1610  (% style="color:blue" %)**Step3**(%%)**: **Open flashloader; choose the correct COM port to update.
1611 -
1612 -
1613 1613  )))
1614 1614  
1615 1615  (((
... ... @@ -1710,6 +1710,8 @@
1710 1710  
1711 1711  
1712 1712  
1503 +
1504 +
1713 1713  = 9.Packing Info =
1714 1714  
1715 1715  
... ... @@ -1728,6 +1728,8 @@
1728 1728  
1729 1729  
1730 1730  
1523 +
1524 +
1731 1731  = 10. FCC Caution for RS485LN-US915 =
1732 1732  
1733 1733  
... ... @@ -1748,7 +1748,7 @@
1748 1748  )))
1749 1749  
1750 1750  (((
1751 -(% style="color:red" %)**Note: **(%%)This equipment has been tested and found to comply with the limits for a Class B digital device, pursuant to part 15 of the FCC Rules. These limits are designed to provide reasonable protection against harmful interference in a residential installation. This equipment generates, uses and can radiate radio frequency energy and, if not installed and used in accordance with the instructions, may cause harmful interference to radio communications. However, there is no guarantee that interference will not occur in a particular installation. If this equipment does cause harmful interference to radio or television reception, which can be determined by turning the equipment off and on, the user is encouraged to try to correct the interference by one or more of the following measures:
1545 +**(% style="color:red" %)Note: **(%%)This equipment has been tested and found to comply with the limits for a Class B digital device, pursuant to part 15 of the FCC Rules. These limits are designed to provide reasonable protection against harmful interference in a residential installation. This equipment generates, uses and can radiate radio frequency energy and, if not installed and used in accordance with the instructions, may cause harmful interference to radio communications. However, there is no guarantee that interference will not occur in a particular installation. If this equipment does cause harmful interference to radio or television reception, which can be determined by turning the equipment off and on, the user is encouraged to try to correct the interference by one or more of the following measures:
1752 1752  )))
1753 1753  
1754 1754  (((
image-20220824144240-1.png
Author
... ... @@ -1,1 +1,0 @@
1 -XWiki.Bei
Size
... ... @@ -1,1 +1,0 @@
1 -110.9 KB
Content
image-20220824145428-2.png
Author
... ... @@ -1,1 +1,0 @@
1 -XWiki.Bei
Size
... ... @@ -1,1 +1,0 @@
1 -12.6 KB
Content
image-20220824145428-3.png
Author
... ... @@ -1,1 +1,0 @@
1 -XWiki.Bei
Size
... ... @@ -1,1 +1,0 @@
1 -17.7 KB
Content
image-20220929111027-1.png
Author
... ... @@ -1,1 +1,0 @@
1 -XWiki.Bei
Size
... ... @@ -1,1 +1,0 @@
1 -240.0 KB
Content
Copyright ©2010-2024 Dragino Technology Co., LTD. All rights reserved
Dragino Wiki v2.0