2017-10-08 12:48:11 +02:00
|
|
|
## 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](https://www.lora-alliance.org/) for more information on LoRa.
|
|
|
|
See [Semtech LoRamac-node repository](https://github.com/Lora-net/LoRaMac-node)
|
|
|
|
to have a look at the original package code.
|
|
|
|
|
|
|
|
This application can only be used with Semtech
|
|
|
|
[SX1272](http://www.semtech.com/images/datasheet/sx1272.pdf) or
|
|
|
|
[SX1276](http://www.semtech.com/images/datasheet/sx1276.pdf) 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](https://www.thethingsnetwork.org/) (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
|
2018-01-25 19:27:08 +01:00
|
|
|
STM32 Nucleo-64 boards and MBED LoRa shields
|
2017-10-08 12:48:11 +02:00
|
|
|
([SX1276](https://os.mbed.com/components/SX1276MB1xAS/) or
|
|
|
|
[SX1272](https://os.mbed.com/components/SX1272MB2xAS/)). You can also use the
|
|
|
|
ST [b-l072z-lrwan1](http://www.st.com/en/evaluation-tools/b-l072z-lrwan1.html)
|
|
|
|
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](https://www.thethingsnetwork.org/docs/applications/mqtt/api.html)
|
|
|
|
for more information.
|
|
|
|
|
|
|
|
* Let's use [mosquitto](https://mosquitto.org/) 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!
|
|
|
|
```
|