Firmware update over the Air library for LoRaWAN devices running Mbed OS 5. It implements the LoRa Alliance Fragmented Data Block, Remote Multicast Setup, and Application Layer Clock Sync specifications. In addition it adds cryptographic verification of firmware, and supports delta updates. See mbed-os-example-lorawan-fuota for an example application and more documentation.
Unit tests are in the TESTS
folder and are ran with Mbed CLI. Note that you need to specify a storage layer (could be HeapBlockDevice or FlashIAPBlockDevice) in TESTS/COMMON/test_setup.h
, and your storage configuration in TESTS/tests/mbed_app.json
. Then run:
$ mbed test --app-config TESTS/tests/mbed_app.json -n mbed-lorawan-update-client-tests-tests-* -v
Omit -v
for less verbose output.
Most buffers are dynamically allocated when needed to save memory.
Memory usage is dependent on:
- The page size of the block device (one page needs to be allocated).
And during fragmentation on:
- Number of fragments required for a full file (without the redundancy packets) (
nbFrag
). - The size of a data fragment (
fragSize
). - The maximum number of redundancy frames that are expected (
nbRedundancy
).
Calculated via: ((nbRedundancy / 8) * nbRedundancy) + (nbFrag * 2) + (nbFrag) + (fragSize * 2) + (nbRedundancy * 3)
.
Use printHeapStats()
to get an idea of the memory load.
For the L-TEK FF1705, with 528 bytes page size, a 7.844 byte image, 204 byte packets, and max. 40 redundancy packets:
- After calling the constructor: 432 bytes.
- During multicast setup: 432 bytes.
- During fragmentation: 1837 bytes (528 bytes page size, and 877 bytes for fragmentation buffers).
- After fragmentation: 960 bytes (only page size buffer active).
- During ECDSA-SHA256 verification: 5420 bytes.
- After ECDSA-SHA256 verification: 960 bytes.
- After calling the destructor: 0 bytes.
Note that these numbers do not include Mbed OS or the LoRaWAN stack. See mbed-os-example-lorawan-fuota for more information on total memory usage, and ways to optimize memory.
Highest memory usage is seen when ECDSA-SHA256 verification is happening. To get the update client running on smaller boards you might want to clear out buffers in your application when this happens. There are two callbacks that fire when the verification starts and stops:
verificationStarting
.verificationFinished
.
Under the directory patch/
new patching methode have been added.
The new algorithms can be used to patch the old version using a more optimized DDELTA patch (patching methode bsdiff-like).
This new patching method requires an on device decompresssion. This is done using the LZCL algorithms.
The DDELTA patch is usually compressed using the Arithmetic algo: A new Z_ARI_FILE have been created on the BDFILE template,
in order to allow decompressing the patch on the fly.
The Memory allocation for the patching can be ajusted depending on the platform used finally.
In the main LoRaWANUpdateClient
file, new functions and definitions have been added to support the requests reguarding the new specification.
This allows to return statistics about the current status of the device, and the current version so that the device can be sent the correct FUOTA patch.
The actual specification in version 0.2 can be found at : LoRaWAN Version and Status Specification_v0_2.pdf