This is an example application based on Mbed-OS LoRaWAN protocol APIs. The Mbed-OS LoRaWAN stack implementation is compliant with LoRaWAN v1.0.2 specification.

Dependents:   Projet_de_bachelor_code Projet_de_bachelor_code

Example LoRaWAN application for Mbed-OS

This is an example application based on Mbed-OS LoRaWAN protocol APIs. The Mbed-OS LoRaWAN stack implementation is compliant with LoRaWAN v1.0.2 specification. See this link for information on support for other LoRaWAN spec versions. This application can work with any Network Server if you have correct credentials for the said Network Server.

Getting Started

Supported Hardware

Mbed Enabled board with an Arduino form factor and one of the following:

OR

Mbed Enabled LoRa Module

Import the example application

For Mbed Online Compiler users:

  • Select "Import", then search for "mbed-os-example-lorawan" from "Team mbed-os-examples". Or simply, import this repo by URL.
  • NOTE: Do NOT select "Update all libraries to latest revision" as this may cause breakage with a new lib version we have not tested.

For mbed-cli users:

$ mbed import mbed-os-example-lorawan
$ cd mbed-os-example-lorawan

#OR

$ git clone git@github.com:ARMmbed/mbed-os-example-lorawan.git
$ cd mbed-os-example-lorawan
$ mbed deploy

Example configuration and radio selection

Because of the pin differences between the SX126x and SX127x radios, example application configuration files are provided with the correct pin sets in the config/ dir of this project.

Please start by selecting the correct example configuration for your radio:

  • For Mbed Online Compiler users, this can be done by simply replacing the contents of the mbed_app.json at the root of the project with the content of the correct example configuration in config/ dir.
  • For mbed-cli users, the config file can be specifed on the command line with the --app-config option (ie --app-config config/SX12xx_example_config.json)

With the correct config file selected, the user can then provide a pin set for their target board in the NC fields at the top if it is different from the default targets listed. If your device is one of the LoRa modules supported by Mbed-OS, the pin set is already provided for the modules in the target-overrides field of the config file. For more information on supported modules, please refer to the module support section

Add network credentials

Open the file mbed_app.json in the root directory of your application. This file contains all the user specific configurations your application and the Mbed OS LoRaWAN stack need. Network credentials are typically provided by LoRa network provider.

For OTAA

Please add Device EUI, Application EUI and Application Key needed for Over-the-air-activation(OTAA). For example:

"lora.device-eui": "{ YOUR_DEVICE_EUI }",
"lora.application-eui": "{ YOUR_APPLICATION_EUI }",
"lora.application-key": "{ YOUR_APPLICATION_KEY }"

For ABP

For Activation-By-Personalization (ABP) connection method, modify the mbed_app.json to enable ABP. You can do it by simply turning off OTAA. For example:

"lora.over-the-air-activation": false,

In addition to that, you need to provide Application Session Key, Network Session Key and Device Address. For example:

"lora.appskey": "{ YOUR_APPLICATION_SESSION_KEY }",
"lora.nwkskey": "{ YOUR_NETWORK_SESSION_KEY }",
"lora.device-address": " YOUR_DEVICE_ADDRESS_IN_HEX  " 

Configuring the application

The Mbed OS LoRaWAN stack provides a lot of configuration controls to the application through the Mbed OS configuration system. The previous section discusses some of these controls. This section highlights some useful features that you can configure.

Selecting a PHY

The LoRaWAN protocol is subject to various country specific regulations concerning radio emissions. That's why the Mbed OS LoRaWAN stack provides a LoRaPHY class that you can use to implement any region specific PHY layer. Currently, the Mbed OS LoRaWAN stack provides 10 different country specific implementations of LoRaPHY class. Selection of a specific PHY layer happens at compile time. By default, the Mbed OS LoRaWAN stack uses EU 868 MHz PHY. An example of selecting a PHY can be:

        "phy": {
            "help": "LoRa PHY region. 0 = EU868 (default), 1 = AS923, 2 = AU915, 3 = CN470, 4 = CN779, 5 = EU433, 6 = IN865, 7 = KR920, 8 = US915, 9 = US915_HYBRID",
            "value": "0"
        },

Duty cycling

LoRaWAN v1.0.2 specifcation is exclusively duty cycle based. This application comes with duty cycle enabled by default. In other words, the Mbed OS LoRaWAN stack enforces duty cycle. The stack keeps track of transmissions on the channels in use and schedules transmissions on channels that become available in the shortest time possible. We recommend you keep duty cycle on for compliance with your country specific regulations.

