1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/tests/pkg_semtech-loramac
jia200x 605d4e3dfb
Merge pull request #8633 from aabadie/pr/tests/pkg_loramac_get
tests/pkg_semtech_loramac: fix get command with EUI values
2018-02-27 10:46:48 +01:00
..
main.c Merge pull request #8633 from aabadie/pr/tests/pkg_loramac_get 2018-02-27 10:46:48 +01:00
Makefile
README.md

Semtech LoRaMAC package test application

About

This is a test application for the Semtech LoRaMAC package. This package provides the MAC primitives for sending and receiving data to/from a LoRaWAN network.

See LoRa Alliance for more information on LoRa. See Semtech LoRamac-node repository to have a look at the original package code.

This application can only be used with Semtech SX1272 or SX1276 radio devices.

Application configuration

Before building the application and joining a LoRaWAN network, you need an account on a LoRaWAN backend provider. Then create a LoRaWAN application and register your device. Since this application has been heavily tested with the backend provided by TheThingsNetwork (TTN), we recommend that you use this one.

Once your application and device are created and registered, you'll have several information (provided by the LoRaWAN provider):

  • The type of join procedure: ABP (Activation by personnalization) or OTAA (Over The Air Activation)
  • The device EUI: an 8 bytes array
  • The application EUI: an 8 bytes array
  • The application key: a 16 bytes array
  • The device address: a 4 bytes array, only required with ABP join procedure
  • The application session key: a 16 bytes array, only required with ABP join procedure
  • The network session key: a 16 bytes array, only required with ABP join procedure

Once you have this information, either edit the Makefile accordingly or use the set/get commands in test application shell.

Building the application

The default parameters for the Semtech SX1272/SX1276 radios works as-is with STM32 Nucleo-64 boards and MBED LoRa shields (SX1276 or SX1272). You can also use the ST b-l072z-lrwan1 board.

Depending on the type of radio device, set the LORA_DRIVER variable accordingly: For example:

    LORA_DRIVER=sx1272 make BOARD=nucleo-f411 -C pkg/semtech-loramac flash term

will build the application for a nucleo-f411 with an SX1272 based mbed LoRa shield.

The SX1276 is the default value.

The other parameter that has to be set at build time is the geographic region: EU868, US915, etc. See LoRaWAN regional parameters for more information.

    LORA_REGION=US915 LORA_DRIVER=sx1272 make BOARD=nucleo-f411 -C pkg/semtech-loramac flash term

will build the application for a nucleo-f411 with an SX1272 based mbed LoRa shield for US915 region.

The default region is EU868.

Using the shell

This application provides the loramac command for configuring the MAC, joining a network and sending/receiving data to/from a LoRaWAN network. join and tx subcommands are blocking until the MAC is done.

  • Set your device EUI, application EUI, application key. Example for OTAA activation:
    > loramac set deveui AAAAAAAAAAAAAAAA
    > loramac set appeui BBBBBBBBBBBBBBBB
    > loramac set appkey CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC
  • Join a network using the OTAA procedure:
    > loramac join otaa
    Join procedure succeeded!
  • Send confirmable data on port 2 (cnf and port are optional):
    > loramac tx This\ is\ RIOT! cnf 2
  • Send unconfirmable data on port 10:
    > loramac tx This\ is\ RIOT! uncnf 10
  • Switch the default datarate index (from 0 to 16). 5 is for SF7, BW125:
    > loramac set dr 5
  • Switch to adaptive data rate:
    > loramac set adr on

The list of available commands:

    > help
    help
    Command              Description
    ---------------------------------------
    loramac              control the loramac stack
    reboot               Reboot the node

On the TTN web console, you can follow the activation and the data sent/received to/from a node.

Playing with MQTT to send/receive data to/from a LoRa node

TheThingsNetwork API also provide a MQTT broker to send/receive data. See the online documentation for more information.

  • Let's use mosquitto clients. They can be installed on Ubuntu using:
    sudo apt install mosquitto-clients
  • Subscribe to data raised by any node from any application:
    mosquitto_sub -h eu.thethings.network -p 1883 -u <your username> -P <your password> -t '+/devices/+/up'
  • Publish some data to one of the node:
    mosquitto_pub -h eu.thethings.network -p 1883 -u <your username> -P <your password> -t '<application name>/devices/<device name>/down' -m '{"port":2, "payload_raw":"VGhpcyBpcyBSSU9UIQ=="}'

After sending some data from the node, the subscribed MQTT client will display:

{"app_id":"<your application>","dev_id":"<your node>","hardware_serial":"XXXXXXXXXXXX","port":2,"counter":7,"confirmed":true,"payload_raw":"dGVzdA==","metadata":{"time":"2017-12-14T09:47:24.84548586Z","frequency":868.1,"modulation":"LORA","data_rate":"SF12BW125","coding_rate":"4/5","gateways":[{"gtw_id":"eui-xxxxxxxx","timestamp":3910359076,"time":"2017-12-14T09:47:24.85112Z","channel":0,"rssi":-10,"snr":12.2,"rf_chain":1,"latitude":48.715027,"longitude":2.2059395,"altitude":157,"location_source":"registry"}]}}

The payload sent is in the payload_raw json field and is formated in base64 (dGVzdA== in this example).

The node will also print the data received:

    > loramac tx test
    Data received: This is RIOT!