FEDER:Lora Network Installation: Difference between revisions

From UNamur InfoSec
Jump to navigation Jump to search
No edit summary
No edit summary
Line 88: Line 88:


         b. File: lora_gateway/libloragw/src/loragw_spi.ftdi.c
         b. File: lora_gateway/libloragw/src/loragw_spi.ftdi.c
         As second step a small modification must be done in one of the low-level connection files. The WiMOD iC880A LoRa Concentrator board uses a FTDI USB to SPI converter chip that is not          supported in Semtech’s reference code. The only difference is another USB PID. Therefore, the USB PID settings in the libloragw library have to be adjusted prior compiling the library.
 
         As second step a small modification must be done in one of the low-level connection files. The WiMOD iC880A LoRa Concentrator board uses a FTDI USB to SPI converter chip that is not  
 
         supported in Semtech’s reference code. The only difference is another USB PID. Therefore, the USB PID settings in the libloragw library have to be adjusted prior compiling the library.
 
         Open the file lora_gateway/libloragw/src/loragw_spi.ftdi.c with your favorite editor (e.g. nano)
         Open the file lora_gateway/libloragw/src/loragw_spi.ftdi.c with your favorite editor (e.g. nano)


Line 140: Line 144:


               ATTRS{idProduct}=="6010”
               ATTRS{idProduct}=="6010”
               to:
               to:
               ATTRS{idProduct}=="6014”
               ATTRS{idProduct}=="6014”


Line 160: Line 166:


         a. Installing the LORIOT software
         a. Installing the LORIOT software
i. Sign up for an account.
 
ii. You’re redirected to the dashboard page.
              i. Sign up for an account.
iii. Click the link to register a new gateway.
 
iv. You’re taken through a wizard. Choose the gateway you have, and follow the steps.
              ii. You’re redirected to the dashboard page.
v. You’re taken to the gateway page where you’ll find the LORIOT binary for your platform and a link to set up document.
 
Tip: Use a tool like scp to copy the binary from your computer to the gateway. For example:
              iii. Click the link to register a new gateway.
scp ~/Downloads/loriot_pi_2_iC880A_USB_1.0.1.tar pi@192.168.2.7:~/
 
vi. Copy the libmpsse.so library from the installation package to the usr/lib directory.
              iv. You’re taken through a wizard. Choose the gateway you have, and follow the steps.
vii. Run the loriot_pi_[B/2]_[CONCENTRATOR_TYPE]_[VERSION] binary
 
viii. Upon a successful startup, the process will daemonize to background. The last printed message should be INFO: Concentrator started, daemonizing
              v. You’re taken to the gateway page where you’ll find the LORIOT binary for your platform and a link to set up document.
ix. The gateway shows as connected on the LORIOT gateway page. You’re ready to work on the device.
 
              Tip: Use a tool like scp to copy the binary from your computer to the gateway. For example:
 
              scp ~/Downloads/loriot_pi_2_iC880A_USB_1.0.1.tar pi@192.168.2.7:~/
 
              vi. Copy the libmpsse.so library from the installation package to the usr/lib directory.
 
              vii. Run the loriot_pi_[B/2]_[CONCENTRATOR_TYPE]_[VERSION] binary
 
              viii. Upon a successful startup, the process will daemonize to background. The last printed message should be INFO: Concentrator started, daemonizing
 
              ix. The gateway shows as connected on the LORIOT gateway page. You’re ready to work on the device.


III. Working with device
III. Working with device


a. Create an application in LORIOT
        a. Create an application in LORIOT  
b. Generate a device on LORIOT
i. Go to your application page
ii. Click on Devices
iii. Click generate new device
iv. Click on newly generated device
v. Copy DevAddr, NwkSKey, AppSKey
vi. Replace dev_addr, nwk_swkey, app_swkey in below example code and run the program
vii. You should see message send from device on the device page.


c. Connect to LORIOT websocket for output data:
         b. Generate a device on LORIOT
i. In LORIOT: go to your dashboard, and click Applications > Sample App > Output.
 
ii. Change the output type to WebSocket.
              i. Go to your application page
iii. Copy the URL and the token under Current output setup, and paste them in the code sample below:
 
              ii. Click on Devices
 
              iii. Click generate new device
 
              iv. Click on newly generated device
 
              v. Copy DevAddr, NwkSKey, AppSKey
 
              vi. Replace dev_addr, nwk_swkey, app_swkey in below example code and run the program
 
              vii. You should see message send from device on the device page.
 
        c. Connect to LORIOT websocket for output data:
 
              i. In LORIOT: go to your dashboard, and click Applications > Sample App > Output.
 
              ii. Change the output type to WebSocket.
 
              iii. Copy the URL and the token under Current output setup, and paste them in the code sample below:


