Wiki source code of PG1302 LoRaWAN Concentrator

Version 98.24 by Xiaoling on 2022/05/14 15:40

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