However, you can define a timer value in the application, which you can use to perform a periodic uplink when the duty cycle is turned off. Such a setup should be used only for testing or with a large enough timer value. For example:

"target_overrides": {
	"*": {
		"lora.duty-cycle-on": false
		},
	}
}

Module support

Here is a nonexhaustive list of boards and modules that we have tested with the Mbed OS LoRaWAN stack:

  • MultiTech mDot (SX1272)
  • MultiTech xDot (SX1272)
  • LTEK_FF1705 (SX1272)
  • Advantech Wise 1510 (SX1276)
  • ST B-L072Z-LRWAN1 LoRa®Discovery kit with Murata CMWX1ZZABZ-091 module (SX1276)

Here is a list of boards and modules that have been tested by the community:

  • IMST iM880B (SX1272)
  • Embedded Planet Agora (SX1276)

Compiling the application

Use Mbed CLI commands to generate a binary for the application. For example:

$ mbed compile -m YOUR_TARGET -t ARM

Running the application

Drag and drop the application binary from BUILD/YOUR_TARGET/ARM/mbed-os-example-lora.bin to your Mbed enabled target hardware, which appears as a USB device on your host machine.

Attach a serial console emulator of your choice (for example, PuTTY, Minicom or screen) to your USB device. Set the baudrate to 115200 bit/s, and reset your board by pressing the reset button.

You should see an output similar to this:

Mbed LoRaWANStack initialized 

 CONFIRMED message retries : 3 

 Adaptive data  rate (ADR) - Enabled 

 Connection - In Progress ...

 Connection - Successful 

 Dummy Sensor Value = 2.1 

 25 bytes scheduled for transmission 
 
 Message Sent to Network Server

Adding trace library

To enable Mbed trace, add to your mbed_app.json the following fields:

    "target_overrides": {
        "*": {
            "mbed-trace.enable": true
            }
     }

The trace is disabled by default to save RAM and reduce main stack usage (see chapter Memory optimization).

Please note that some targets with small RAM size (e.g. DISCO_L072CZ_LRWAN1 and MTB_MURATA_ABZ) mbed traces cannot be enabled without increasing the default "main_stack_size": 1024.

Memory optimization

Using Arm CC compiler instead of GCC reduces 3K of RAM. Currently the application takes about 15K of static RAM with Arm CC, which spills over for the platforms with 20K of RAM because you need to leave space, about 5K, for dynamic allocation. So if you reduce the application stack size, you can barely fit into the 20K platforms.

For example, add the following into config section in your mbed_app.json:

"main_stack_size": {
    "value": 2048
}

Essentially you can make the whole application with Mbed LoRaWAN stack in 6K if you drop the RTOS from Mbed OS and use a smaller standard C/C++ library like new-lib-nano. Please find instructions here.

For more information, please follow this blog post.

License and contributions

The software is provided under Apache-2.0 license. Contributions to this project are accepted under the same license. Please see contributing.md for more info.

This project contains code from other projects. The original license text is included in those source files. They must comply with our license guide.

Committer:
mbed_official
Date:
Thu Mar 08 17:46:15 2018 +0000
Revision:
0:7037ed05f54f
Fix construction of LoRaWANInterface object

Since radio object is constructed by another source file, we have a
race condition. In order to prevent this race condition, LoRaWANInterface
object is now created in main().

.
Commit copied from https://github.com/ARMmbed/mbed-os-example-lorawan

Who changed what in which revision?