IV. References
IV. References
Building your own private LoRa network
 
https://docs.mbed.com/docs/lora-with-mbed/en/latest/intro-to-lora/
       Building your own private LoRa network https://docs.mbed.com/docs/lora-with-mbed/en/latest/intro-to-lora/
iC880A Quick Start Guide
 
https://wireless-solutions.de/images/stories/downloads/Radio%20Modules/iC880A/iC880A_QuickStartGuide.pdf
        iC880A Quick Start Guide https://wireless-solutions.de/images/stories/downloads/Radio%20Modules/iC880A/iC880A_QuickStartGuide.pdf
LORIOT gateway installation guide
 
https://eu1.loriot.io/home/documentation.html#docu/gwguide/pi
        LORIOT gateway installation guide https://eu1.loriot.io/home/documentation.html#docu/gwguide/pi
LoRaWAN with ABP join method (LoPy)
 
https://docs.pycom.io/pycom_esp32/pycom_esp32/tutorial/includes/lora-abp.html
        LoRaWAN with ABP join method (LoPy) https://docs.pycom.io/pycom_esp32/pycom_esp32/tutorial/includes/lora-abp.html

Revision as of 15:31, 3 March 2017

We have installed a LoraWAN using raspberry pi 2 and IMST gateway (iC880A-USB). The loriot.io network service has been used in our experimentation. LoPy micro-controllers were used as end-devices in our test. We were able publishing data to Loriot.io by using LoPy board. Below are the step-by-step LoraWAN installation procedure.

