diff --git a/docs/guides/nxp/nxp_rw61x_ota_software_update.md b/docs/guides/nxp/nxp_RTs_ota_software_update.md similarity index 70% rename from docs/guides/nxp/nxp_rw61x_ota_software_update.md rename to docs/guides/nxp/nxp_RTs_ota_software_update.md index af67b1419d0526..a841a2cce166e1 100644 --- a/docs/guides/nxp/nxp_rw61x_ota_software_update.md +++ b/docs/guides/nxp/nxp_RTs_ota_software_update.md @@ -1,11 +1,16 @@ -# Matter Over-The-Air Software Update with NXP RW61x example applications +# Matter Over-The-Air Software Update with NXP RTs example applications ## Overview +This document describes OTA feature on NXP devices: +- RW61x +- RT1060_EVKC +- RT1170_EVKB + The OTA Requestor feature enables the device to be informed of, download and apply a software update from an OTA Provider. -This section explains how to perform an OTA Software Update with NXP RW61x +This section explains how to perform an OTA Software Update with NXP RTs example applications. Throughout this guide, the all-clusters application is used as an example. @@ -24,10 +29,9 @@ steps : ### Flash Memory Layout -The RW61x Flash is divided into different regions as follow : +The RTs Flash is divided into different regions as follow : -- Bootloader : MCUBoot resides at the base of the flash and occupies 0x20000 - (128 kB). +- Bootloader : MCUBoot resides at the base of the flash. - Primary application partition : The example application which would be run by the bootloader (active application). The size reserved for this partition is 4.4 MB. @@ -36,11 +40,11 @@ The RW61x Flash is divided into different regions as follow : Notes : -- The CPU1/CPU2 firmware are embedded in the CPU3 example application. +- For RW61x: The CPU1/CPU2 firmware are embedded in the CPU3 example application. - The sizes of the primary and secondary applications are provided as an example (currently 4.4 MB is reserved for each partition). The size can be changed by modifying the `m_app_max_sectors` value in the linker script of - the application (`RW610_flash.ld`). + the application . ### MCUBoot Bootloader @@ -48,11 +52,11 @@ MCUBoot is an open-source secure bootloader used by RW61x to apply the self-upgrade. For more details, please refer to the [MCUBoot documentation](https://github.com/mcu-tools/mcuboot/blob/main/docs/design.md). -For RW61x platform, the bootloader is configured to use the flash remapping +For RTs platform, the bootloader is configured to use the flash remapping mechanism by default, in order to perform the image upgrade. This is achieved by using the `MCUBoot DIRECT-XIP` upgrade mode. -## OTA Software Update process for RW61x example application +## OTA Software Update process for RTs example application ### Flashing the bootloader @@ -71,9 +75,10 @@ $ JLink Run the following commands : -``` +Connect J-Link debugger to device: +```sh J-Link > connect -Device> ? # you will be presented with a dialog -> select `RW612` +Device> ? # you will be presented with a dialog -> select `RW612` for RW61x, `MIMXRT1062XXX6B` for RT1060, `MIMXRT1176xxxA_M7` for RT1170 Please specify target interface: J) JTAG (Default) S) SWD @@ -81,34 +86,48 @@ T) cJTAG TIF> S Specify target interface speed [kHz]. : 4000 kHz Speed> # +``` + +Erase flash: +``` J-Link > exec EnableEraseAllFlashBanks +``` +For RW61x +``` J-Link > erase 0x8000000, 0x88a0000 ``` +For RT1060-EVKC +``` +J-Link > erase 0x60000000, 0x61000000 +``` +For RT1170-EVKB +``` +J-Link > erase 0x30000000, 0x34000000 +``` -- MCUBoot application can be built with SDK installed, using instructions - +- MCUBoot application can be built with SDK installed, using intructions below. +- Retrieve the mcuboot directory located at +>*/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples/<`RT_board`>[1](#RT_board)/ota_examples/mcuboot_opensource/armgcc* -- Retrieve the mcuboot directory with : - +*1 : `rdrw612bga` or `frdmrw612` for RW61x, `evkcmimxrt1060` for RT1060-EVKC, `evkbmimxrt1170` for RT1170-EVKB* ``` -user@ubuntu: cd ~/Desktop/connectedhomeip/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples//ota_examples/mcuboot_opensource/armgcc +user@ubuntu: cd ~/Desktop/connectedhomeip/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples//ota_examples/mcuboot_opensource/armgcc ``` - -``: Supported rw612 boards are: `rdrw612bga` or `frdmrw612` - -- Build the mcuboot application : - +- Build the mcuboot application with running <`build_script`>[2](#mcuboot_build_script) + ``` -user@ubuntu: chmod +x build_flash_release.sh +user@ubuntu: chmod +x user@ubuntu: export ARMGCC_DIR=/opt/gcc-arm-none-eabi-10.3-2021.10 # with ARMGCC_DIR referencing the compiler path -user@ubuntu: ./build_flash_release.sh +user@ubuntu: ./ ``` +*2 : `build_flash_release.sh` for RW61x, `build_flexspi_nor_release.sh` for RT1060 and RT1170* + - Program the generated binary to the target board. ``` -J-Link > loadbin ~/Desktop/connectedhomeip/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples//ota_examples/mcuboot_opensource/armgcc/flash_release/mcuboot_opensource.elf +J-Link > loadbin /mcuboot_opensource.elf ``` - If it runs successfully, the following logs will be displayed on the @@ -128,8 +147,8 @@ Note : By default, mcuboot application considers the primary and secondary partitions to be the size of 4.4 MB. If the size is to be changed, the partition addresses should be modified in the flash_partitioning.h accordingly. For more information about the flash partitioning with mcuboot, please refer to the -dedicated readme.txt located in -"`/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples//ota_examples/mcuboot_opensource/`". +dedicated *readme.txt* located in +>*/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples/<`RT_board`>[1](#RT_board)/ota_examples/mcuboot_opensource/.* ### Generating and flashing the signed application image @@ -143,15 +162,21 @@ The image must have the following format : signature, the upgrade type, the swap status... The all-clusters application can be generated using the instructions from the -[README.md 'Building'](../../../examples/all-clusters-app/nxp/rt/rw61x/README.md#building) + +README.md[3](#board) 'Building' section. The application is automatically linked to be executed from the primary image partition, taking into consideration the offset imposed by mcuboot. -The resulting executable file found in out/debug/chip-rw61x-all-cluster-example +3 : [RW61x README.md 'Building'](../../../examples/all-clusters-app/nxp/rt/rw61x/README.md#building), [RT1060 README.md 'Building'](../../../examples/all-clusters-app/nxp/rt/rt1060/README.md#building), [RT1170 README.md 'Building'](../../../examples/all-clusters-app/nxp/rt/rt1170/README.md#building) + +The resulting executable file found in out/release/chip-<`rt_board`>[4](#rt_board)-all-cluster-example needs to be converted into raw binary format as shown below. -``` -arm-none-eabi-objcopy -R .flash_config -R .NVM -O binary chip-rw61x-all-cluster-example chip-rw61x-all-cluster-example.bin +*4 : `rw61x` for RW61x, `rt1060` for RT1060-EVKC, `rt1170` for RT1170-EVKB* + + +```sh +arm-none-eabi-objcopy -R .flash_config -R .NVM -O binary chip-<"rt_board">-all-cluster-example chip-<"rt_board">-all-cluster-example.bin ``` To sign the image and wrap the raw binary of the application with the header and @@ -161,10 +186,10 @@ trailer, "`imgtool`" is provided in the SDK and can be found in The following commands can be run (make sure to replace the /path/to/file/binary with the adequate files): -``` +```sh user@ubuntu: cd ~/Desktop//third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/middleware/mcuboot_opensource/scripts/ -user@ubuntu: python3 imgtool.py sign --key ~/Desktop//third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples//ota_examples/mcuboot_opensource/keys/sign-rsa2048-priv.pem --align 4 --header-size 0x1000 --pad-header --pad --confirm --slot-size 0x440000 --max-sectors 1088 --version "1.0" ~/Desktop/connectedhomeip/examples/all-clusters-app/nxp/rt/rw61x/out/debug/chip-rw61x-all-cluster-example.bin ~/Desktop/connectedhomeip/examples/all-clusters-app/nxp/rt/rw61x/out/debug/chip-rw61x-all-cluster-example_SIGNED.bin +user@ubuntu: python3 imgtool.py sign --key ~/Desktop//third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples//ota_examples/mcuboot_opensource/keys/sign-rsa2048-priv.pem --align 4 --header-size 0x1000 --pad-header --pad --confirm --slot-size 0x440000 --max-sectors 1088 --version "1.0" ~/Desktop/connectedhomeip/examples/all-clusters-app/nxp/rt/<"rt_board">/out/debug/chip-<"rt_board">-all-cluster-example.bin ~/Desktop/connectedhomeip/examples/all-clusters-app/nxp/rt/<"rt_board">/out/debug/chip-<"rt_board">-all-cluster-example_SIGNED.bin ``` Notes : @@ -176,7 +201,7 @@ Notes : adjusted accordingly. - In this example, the image is signed with the private key provided by the SDK as an example - (`/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples//ota_examples/mcuboot_opensource/keys/sign-rsa2048-priv.pem`), + (`/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples//ota_examples/mcuboot_opensource/keys/sign-rsa2048-priv.pem`), MCUBoot is built with its corresponding public key which would be used to verify the integrity of the image. It is possible to generate a new pair of keys using the following commands. This procedure should be done prior to @@ -195,17 +220,25 @@ user@ubuntu: python3 imgtool.py getpub -k priv_key.pem ``` - The extracted public key can then be copied to the - `/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples//ota_examples/mcuboot_opensource/keys/sign-rsa2048-pub.c`, + `/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples//ota_examples/mcuboot_opensource/keys/sign-rsa2048-pub.c`, given as a value to the rsa_pub_key[] array. The resulting output is the signed binary of the application version "1.0". -JLink can be used to flash the application at the address 0x8020000, using the -command : +JLink can be used to flash the application using the command : +For RW61x ``` J-Link > loadbin chip-rw61x-all-cluster-example_SIGNED.bin 0x8020000 ``` +For RT1060-EVKC +``` +J-Link > loadbin chip-rt1060-all-cluster-example_SIGNED.bin 0x60040000 +``` +For RT1170-EVKB +``` +J-Link > loadbin chip-rt1170-all-cluster-example_SIGNED.bin 0x30040000 +``` The bootloader should then be able to jump directly to the start of the application and run it. @@ -216,18 +249,18 @@ To generate the OTA update image the same procedure can be followed from the [Generating and flashing the signed application image](#generating-and-flashing-the-signed-application-image) sub-section, replacing the "--version "1.0"" argument with "--version "2.0"" (recent version of the update), without arguments "--pad" "--confirm" when -running `imgtool` script during OTA Update Image generation. +running imgtool script during OTA Update Image generation. Note : When building the update image, the build arguments -nxp_software_version=2 nxp_software_version_string=\"2.0\" can be added to the -gn gen command in order to specify the upgraded version. +nxp_software_version=2 nxp_software_version_string=\"2.0\" can be added to the gn +gen command in order to specify the upgraded version. When the signed binary of the update is generated, the file should be converted into OTA format. To do so, the ota_image_tool is provided in the repo and can be used to convert a binary file into an .ota file. -``` -user@ubuntu:~/connectedhomeip$ : ./src/app/ota_image_tool.py create -v 0xDEAD -p 0xBEEF -vn 2 -vs "2.0" -da sha256 chip-rw61x-all-cluster-example_SIGNED.bin chip-rw61x-all-cluster-example.ota +```sh +user@ubuntu:~/connectedhomeip$ : ./src/app/ota_image_tool.py create -v 0xDEAD -p 0xBEEF -vn 2 -vs "2.0" -da sha256 chip-<"rt_board">-all-cluster-example_SIGNED.bin chip-rw61x-all-cluster-example.ota ``` The generated OTA file can be used to perform the OTA Software Update. The @@ -240,7 +273,7 @@ Setup example : - [Chip-tool](../../../examples/chip-tool/README.md) application running on the RPi. - OTA Provider application built on the same RPi (as explained below). -- RW61x board programmed with the example application (with the instructions +- RT board programmed with the example application (with the instructions above). Before starting the OTA process, the Linux OTA Provider application can be built @@ -248,9 +281,10 @@ on the RPi (if not already present in the pre-installed apps) : ``` user@ubuntu:~/connectedhomeip$ : ./scripts/examples/gn_build_example.sh examples/ota-provider-app/linux out/ota-provider-app chip_config_network_layer_ble=false - user@ubuntu:~/connectedhomeip$ : rm -rf /tmp/chip_* -user@ubuntu:~/connectedhomeip$ : ./out/ota-provider-app/chip-ota-provider-app -f chip-rw61x-all-cluster-example.ota +``` +```sh +user@ubuntu:~/connectedhomeip$ : ./out/ota-provider-app/chip-ota-provider-app -f chip-<"rt_board">-all-cluster-example.ota ``` The OTA Provider should first be provisioned with chip-tool by assigning it the diff --git a/examples/all-clusters-app/nxp/rt/rt1170/README.md b/examples/all-clusters-app/nxp/rt/rt1170/README.md index 38eee7dd93581a..4146b9dd6bfd56 100644 --- a/examples/all-clusters-app/nxp/rt/rt1170/README.md +++ b/examples/all-clusters-app/nxp/rt/rt1170/README.md @@ -241,7 +241,7 @@ Optional GN options that can be added when building an application: - To build the application with the OTA Requestor enabled, the arguments `chip_enable_ota_requestor=true no_mcuboot=false` must be added to the _gn gen_ command. (More information about the OTA Requestor feature in - [OTA Requestor README](README_OTA_Requestor.md))) + [OTA Requestor README](../../../../../docs/guides/nxp/nxp_RTs_ota_software_update.md))) diff --git a/examples/all-clusters-app/nxp/rt/rt1170/README_OTA_Requestor.md b/examples/all-clusters-app/nxp/rt/rt1170/README_OTA_Requestor.md deleted file mode 100644 index f45045f3948644..00000000000000 --- a/examples/all-clusters-app/nxp/rt/rt1170/README_OTA_Requestor.md +++ /dev/null @@ -1,173 +0,0 @@ -# OTA requestor feature - -## Overview -The OTA Requestor feature enables the device to be informed of, download and apply a software update from an OTA Provider. - -This section explains how to perform an OTA Software Update using the RT1170 All-Clusters application. - -In general, the Over-The-Air Software Update process consists of the following steps : -- The OTA Requestor queries an update image from the OTA Provider which responds according to its availability. -- The update image is received in blocks and stored in the external flash of the device. -- Once the update image is fully downloaded, the bootloader is notified and the device resets applying the update in test-mode. -- If the test is successful, the update is applied permanently. Otherwise, the bootloader reverts back to the primary application, preventing any downgrade. - -### Flash Memory Layout - -The RT1170 Flash is divided into different regions as follow : -- Bootloader : MCUBoot resides at the base of the flash and occupies 0x40000 (256 kBytes). -- Primary application partition : The all-clusters application which would be run by the bootloader (active application). The size reserved for this partition is 4MBytes. -- Secondary application partition : Update image received with the OTA (candidate application). The size reserved for this partition is 4MBytes. - -Note : The sizes of the primary and secondary applications are provided as an example (currently 4MB is reserved for each partition). The size can be changed by modifying the `m_app_max_sectors` value in the linkerscript of the application (MIMXRT1176xxxxx_cm7_flexspi_nor.ld). - -### MCUBoot Bootloader - -MCUBoot is an open-source secure bootloader used by RT1170 to apply the self-upgrade. For more details, please refer to the [MCUBoot documentation](https://github.com/mcu-tools/mcuboot/blob/main/docs/design.md). - -In our use case, the bootloader runs the application residing in the primary partition. In order to run the OTA update image, the bootloader will swap the content of the primary and the secondary partitions. This type of upgrade is called swap-move and is the default upgrade configured by MCUBoot. - -## OTA Software Update process for RT1170 all-clusters application - -### Flashing the bootloader - -In order for the device to perform the software update, the MCUBoot bootloader must be flashed first at the base of the flash. A step-by-step guide is given below. - -- MIMXRT1170-EVKB board supports CMSIS-DAP debug protocol by default. It should be switched to JLink. - - download and install [MCU-LINK_INSTALLER 2.263](https://www.nxp.com/webapp/Download?colCode=MCU-LINK_INSTALLER_2.263_LIN) - - connect jumper JP3 to get board in ISP mode when powered - - connect board and run installed MCU-LINK, follow steps to flash JLINK firmware - - remove jumper JP3 and reboot board - -- It is recommended to start with erasing the external flash of the device, for this JLink from Segger can be used. It can be downloaded and installed from https://www.segger.com/products/debug-probes/j-link. Once installed, JLink can be run using the command line : -``` -$ JLink -``` -Run the following commands : -``` -J-Link > erase 0x30000000, 0x3043f000 -``` -- Build mcuboot binary: - -``` -cd /third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples/evkbmimxrt1170/ota_examples/mcuboot_opensource/cm7/armgcc -``` -Edit the file `flags.cmake` and `-DCONFIG_MCUBOOT_SWAP_MOVE=1` in `CMAKE_C_FLAGS_FLEXSPI_NOR_RELEASE` and `CMAKE_CXX_FLAGS_FLEXSPI_NOR_DEBUG`. - -``` -chmod +x build_flexspi_nor_release.sh -export ARMGCC_DIR=/opt/gcc-arm-none-eabi-10-2020-q4-major/ # with ARMGCC_DIR referencing the compiler path -./build_flexspi_nor_release.sh -``` -Flash the generated binary with JLINK -``` -J-Link > loadbin /third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples/evkbmimxrt1170/ota_examples/mcuboot_opensource/cm7/armgcc/flexspi_nor_release/mcuboot_opensource.elf -``` -If it runs successfully, the following logs will be displayed on the terminal : - -``` -hello sbl. -Bootloader Version 2.0.0 -Primary image: magic=unset, swap_type=0x1, copy_done=0x3, image_ok=0x3 -Secondary image: magic=unset, swap_type=0x1, copy_done=0x3, image_ok=0x3 -Boot source: none -Image index: 0, Swap type: none -erasing trailer; fa_id=1 -Unable to find bootable image -``` - -Note : By default, mcuboot application considers the primary and secondary partitions to be the size of 4MB. If the size is to be changed, the partition addresses should be modified in the flash_partitioning.h accordingly. For more information about the flash partitioning with mcuboot, please refer to the dedicated readme.txt located in "/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples/evkbmimxrt1170/ota_examples/mcuboot_opensource/". - -### Generating and flashing the signed application image - -After flashing the bootloader, the application can be programmed to the board. The image must have the following format : -- Header : contains general information about the image (version, size, magic...) -- Code of the application : generated binary -- Trailer : contains metadata needed by the bootloader such as the image signature, the upgrade type, the swap status... - -The application can be generated using the instructions from the [README.md 'Building section'][readme_building_section] section. The application is automatically linked to be executed from the primary image partition, taking into consideration the offset imposed by mcuboot. - -[readme_building_section]: README.md#building - -The resulting executable file found in out/debug/chip-rt1170-all-cluster-example needs to be converted into raw binary format as shown below. -``` -arm-none-eabi-objcopy -R .flash_config -R .ivt -R .NVM -O binary chip-rt1170-all-cluster-example chip-rt1170-all-cluster-example.bin -``` -To sign the image and wrap the raw binary of the application with the header and trailer, "imgtool" is provided in the SDK and can be found in "/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/middleware/mcuboot_opensource/scripts/". - -The following commands can be run (make sure to replace the /path/to/file/binary with the adequate files): - -``` -user@ubuntu: cd /third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/middleware/mcuboot_opensource/scripts/ - -user@ubuntu: python3 imgtool.py sign --key ~/Desktop/SDK_RT1170/boards/evkbmimxrt1170/mcuboot_opensource/cm7/keys/sign-rsa2048-priv.pem --align 4 --header-size 0x1000 --pad-header --pad --confirm --slot-size 0x400000 --max-sectors 512 --version "1.0" ~/Desktop/connectedhomeip/examples/all-clusters-app/nxp/rt/rt1170/out/debug/chip-rt1170-all-cluster-example.bin ~/Desktop/connectedhomeip/examples/all-clusters-app/nxp/rt/rt1170/out/debug/chip-rt1170-all-cluster-example_SIGNED.bin -``` -Note : - -- The arguments `slot-size` and `max-sectors` should be adjusted to the size of the partitions reserved for the primary and the secondary applications. (By default the size considered is 4MB) - -- In this example, the image is signed with the private key provided by the SDK as an example (/third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/examples/evkbmimxrt1170/ota_examples/mcuboot_opensource/cm7/keys/sign-rsa2048-priv.pem), MCUBoot is built with its corresponding public key which would be used to verify the integrity of the image. It is possible to generate a new pair of keys using the following commands. This procedure should be done prior to building the mcuboot application. - -- To generate the private key : - -``` -user@ubuntu: python3 imgtool.py keygen -k priv_key.pem -t rsa-2048 -``` -- To extract the public key : - -``` -user@ubuntu: python3 imgtool.py getpub -k priv_key.pem -``` -- The extracted public key can then be copied to the /third_party/nxp/nxp_matter_support/github_sdk/common_sdk/repo/middleware/mcuboot_opensource/boot/nxp_mcux_sdk/keys/sign-rsa2048-pub.c, given as a value to the rsa_pub_key[] array. - - -The resulting output is the signed binary of the application version "1.0". - -JLink can be used to flash the application at the address 0x30040000, using the command : -``` -J-Link > loadbin chip-rt1170-all-cluster-example_SIGNED.bin 0x30040000 -``` - -The bootloader should then be able to jump directly to the start of the application and run it. - -### Generating the OTA Update Image - -To generate the OTA update image the same procedure can be followed from the [Generating and flashing the signed application image](#generating-and-flashing-the-signed-application-image) sub-section, replacing the "--version "1.0"" argument with "--version "2.0"" (recent version of the update). - -When the signed binary of the update is generated, the file should be converted into OTA format. To do so, the ota_image_tool is provided in the repo and can be used to convert a binary file into an .ota file. - -``` -user@ubuntu:~/connectedhomeip$ : ./src/app/ota_image_tool.py create -v 0xDEAD -p 0xBEEF -vn 2 -vs "2.0" -da sha256 chip-rt1170-all-cluster-example_SIGNED.bin chip-rt1170-all-cluster-example.ota -``` -The generated OTA file can be used to perform the OTA Software Update. The instructions below describe the procedure step-by-step. - -### Performing the OTA Software Update - -Setup example : -- [Chip-tool](../../../../../examples/chip-tool/README.md) application running on the RPi. -- OTA Provider application built on the same RPi (as explained below). -- RT1170 board programmed with the All-clusters application (with the instructions above). - -Before starting the OTA process, the Linux OTA Provider application can be built on the RPi (if not already present in the pre-installed apps) : -``` -user@ubuntu:~/connectedhomeip$ : ./scripts/examples/gn_build_example.sh examples/ota-provider-app/linux out/ota-provider-app chip_config_network_layer_ble=false - -user@ubuntu:~/connectedhomeip$ : rm -rf /tmp/chip_* -user@ubuntu:~/connectedhomeip$ : ./out/ota-provider-app/chip-ota-provider-app -f chip-rt1170-all-cluster-example.ota -``` -The OTA Provider should first be provisionned with chip-tool by assigning it the node id 1, and then granted the ACL entries : -``` -user@ubuntu:~/connectedhomeip$ : ./out/chip-tool-app/chip-tool pairing onnetwork 1 20202021 -user@ubuntu:~/connectedhomeip$ : ./out/chip-tool-app/chip-tool 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 second step is to provision the device with the node id 2 using ble-wifi or ble-thread commissioning. For example : -``` -user@ubuntu:~/connectedhomeip$ : ./out/chip-tool-app/chip-tool pairing ble-wifi 2 WIFI_SSID WIFI_PASSWORD 20202021 3840 -``` - - -Once commissioned, the OTA process can be initiated with the "announce-ota-provider" command using chip-tool (the given numbers refer respectively to [ProviderNodeId] [VendorId] [AnnouncementReason] [Endpoint] [node-id] [endpoint-id]) : -``` -user@ubuntu:~/connectedhomeip$ : ./out/chip-tool-app/chip-tool otasoftwareupdaterequestor announce-otaprovider 1 0 0 0 2 0 -``` - -When the full update image is downloaded and stored, the bootloader will be notified and the device will reboot with the update image.