Wiki source code of PG1302 LoRaWAN Concentrator

Version 99.13 by Xiaoling on 2022/05/25 16:30

Show last authors
1 (% style="text-align:center" %)
2 [[image:Main.User Manual for All Gateway models.WebHome@pg1302.jpg||height="391" width="549"]]
3
4
5
6 **PG1302 LoRaWAN Concentrator User Manual**
7
8
9 **Table of Contents:**
10
11 {{toc/}}
12
13
14 (% class="wikigeneratedid" id="H" %)
15 (((
16
17 )))
18
19 = 1. Introduction =
20
21 == 1.1 What is PG1302 LoRaWAN Concentrator? ==
22
23 (((
24 The PG1302 is a multi-channel high performance transmitter/receiver designed to simultaneously receive several LoRa packets using random spreading factors on random channels. Its goal is to enable robust connection between a central wireless data concentrator and a massive amount of wireless end-points spread over a very wide range of distances.
25 )))
26
27 (((
28 The PG1302 is design to use with Raspberry Pi to build smart metering fixed networks and Internet of Things applications with up to 5000 nodes per km2 in moderately interfered environment.
29 )))
30
31 (((
32 PG1302 is fully compatible with RPi3/4, users can use the pre-build OS from Dragino to set up and easy to use the module by Web UI. Or install the raw lorawan driver in the exist OS.
33 )))
34
35 == 1.2 Features ==
36
37 * Base on Semtech SX1302 solution
38 * Support Raspberry Pi 3B/3B+/4
39 * Up to -140dBm sensitivity
40 * Support 3.3v and 5v.
41 * Mini-PCIe Interface
42 * Converter board to support Raspberry Pi
43
44 == 1.3 General Interfaces ==
45
46 * SPI interface for LoRa
47 * Power Input: 5v, 1A
48 * 1 x I-PEX for LoRa
49
50 == 1.4 Pin Mapping ==
51
52 [[image:1651743282627-547.png||height="402" width="425"]]
53
54 == 1.5 LEDs ==
55
56 TX: Blink when transmit a packet
57 RX: Blink when receive a packet
58 Config: Always ON
59
60 == 1.6 Power Consumption ==
61
62 TBD
63
64 == 1.7 Applications ==
65
66 * Smart Buildings & Home Automation
67 * Logistics and Supply Chain Management
68 * Smart Metering
69 * Smart Agriculture
70 * Smart Cities
71 * Smart Factory
72
73 = 2. Example: Set up as LoRaWAN gateway. =
74
75 == 2.1 System structure ==
76
77 This example is an example to show how to set up the PG1302 + RPi as a LoRaWAN gateway to use with [[TheThingsNetwork>>url:http://www.thethingsnetwork.org/]](TTN) LoRaWAN server. Set up method for other server are similar.
78
79 [[image:1651743698677-436.png||height="457" width="686"]]
80
81 == 2.2 Hardware Installation ==
82
83 (% style="color:red" %)**Important Notice: Please power the RPI with 5V,3A cable.**
84
85 [[image:1651743803032-803.png]]
86
87 = 3. Install the software? =
88
89 There are two ways to install software in RPi4 to use PG1302.
90
91 * Flash SD card with Dragino pre-build image which support Web UI.
92 * Install lora packet forwarder in existing RPi OS.
93
94 = 4. Flash with pre-build image =
95
96 == 4.1 Download the dragino image for RPI ==
97
98 Download PG1302_for_Rpi4_64_with_webui from
99 [[https:~~/~~/www.dropbox.com/sh/f6nbldh1qbspya5/AACgL6pDkwdBQO1BQqq_Nubwa?dl=0>>https://www.dropbox.com/sh/f6nbldh1qbspya5/AACgL6pDkwdBQO1BQqq_Nubwa?dl=0]]
100
101 == 4.2 Flash the image to SD card ==
102
103 Flash the image to SD card:
104
105 [[image:1651744119133-233.png||height="373" width="621"]]
106
107 Note: Download the flash tool following this link
108
109 [[https:~~/~~/www.balena.io/etcher/>>https://www.balena.io/etcher/]]
110
111 == 4.3 Access the Linux console ==
112
113 Connect the RPI Ethernet port to your router, RPi will obtain an IP address from your router. In the router’s management portal, you should be able to find what IP address the router has assigned to the RPI. You can use this IP to connect the WEB UI or SSH access of RPI. Make sure your PC and the RPI is in the same network, then use a SSH tool (such as [[putty>>url:http://www.chiark.greenend.org.uk/~~sgtatham/putty/download.html]]) to access it. Below are screenshots
114
115 [[image:1651744193675-591.png||height="450" width="466"]]
116
117 The account details for Web Login are:
118
119 (((
120 **~ (% style="color:#0000ff" %)User Name: root(%%)**
121 )))
122
123 (((
124 **~ (% style="color:#0000ff" %)Password:   dragino(%%)**
125 )))
126
127 (((
128
129 )))
130
131 (((
132 **~ (% style="color:#0000ff" %)Backup account(%%)**
133 )))
134
135 (((
136 **~ (% style="color:#0000ff" %)Pi/dragino(%%)**
137 )))
138
139 After log in, you will be in the Linux console and type command here.
140
141 [[image:1651744358515-107.png||height="366" width="581"]]
142
143 == 4.4 Access the WebUI of RPi4. ==
144
145 === 4.4.1 Home page ===
146
147 Open a browser on the PC and type the RPI ip address[[http:~~/~~/IP_ADDRESS** **>>url:http://192.168.1.xx/]] (If the IP is assigned by uplink router)
148 You will see the login interface of RPI as shown below.
149 The account details for Web Login are:
150
151 (((
152 **~ (% style="color:#0000ff" %)User Name: root(%%)**
153 (% style="color:#0000ff" %)** Password:   dragino**
154 )))
155
156 [[image:1651744457761-993.png||height="352" width="621"]]
157
158 === 4.4.2 LoRa Page ===
159
160 This page shows the LoRa Radio Settings. There are a set of default frequency band according to LoRaWAN protocol, and user can customize the band* as well.
161
162 [[image:1651744554845-970.png||height="328" width="621"]]
163
164 Different PG1302 hardware version can support different frequency range:
165
166 ➢ 868: valid frequency: 863Mhz ~~ 870Mhz. for bands EU868, RU864, IN865 or KZ865.
167
168 ➢ 915: valid frequency: 902Mhz ~~ 928Mhz. for bands US915, AU915, AS923 or KR920
169
170 After user choose the frequency plan, he can see the actually frequency in used by checking the
171
172 page LogRead ~-~-> LoRa Log
173
174 Note *: [[See this instruction for how to customize frequency band>>doc:Main.How to customized LoRaWAN frequency band.WebHome]]
175
176
177 === 4.4.3 LoRaWAN Page ===
178
179 ==== 4.4.3.1 Semtech UDP ====
180
181 [[image:1651744767914-283.png||height="352" width="621"]]
182
183 Note *: [[See this instruction for how to configure TTN>>doc:Main.Notes for TTN.WebHome]].
184
185
186 ==== 4.4.3.2 Basic Station ====
187
188 [[image:1651744890629-683.png||height="380" width="621"]]
189
190 Note *: See this instruction for how to configure TTN.
191
192 [[https:~~/~~/wiki.dragino.com/index.php?title=Notes_for_AWS-IoT-Core>>url:https://wiki.dragino.com/index.php?title=Notes_for_AWS-IoT-Core]]
193
194 === 4.4.4 LogRead ===
195
196 ==== 4.4.4.1 LoRa Log ====
197
198 [[image:1651744955955-452.png||height="571" width="621"]]
199
200 Show the frequency for LoRa Radio and traffics.
201
202 ==== 4.4.4.2 System Log ====
203
204 Show system log.
205
206 [[image:1651745003470-264.png||height="477" width="621"]]
207
208 ==== 4.4.4.3 Record Log ====
209
210 **Record the system log.**
211
212 [[image:1651745069814-662.png||height="144" width="621"]]
213
214 = 5. Install stand alone LoRa Packet Forwarder. =
215
216 == 5.1 OS requirement ==
217
218 RPI in this example is RPI model 4B with fresh Raspbian OS install.
219
220 (% class="box" %)
221 (((
222 pi@raspberrypi:~~$ cat /etc/os-release
223 PRETTY_NAME="Raspbian GNU/Linux 8 (jessie)"
224 NAME="Raspbian GNU/Linux"
225 VERSION_ID="8"
226 VERSION="8 (jessie)"
227 ID=raspbian
228 ID_LIKE=debian
229 HOME_URL="http:~/~/www.raspbian.org/"
230 SUPPORT_URL="http:~/~/www.raspbian.org/RaspbianForums"
231 BUG_REPORT_URL="http:~/~/www.raspbian.org/RaspbianBugs"
232 )))
233
234 == 5.2 Get Gateway ID in Raspberry and input this in TTN v3. ==
235
236 In RPI, run below command to get a Gateway ID
237
238 (% class="box infomessage" %)
239 (((
240 ifconfig eth0
241 )))
242
243 [[image:1651745210205-512.png||height="130" width="621"]]
244
245 (((
246 (((
247 We got the ether (eth0 MAC) address is b8:27:eb:49:62:bc). Add ffff at the end and remove “:” to get the gateway ID: b827ebxxxxbcffff.  Input this to TTN v3. Make sure to select legacy packet forwarder.
248 )))
249 )))
250
251 [[image:1651745267862-321.png||height="526" width="621"]]
252
253 [[image:1651745306744-481.png||height="478" width="621"]]
254
255 After set up, the status should show not connected as below:
256
257 [[image:1651745366987-458.png||height="363" width="621"]]
258
259 === 5.2.1 Download and install LoRaWAN packet forwarder ===
260
261 Enable SPI and I2C first:
262
263 a)SPI needs to be enabled on the Raspberry Pi
264
265 Run (% style="background-color:#dcdcdc" %)**sudo raspi-config**(%%) to open the config window
266
267 [[image:1651745476754-240.png||height="234" width="629"]]
268
269 [[image:image-20220505181135-1.png]]
270
271 [[image:image-20220505181135-2.png||height="229" width="622"]]
272
273 In RPI , Fist: Enter root account:
274
275 (((
276 [[image:1651745583363-614.png||height="151" width="732"]]
277 )))
278
279 and then run:
280
281 (% style="background-color:#dcdcdc" %)wget [[https:~~/~~/www.dragino.com/downloads/downloads/LoRa_Gateway/PG1302/software/auto_install.sh>>url:https://www.dragino.com/downloads/downloads/LoRa_Gateway/PG1302/software/auto_install.sh]]
282
283 (% style="background-color:#dcdcdc" %)chmod +x ./auto_install.sh
284
285 (% style="background-color:#dcdcdc" %)./auto_install.sh
286
287 (((
288 [[image:1651745611629-818.png||height="225" width="729"]]
289 )))
290
291 This will download the packet forwarder package from Dragino Server to RPI, and start install the package.
292
293 You can get these output:
294
295 (((
296 [[image:1651745657252-173.png||height="426" width="621"]]
297 )))
298
299 === 5.2.2 Config Gateway ID, Frequency Band and Server address ===
300
301 (((
302 After installation, user can find the configuration file in** (% style="color:#0000ff" %)/etc/lora/ (%%)**Replace the gateway ID we got above to the (% style="color:#0000ff" %)**gateway_ID** (%%)in file (% style="color:#0000ff" %)**local_conf.json.**
303 )))
304
305 (((
306 The default LoRaWAN server points to localhost, user need to put the correct server address to the server_address field in file (% style="color:#0000ff" %)**local_conf.json**(%%), like below.
307 )))
308
309 [[image:1651745709709-887.png||height="820" width="621"]]
310
311 User can find the TTN v3 server address from:
312
313 [[Server Addresses ~| The Things Stack for LoRaWAN (thethingsindustries.com)>>url:https://www.thethingsindustries.com/docs/getting-started/server-addresses/#deployments]]
314
315 And the default frequency band is US915 in (% style="color:#0000ff" %)**global_conf.json**(%%) file.
316
317 [[image:1651745838008-820.png||height="650" width="621"]]
318
319 * If user want to change to other frequency bands, User can copy the file from(% style="color:#0000ff" %)** /etc/lora/cfg-302**(%%) ** **and put it into** (% style="color:#0000ff" %)/etc/lora/global_conf.json(%%).**
320
321 1).Chose your need the name of region frequency.
322
323 [[image:1651745867516-322.png||height="83" width="740"]]
324
325 2). Use this command to copy it.
326
327 cp /etc/lora/cfg-302/EU-global_conf.json /etc/lora/global_conf.json
328
329 [[image:1651745984006-868.png||height="87" width="745"]]
330
331 * If user wants to change to other LoRaWAN server, modify the (% style="color:#0000ff" %)**global_conf.json**(%%) file.
332
333 === 5.2.3 Check result ===
334
335 (((
336 Run below command to restart the dragino_fwd:
337 )))
338
339 (((
340 (% class="box infomessage" %)
341 (((
342 sudo systemctl stop draginofwd
343 )))
344
345 (% class="box infomessage" %)
346 (((
347 sudo systemctl start draginofwd
348 )))
349 )))
350
351 (((
352 debug check the ruing status of fwd:
353 )))
354
355 (((
356 (% class="box infomessage" %)
357 (((
358 sudo systemctl status draginofwd
359 )))
360 )))
361
362 [[image:1651746045057-414.png||height="193" width="729"]]
363
364 The dragino_fwd will start with the new gateway ID and TTN v3 should show the connection ok:
365
366 [[image:1651746078253-168.png||height="372" width="621"]]
367
368
369 We can check dragino_fwd running states in RPi by running:
370
371 (% class="box infomessage" %)
372 (((
373 sudo journalctl -u draginofwd -f
374 )))
375
376 [[image:1651746111963-838.png||height="184" width="730"]]
377
378 If there are LoRaWAN nodes transmitting nearby, we can see the traffic in **TTN v3 –> Gateway ~-~-> Live data**
379
380 [[image:1651746139304-966.png||height="326" width="621"]]
381
382 === 5.2.4 Commands to handle service ===
383
384 * (% style="color:#0000ff" %)**Stop** (%%)dragino_fwd service:  sudo systemctl stop draginofwd
385 * (% style="color:#0000ff" %)**Disable**(%%) dragino_fwd auto run after boot: sudo systemctl disable draginofwd
386 * (% style="color:#0000ff" %)**Start** (%%)dragino_fwd : sudo systemctl start draginofwd
387 * (% style="color:#0000ff" %)**Auto run**(%%) dragino_fwd after boot:  sudo systemctl enable draginofwd
388 * (% style="color:#0000ff" %)**Show status** (%%)of dragino_fwd:  sudo systemctl status draginofwd
389
390 = 6. Order Info =
391
392 Part Number: (% style="color:#0000ff" %)**PG1302-XX**   (%%) Or  Part Number: (% style="color:#0000ff" %)**PG1302-PI-XX   **(%%)(Include RPi converter board for RPI 3/4)
393
394 **~ (% style="color:#0000ff" %)XX:(%%)**
395
396 * (% style="color:#0000ff" %)868 (%%)(For Bands: EU868,IN865)
397 * (% style="color:#0000ff" %)915 (%%)(For Bands: US915,AU915,AS923,KR920)
398 * (% style="color:#0000ff" %)470 (%%)(For Band: CN470)
399
400 = 7. Packing Info =
401
402 (((
403 **PG1302 Package Includes**:
404 )))
405
406 (((
407 (((
408 * PG1302 x 1
409 * LoRa Antenna x 1
410 )))
411 )))
412
413 (((
414 **PG1302-PI Package Includes**:
415 )))
416
417 * PG1302 x 1
418 * LoRa Antenna x 1
419 * RPi3/4 converter PCB
420 * Screws to hole converter PCB on RPI.
421
422 (((
423 = 8. Support =
424
425 (((
426 If you are experiencing issues and can’t solve, you can send mail to
427 )))
428
429 (((
430 [[support@dragino.com>>mailto:support@dragino.com]]
431 )))
432
433 (((
434 With your question as detail as possible. We will reply and help you in the shortest.
435 )))
436 )))