UserRevisionLine numberNew contents of line
mbed_official 0:7037ed05f54f 1 Apache License
mbed_official 0:7037ed05f54f 2 Version 2.0, January 2004
mbed_official 0:7037ed05f54f 3 http://www.apache.org/licenses/
mbed_official 0:7037ed05f54f 4
mbed_official 0:7037ed05f54f 5 TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION
mbed_official 0:7037ed05f54f 6
mbed_official 0:7037ed05f54f 7 1. Definitions.
mbed_official 0:7037ed05f54f 8
mbed_official 0:7037ed05f54f 9 "License" shall mean the terms and conditions for use, reproduction, and
mbed_official 0:7037ed05f54f 10 distribution as defined by Sections 1 through 9 of this document.
mbed_official 0:7037ed05f54f 11
mbed_official 0:7037ed05f54f 12 "Licensor" shall mean the copyright owner or entity authorized by the copyright
mbed_official 0:7037ed05f54f 13 owner that is granting the License.
mbed_official 0:7037ed05f54f 14
mbed_official 0:7037ed05f54f 15 "Legal Entity" shall mean the union of the acting entity and all other entities
mbed_official 0:7037ed05f54f 16 that control, are controlled by, or are under common control with that entity.
mbed_official 0:7037ed05f54f 17 For the purposes of this definition, "control" means (i) the power, direct or
mbed_official 0:7037ed05f54f 18 indirect, to cause the direction or management of such entity, whether by
mbed_official 0:7037ed05f54f 19 contract or otherwise, or (ii) ownership of fifty percent (50%) or more of the
mbed_official 0:7037ed05f54f 20 outstanding shares, or (iii) beneficial ownership of such entity.
mbed_official 0:7037ed05f54f 21
mbed_official 0:7037ed05f54f 22 "You" (or "Your") shall mean an individual or Legal Entity exercising
mbed_official 0:7037ed05f54f 23 permissions granted by this License.
mbed_official 0:7037ed05f54f 24
mbed_official 0:7037ed05f54f 25 "Source" form shall mean the preferred form for making modifications, including
mbed_official 0:7037ed05f54f 26 but not limited to software source code, documentation source, and configuration
mbed_official 0:7037ed05f54f 27 files.
mbed_official 0:7037ed05f54f 28
mbed_official 0:7037ed05f54f 29 "Object" form shall mean any form resulting from mechanical transformation or
mbed_official 0:7037ed05f54f 30 translation of a Source form, including but not limited to compiled object code,
mbed_official 0:7037ed05f54f 31 generated documentation, and conversions to other media types.
mbed_official 0:7037ed05f54f 32
mbed_official 0:7037ed05f54f 33 "Work" shall mean the work of authorship, whether in Source or Object form, made
mbed_official 0:7037ed05f54f 34 available under the License, as indicated by a copyright notice that is included
mbed_official 0:7037ed05f54f 35 in or attached to the work (an example is provided in the Appendix below).
mbed_official 0:7037ed05f54f 36
mbed_official 0:7037ed05f54f 37 "Derivative Works" shall mean any work, whether in Source or Object form, that
mbed_official 0:7037ed05f54f 38 is based on (or derived from) the Work and for which the editorial revisions,
mbed_official 0:7037ed05f54f 39 annotations, elaborations, or other modifications represent, as a whole, an
mbed_official 0:7037ed05f54f 40 original work of authorship. For the purposes of this License, Derivative Works
mbed_official 0:7037ed05f54f 41 shall not include works that remain separable from, or merely link (or bind by
mbed_official 0:7037ed05f54f 42 name) to the interfaces of, the Work and Derivative Works thereof.
mbed_official 0:7037ed05f54f 43
mbed_official 0:7037ed05f54f 44 "Contribution" shall mean any work of authorship, including the original version
mbed_official 0:7037ed05f54f 45 of the Work and any modifications or additions to that Work or Derivative Works
mbed_official 0:7037ed05f54f 46 thereof, that is intentionally submitted to Licensor for inclusion in the Work
mbed_official 0:7037ed05f54f 47 by the copyright owner or by an individual or Legal Entity authorized to submit
mbed_official 0:7037ed05f54f 48 on behalf of the copyright owner. For the purposes of this definition,
mbed_official 0:7037ed05f54f 49 "submitted" means any form of electronic, verbal, or written communication sent
mbed_official 0:7037ed05f54f 50 to the Licensor or its representatives, including but not limited to
mbed_official 0:7037ed05f54f 51 communication on electronic mailing lists, source code control systems, and
mbed_official 0:7037ed05f54f 52 issue tracking systems that are managed by, or on behalf of, the Licensor for
mbed_official 0:7037ed05f54f 53 the purpose of discussing and improving the Work, but excluding communication
mbed_official 0:7037ed05f54f 54 that is conspicuously marked or otherwise designated in writing by the copyright
mbed_official 0:7037ed05f54f 55 owner as "Not a Contribution."
mbed_official 0:7037ed05f54f 56
mbed_official 0:7037ed05f54f 57 "Contributor" shall mean Licensor and any individual or Legal Entity on behalf
mbed_official 0:7037ed05f54f 58 of whom a Contribution has been received by Licensor and subsequently
mbed_official 0:7037ed05f54f 59 incorporated within the Work.
mbed_official 0:7037ed05f54f 60
mbed_official 0:7037ed05f54f 61 2. Grant of Copyright License.
mbed_official 0:7037ed05f54f 62
mbed_official 0:7037ed05f54f 63 Subject to the terms and conditions of this License, each Contributor hereby
mbed_official 0:7037ed05f54f 64 grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free,
mbed_official 0:7037ed05f54f 65 irrevocable copyright license to reproduce, prepare Derivative Works of,
mbed_official 0:7037ed05f54f 66 publicly display, publicly perform, sublicense, and distribute the Work and such
mbed_official 0:7037ed05f54f 67 Derivative Works in Source or Object form.
mbed_official 0:7037ed05f54f 68
mbed_official 0:7037ed05f54f 69 3. Grant of Patent License.
mbed_official 0:7037ed05f54f 70
mbed_official 0:7037ed05f54f 71 Subject to the terms and conditions of this License, each Contributor hereby
mbed_official 0:7037ed05f54f 72 grants to You a perpetual, worldwide, non-exclusive, no-charge, royalty-free,
mbed_official 0:7037ed05f54f 73 irrevocable (except as stated in this section) patent license to make, have
mbed_official 0:7037ed05f54f 74 made, use, offer to sell, sell, import, and otherwise transfer the Work, where
mbed_official 0:7037ed05f54f 75 such license applies only to those patent claims licensable by such Contributor
mbed_official 0:7037ed05f54f 76 that are necessarily infringed by their Contribution(s) alone or by combination
mbed_official 0:7037ed05f54f 77 of their Contribution(s) with the Work to which such Contribution(s) was
mbed_official 0:7037ed05f54f 78 submitted. If You institute patent litigation against any entity (including a
mbed_official 0:7037ed05f54f 79 cross-claim or counterclaim in a lawsuit) alleging that the Work or a
mbed_official 0:7037ed05f54f 80 Contribution incorporated within the Work constitutes direct or contributory
mbed_official 0:7037ed05f54f 81 patent infringement, then any patent licenses granted to You under this License
mbed_official 0:7037ed05f54f 82 for that Work shall terminate as of the date such litigation is filed.
mbed_official 0:7037ed05f54f 83
mbed_official 0:7037ed05f54f 84 4. Redistribution.
mbed_official 0:7037ed05f54f 85
mbed_official 0:7037ed05f54f 86 You may reproduce and distribute copies of the Work or Derivative Works thereof
mbed_official 0:7037ed05f54f 87 in any medium, with or without modifications, and in Source or Object form,
mbed_official 0:7037ed05f54f 88 provided that You meet the following conditions:
mbed_official 0:7037ed05f54f 89
mbed_official 0:7037ed05f54f 90 You must give any other recipients of the Work or Derivative Works a copy of
mbed_official 0:7037ed05f54f 91 this License; and
mbed_official 0:7037ed05f54f 92 You must cause any modified files to carry prominent notices stating that You
mbed_official 0:7037ed05f54f 93 changed the files; and
mbed_official 0:7037ed05f54f 94 You must retain, in the Source form of any Derivative Works that You distribute,
mbed_official 0:7037ed05f54f 95 all copyright, patent, trademark, and attribution notices from the Source form
mbed_official 0:7037ed05f54f 96 of the Work, excluding those notices that do not pertain to any part of the
mbed_official 0:7037ed05f54f 97 Derivative Works; and
mbed_official 0:7037ed05f54f 98 If the Work includes a "NOTICE" text file as part of its distribution, then any
mbed_official 0:7037ed05f54f 99 Derivative Works that You distribute must include a readable copy of the
mbed_official 0:7037ed05f54f 100 attribution notices contained within such NOTICE file, excluding those notices
mbed_official 0:7037ed05f54f 101 that do not pertain to any part of the Derivative Works, in at least one of the
mbed_official 0:7037ed05f54f 102 following places: within a NOTICE text file distributed as part of the
mbed_official 0:7037ed05f54f 103 Derivative Works; within the Source form or documentation, if provided along
mbed_official 0:7037ed05f54f 104 with the Derivative Works; or, within a display generated by the Derivative
mbed_official 0:7037ed05f54f 105 Works, if and wherever such third-party notices normally appear. The contents of
mbed_official 0:7037ed05f54f 106 the NOTICE file are for informational purposes only and do not modify the
mbed_official 0:7037ed05f54f 107 License. You may add Your own attribution notices within Derivative Works that
mbed_official 0:7037ed05f54f 108 You distribute, alongside or as an addendum to the NOTICE text from the Work,
mbed_official 0:7037ed05f54f 109 provided that such additional attribution notices cannot be construed as
mbed_official 0:7037ed05f54f 110 modifying the License.
mbed_official 0:7037ed05f54f 111 You may add Your own copyright statement to Your modifications and may provide
mbed_official 0:7037ed05f54f 112 additional or different license terms and conditions for use, reproduction, or
mbed_official 0:7037ed05f54f 113 distribution of Your modifications, or for any such Derivative Works as a whole,
mbed_official 0:7037ed05f54f 114 provided Your use, reproduction, and distribution of the Work otherwise complies
mbed_official 0:7037ed05f54f 115 with the conditions stated in this License.
mbed_official 0:7037ed05f54f 116
mbed_official 0:7037ed05f54f 117 5. Submission of Contributions.
mbed_official 0:7037ed05f54f 118
mbed_official 0:7037ed05f54f 119 Unless You explicitly state otherwise, any Contribution intentionally submitted
mbed_official 0:7037ed05f54f 120 for inclusion in the Work by You to the Licensor shall be under the terms and
mbed_official 0:7037ed05f54f 121 conditions of this License, without any additional terms or conditions.
mbed_official 0:7037ed05f54f 122 Notwithstanding the above, nothing herein shall supersede or modify the terms of
mbed_official 0:7037ed05f54f 123 any separate license agreement you may have executed with Licensor regarding
mbed_official 0:7037ed05f54f 124 such Contributions.
mbed_official 0:7037ed05f54f 125
mbed_official 0:7037ed05f54f 126 6. Trademarks.
mbed_official 0:7037ed05f54f 127
mbed_official 0:7037ed05f54f 128 This License does not grant permission to use the trade names, trademarks,
mbed_official 0:7037ed05f54f 129 service marks, or product names of the Licensor, except as required for
mbed_official 0:7037ed05f54f 130 reasonable and customary use in describing the origin of the Work and
mbed_official 0:7037ed05f54f 131 reproducing the content of the NOTICE file.
mbed_official 0:7037ed05f54f 132
mbed_official 0:7037ed05f54f 133 7. Disclaimer of Warranty.
mbed_official 0:7037ed05f54f 134
mbed_official 0:7037ed05f54f 135 Unless required by applicable law or agreed to in writing, Licensor provides the
mbed_official 0:7037ed05f54f 136 Work (and each Contributor provides its Contributions) on an "AS IS" BASIS,
mbed_official 0:7037ed05f54f 137 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied,
mbed_official 0:7037ed05f54f 138 including, without limitation, any warranties or conditions of TITLE,
mbed_official 0:7037ed05f54f 139 NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A PARTICULAR PURPOSE. You are
mbed_official 0:7037ed05f54f 140 solely responsible for determining the appropriateness of using or
mbed_official 0:7037ed05f54f 141 redistributing the Work and assume any risks associated with Your exercise of
mbed_official 0:7037ed05f54f 142 permissions under this License.
mbed_official 0:7037ed05f54f 143
mbed_official 0:7037ed05f54f 144 8. Limitation of Liability.
mbed_official 0:7037ed05f54f 145
mbed_official 0:7037ed05f54f 146 In no event and under no legal theory, whether in tort (including negligence),
mbed_official 0:7037ed05f54f 147 contract, or otherwise, unless required by applicable law (such as deliberate
mbed_official 0:7037ed05f54f 148 and grossly negligent acts) or agreed to in writing, shall any Contributor be
mbed_official 0:7037ed05f54f 149 liable to You for damages, including any direct, indirect, special, incidental,
mbed_official 0:7037ed05f54f 150 or consequential damages of any character arising as a result of this License or
mbed_official 0:7037ed05f54f 151 out of the use or inability to use the Work (including but not limited to
mbed_official 0:7037ed05f54f 152 damages for loss of goodwill, work stoppage, computer failure or malfunction, or
mbed_official 0:7037ed05f54f 153 any and all other commercial damages or losses), even if such Contributor has
mbed_official 0:7037ed05f54f 154 been advised of the possibility of such damages.
mbed_official 0:7037ed05f54f 155
mbed_official 0:7037ed05f54f 156 9. Accepting Warranty or Additional Liability.
mbed_official 0:7037ed05f54f 157
mbed_official 0:7037ed05f54f 158 While redistributing the Work or Derivative Works thereof, You may choose to
mbed_official 0:7037ed05f54f 159 offer, and charge a fee for, acceptance of support, warranty, indemnity, or
mbed_official 0:7037ed05f54f 160 other liability obligations and/or rights consistent with this License. However,
mbed_official 0:7037ed05f54f 161 in accepting such obligations, You may act only on Your own behalf and on Your
mbed_official 0:7037ed05f54f 162 sole responsibility, not on behalf of any other Contributor, and only if You
mbed_official 0:7037ed05f54f 163 agree to indemnify, defend, and hold each Contributor harmless for any liability
mbed_official 0:7037ed05f54f 164 incurred by, or claims asserted against, such Contributor by reason of your
mbed_official 0:7037ed05f54f 165 accepting any such warranty or additional liability.