In this guide we will explain how you can trigger a download and software upgrade of a Matter node in the Matter network. The Matter OTA protocol will be used for this.
Prerequisites:
- Qorvo's QPG7015M Gateway development kit is used as OpenThread Border Router. See How to setup the OpenThread Border Router.
- Host for the chip-tool such as Linux 64-bit PC running Ubuntu 20.04+ or RPi4 running Ubuntu 20.04+.
- Host for the ota-provider-app such as Linux 64-bit PC running Ubuntu 20.04+ or RPi4 running Ubuntu 20.04+.
In the example below a RaspberryPi4 will be used as host device for these tools and refered to as RPi. If an other platform is selected for one or all of the tools/apps please use the respective folder versions of the tools.
To do a device upgrade over the Matter protocol, two nodes are needed in the Matter network : Matter OTA provider and Matter OTA requestor node. An OTA provider node is the node that can supply the available software update to the OTA requestor node. In this example the QPG6105 Matter light device will be the Matter OTA requestor. This node will query the Matter OTA provider node for a software update. The Matter OTA provider for this test is your Linux 64-bit PC that runs the Matter OTA provider tool from the Matter repository.
See the guide How to setup the OpenThread Border Router.
A prerequisite for starting the Matter OTA protocol download process is that the version of the application firmware needs to be updated. If the software version matches the one that is running, the update image will be ignored.. To change the version of the software, and as a consequence also the version of the ota image, the following actions need to be taken:
- Update the application's software version in the CHIPProjectConfig.h of your application as shown below (for the
light
application this is light/linclude/CHIPProjectConfig.h):
#ifndef CHIP_DEVICE_CONFIG_DEVICE_SOFTWARE_VERSION
-#define CHIP_DEVICE_CONFIG_DEVICE_SOFTWARE_VERSION 0x0002
+#define CHIP_DEVICE_CONFIG_DEVICE_SOFTWARE_VERSION 0x0003
...
#ifndef CHIP_DEVICE_CONFIG_DEVICE_SOFTWARE_VERSION_STRING
-#define CHIP_DEVICE_CONFIG_DEVICE_SOFTWARE_VERSION_STRING "1.0"
+#define CHIP_DEVICE_CONFIG_DEVICE_SOFTWARE_VERSION_STRING "1.0upg"
#endif
The version is also part of the OTA header when the .ota file gets generated. The generate_ota_img.py script that generates this file will parse this C header and consider this a new version.
Once these lines are modified restart the application build to get the updated ota file.
cd QMatter/
source Scripts/activate.sh
cd Applications/Matter/light
make -f Makefile.light_qpg6105_development
After successful compilation you can tell the OTA provider tool where it can find the .ota file.
cd QMatter/Tools/MatterOtaProviders/RPi/
sudo ./chip-ota-provider-app.elf -f <path to QMatter>/Work/light_qpg6105_development/light_qpg6105_development.ota
Now make sure to keep this application keeps running. Open a new terminal window to complete the next steps.
For this the Matter controller tool is needed. It can run on the same machine as the chip-ota-provider-app. The OTA provider will be commissioned as node id 1 in the network:
cd QMatter/Tools/MatterControllers/RPi/
sudo ./chip-tool.elf pairing onnetwork 1 20202021
We will also use the matter controller tool to commission thi device. First, get the active dataset from the running OpenThread border router. Details how to retrieve this can be found in the guide How to setup the OpenThread Border Router. With this information we can commission the Matter light node with node identifier 2 in the network:
sudo ./chip-tool.elf pairing ble-thread 2 hex:<otbr active dataset> 20202021 3840
We will instruct the Matter controller to write configuration to the default OTA provider in the Matter light. We need to provide it the fabricIndex on which the OTA provider lives, the node identifier we assigned to it and the endpoint of the OTA software update provider cluster. The last arguments in the command contain the node identifier of the OTA requestor (e.g. the light) and the endpoint where the OTA software update requestor cluster lives.
sudo ./chip-tool.elf otasoftwareupdaterequestor write default-otaproviders '[{"fabricIndex": 1, "providerNodeID": 1, "endpoint": 0}]' 2 0
We need to add access control configuration to the OTA provider node so it accepts commands from nodes that are part of the fabric. This command will grant Operation privileges to all the nodes that are part of the fabric:
sudo ./chip-tool.elf accesscontrol write acl '[{"fabricIndex": 1, "privilege": 5, "authMode": 2, "subjects": [112233], "targets": null}, {"fabricIndex": 1, "privilege": 3, "authMode": 2, "subjects": null, "targets": null}]' 1 0
The final step in the flow is to announce that a software update is available for the Matter node. This will trigger the download of the full .ota image and once the image is taken in, a reboot of the device will take place to allow the bootloader to upgrade to the new firmware.
sudo ./chip-tool.elf otasoftwareupdaterequestor announce-otaprovider 1 0 0 0 2 0
Arguments in this command are:
- OTA Provider node identifier [1]
- OTA Provider vendor identifier [0]
- Announcement Reason [0 - SimpleAnnouncement]
- OTA Requestor node endpoint [0]
- OTA Requestor node identifier [2]
- Endpoint to be ignored for group commands [0]
If all goes well, you should now have your application rebooted with the updated version 1.0upg
on the ota requestor node:
[P][DL] _OnPlatformEvent default: event->Type = 32780
[P][-] Current Software Version: 1.0upg