I. Setting up the gateway
      1. Make sure that the Raspberry Pi is connected to the internet and that you connected the IMST iC880A over USB.
      2. Download of the Open Source Driver
          a. Install git client:
              sudo apt-get install git
          b. Create local folder:

              mkdir -p ~/LoRa/lora_gateway

          c. Clone the repository:

              cd ~/LoRa/lora_gateway

              git clone https://github.com/Lora-net/lora_gateway.git

              Note: Use lora_gateway 2.0.0, not the latest version. (Run git checkout v2.0.0 in the lora_gateway folder).

              cd lora_gateway

              git checkout v2.0.0

      3. Downloading Additional Drivers

          a. Create a folder for the libmpsse files:

              mkdir –p ~/LoRa/libmpsse

          b. Download the newest version of the libmpsse files:

              cd ~/LoRa/libmpsse

              wget https://storage.googleapis.com/google-code-archivedownloads/v2/code.google.com/libmpsse/libmpsse-1.3.tar.gz

              tar –xzvf libmpsse-1.3.tar.gz

          c. Follow the installation instructions from the hosted website:(https://code.google.com/p/libmpsse/wiki/Installation)

              sudo apt-get install libftdi-dev

              cd ~/LoRa/libmpsse/libmpsse-1.3/src

                ./configure --disable-python && make && sudo make install

              sudo ldconfig

                Note: If the configure step fails, follow the instructions and try to install the missing dependencies.

      4. Configuration of the Driver

      The driver must be configured in order to work with the iC880A. The following chapter describes the necessary configuration options to make.

      In the folder “LoRa/github/lora_gateway/libloragw” there is a file called “libraray.cfg”. This file contains the most important options for the HAL-library and must be modified to your needs

      before compiling the software.

          a. File: lora_gateway/libloragw/library.cfg

          This file is used as general configuration file for the whole libloragw system library. In order to fit the needs of the iC880A, some parameters must be set to the following

          values prior (re-) compiling the library:

            CFG_SPI= ftdi

            CFG_CHIP= sx1301

            CFG_RADIO= sx1257

            CFG_BAND= eu868

            The parameter called “CFG_BRD” must be left empty or set to: CFG_BRD= ref_1301_868

            Additionally, there are some optional debug settings that can be turned on (1) or off (0):

              DEBUG_AUX= 0

              DEBUG_SPI= 0

              DEBUG_REG= 0

              DEBUG_HAL= 1

              DEBUG_GPS= 0

            These flags are used by the internal modules of the library to enable / disable additional output for debugging purposes.

      b. File: lora_gateway/libloragw/src/loragw_spi.ftdi.c

      As second step a small modification must be done in one of the low-level connection files. The WiMOD iC880A LoRa Concentrator board uses a FTDI USB to SPI converter chip that is not

      supported in Semtech’s reference code. The only difference is another USB PID. Therefore, the USB PID settings in the libloragw library have to be adjusted prior compiling the library.

      Open the file lora_gateway/libloragw/src/loragw_spi.ftdi.c with your favorite editor (e.g. nano)

          nano lora_gateway/libloragw/src/loragw_spi.ftdi.c

          Find the block with the “PRIVATE CONSTANTS” (around line 50 in the file) and change the line

          #define PID 0x6010

          To

          #define PID 0x6014

          Afterwards save the file and close the editor.

      5. Compilation of the Library

      In order to compile the libloragw library it is assumed that a gcc/g++ compiler and a make utility is already installed and runnable.

      Enter the lora_gateway folder and execute the make command:

      cd lora_gateway

      make

      This will compile the library and some of the basic test utilities located in the subfolders of lora_gateway.

      After a successful compilation a library file called “libloragw.a” has been created and is ready for usage now.

      6. Setting up “udev” Rules

      The FTDI USB chip needs to be run in the SPI mode. Therefore an “udev” rule must be installed on the Linux host system. This rule will configure the right mode automatically when the iC880A

      device is connected to the host system. In order to install the udev rule the following steps must be done:

          In the folder lora_gateway/libloragw there is a template file present. Open the file in

          your favorite editor (e.g. nano).

          nano lora_gateway/libloragw/99-libftdi.rules

          locate the line

          SUBSYSTEM=="usb",ENV{DEVTYPE}=="usb_device",

          ATTRS{idVendor}=="0403", ATTRS{idProduct}=="6010",

          MODE="0664", GROUP="plugdev"

          and change the entry

          ATTRS{idProduct}=="6010”

          to:

          ATTRS{idProduct}=="6014”

          Save the file and leave the editor. Next copy the file to the folder /etc/udev/rules.d/

          sudo cp 99-libftdi.rules /etc/udev/rules.d/

      7. After following these steps:

      Restart the Pi.

      Run:

      ~/LoRa/lora_gateway/lora_gateway/util_pkt_logger/util_pkt_logger

      You see ‘INFO: concentrator started, packet can now be received’, which indicates that everything is functioning.

II. Setting up LoRa network on LORIOT

      a. Installing the LORIOT software

          i. Sign up for an account.

          ii. You’re redirected to the dashboard page.

          iii. Click the link to register a new gateway.

          iv. You’re taken through a wizard. Choose the gateway you have, and follow the steps.

          v. You’re taken to the gateway page where you’ll find the LORIOT binary for your platform and a link to set up document.

          Tip: Use a tool like scp to copy the binary from your computer to the gateway. For example:

          scp ~/Downloads/loriot_pi_2_iC880A_USB_1.0.1.tar pi@192.168.2.7:~/

          vi. Copy the libmpsse.so library from the installation package to the usr/lib directory.

          vii. Run the loriot_pi_[B/2]_[CONCENTRATOR_TYPE]_[VERSION] binary

          viii. Upon a successful startup, the process will daemonize to background. The last printed message should be INFO: Concentrator started, daemonizing

          ix. The gateway shows as connected on the LORIOT gateway page. You’re ready to work on the device.

III. Working with device

      a. Create an application in LORIOT

      b. Generate a device on LORIOT

          i. Go to your application page

          ii. Click on Devices

          iii. Click generate new device

          iv. Click on newly generated device

          v. Copy DevAddr, NwkSKey, AppSKey

          vi. Replace dev_addr, nwk_swkey, app_swkey in below example code and run the program

          vii. You should see message send from device on the device page.

      c. Connect to LORIOT websocket for output data:

          i. In LORIOT: go to your dashboard, and click Applications > Sample App > Output.

          ii. Change the output type to WebSocket.

          iii. Copy the URL and the token under Current output setup, and paste them in the code sample below:

IV. References

     Building your own private LoRa network https://docs.mbed.com/docs/lora-with-mbed/en/latest/intro-to-lora/

      iC880A Quick Start Guide https://wireless-solutions.de/images/stories/downloads/Radio%20Modules/iC880A/iC880A_QuickStartGuide.pdf

      LORIOT gateway installation guide https://eu1.loriot.io/home/documentation.html#docu/gwguide/pi

      LoRaWAN with ABP join method (LoPy) https://docs.pycom.io/pycom_esp32/pycom_esp32/tutorial/includes/lora-abp.html