Skip to content

Commit 09fb523

Browse files
AhmedIsmail02Filip Jagodzinski
and
Filip Jagodzinski
authored
Add ML Model component OTA update on keyword-detection application (#106)
* sign-tfm-image: Refactor the CMake Module The `SignTfmImage.cmake` module is refactored to to accept an input binary name and an input signing layout file. These modifications are going to be used to sign the non_secure and the ML Model images separately which is essential to add the ML Model component OTA update feature. Signed-off-by: Ahmed Ismail <[email protected]> * fvp-options: Remove `--fast` option `--fast` FVP NPU option is removed as it's not completely supported by all platforms. Signed-off-by: Ahmed Ismail <[email protected]> * cs-300: Extract the ML model to a separate binary Eventually, we want the MCUBoot (and the rest of TF-M) to handle the ML model in the same way as other components. To achieve that, the ML model component will be kept in flash during boot, for the MCUBoot to validate the image, and perform the swap operation if needed. Since the Ethos NPU doesn't have access to flash, the model will be copied back to DDR at runtime. This is why the model is still kept in the DDR memory region in the linker script. Patches for the trusted_firmware-m component: - Add support for the third image for cs-300 platform. - Configure the signing layout for the ML model, and reuse the NS key. - Add a modified flash map for the cs-300, for the MCUBoot to handle the third image. This is based on the default flash layout used before. Signed-off-by: Filip Jagodzinski <[email protected]> Signed-off-by: Ahmed Ismail <[email protected]> * cs-310: Extract the ML model to a separate binary Eventually, we want the MCUBoot (and the rest of TF-M) to handle the ML model in the same way as other components. To achieve that, the ML model component will be kept in flash during boot, for the MCUBoot to validate the image, and perform the swap operation if needed. Since the Ethos NPU doesn't have access to flash, the model will be copied back to DDR at runtime. This is why the model is still kept in the DDR memory region in the linker script. Patches for the trusted_firmware-m component: - Add support for the third image for cs-310 platform. - Configure the signing layout for the ML model, and reuse the NS key. - Add a modified flash map for the cs-310, for the MCUBoot to handle the third image. This is based on the default flash layout used before. Signed-off-by: Filip Jagodzinski <[email protected]> Signed-off-by: default avatarAhmed Ismail <[email protected]> * mps4: Extract the ML model to a separate binary Eventually, we want the MCUBoot (and the rest of TF-M) to handle the ML model in the same way as other components. To achieve that, the ML model component will be kept in flash during boot, for the MCUBoot to validate the image, and perform the swap operation if needed. Since the Ethos NPU doesn't have access to flash, the model will be copied back to DDR at runtime. This is why the model is still kept in the DDR memory region in the linker script. Patches for the trusted_firmware-m component: - Add support for the third image for mps4 platforms. - Configure the signing layout for the ML model, and reuse the NS key. - Add a modified flash map for the mps4 platforms, for the MCUBoot to handle the third image. This is based on the default flash layout used before. These changes applies to both: * Corstone-315 Platform. * Corstone-320 Platform. Signed-off-by: Filip Jagodzinski <[email protected]> Signed-off-by: Ahmed Ismail <[email protected]> * keyword: Extract the ML model as a TF-M component keyword-detection example: - Configure the MCUBoot to work with 3 components instead of 2. - Configure the MCUBoot to use a non-default flash map. - Set the ML model image version. - Sign the ML model image using the same key as the NS image. - Generate an update signature for the ML model image. - At the ML task init, add a new step, where the ML model is copied from flash to DDR. - Update the merge images CMake function in TF-M integration layer to handle the third component (the ML model image). - Update the extract_sections_from_axf CMake function. Patches for the freertos_ota_pal_psa component: - Add the ML model file path. - Stop using a global variable to store the NS image version. - Fix the GetImageVersionPSA to return the version to an output param for any given component (rather than update the global var). Patches for the ml_embedded_evaluation_kit component: - Override EthosU55 NPU default IRQ handler to avoid modifying the vector table in run-time which alter the non-secure image result in MCUBoot validation failure. Additions for the OTA Orchestrator: - Stop using a global variable to store the NS image version. - Replace all the uses of the appFirmwareVersion global var with the appropriate call to the new image version getter. Signed-off-by: Filip Jagodzinski <[email protected]> Signed-off-by: Ahmed Ismail <[email protected]> * ml-update-demo: Update from a faulty model to a working one Add a modified tflite file that produces no inference results at runtime. This file can be used to build an application that is fully functional, but the ML inference is unsuccessful in detecting any keyword. Applying an OTA ML model update in this state is very visible since the updated model does work as expected (detects keywords from audio samples). Signed-off-by: Filip Jagodzinski <[email protected]> Signed-off-by: Ahmed Ismail <[email protected]> * freertos-integration-tests: Remove OTA update dependencies Since we don't run OTA tests as part of the intgeration tests anymore, we don't need to sign the update binary and there is no need to upload the update binary to AWS. Signed-off-by: Ahmed Ismail <[email protected]> * ci: Add keyword-detection ML Model update nightly test Add a new nightly test to verify the ML model OTA update, this is done for Keyword-Detection application compiled with GNU toolchain only as this is the currently supported combination. This nightly test runs on all the Corstone platforms. Signed-off-by: Ahmed Ismail <[email protected]> --------- Signed-off-by: Ahmed Ismail <[email protected]> Signed-off-by: Filip Jagodzinski <[email protected]> Signed-off-by: default avatarAhmed Ismail <[email protected]> Co-authored-by: Filip Jagodzinski <[email protected]>
1 parent 4fb65d8 commit 09fb523

File tree

69 files changed

+3674
-306
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

69 files changed

+3674
-306
lines changed

.github/.cSpellWords.txt

+5
Original file line numberDiff line numberDiff line change
@@ -168,6 +168,7 @@ NVIC
168168
ohmyzsh
169169
Onoa
170170
OPTIM
171+
optimise
171172
OPTIMISED
172173
otaexample
173174
otapalconfig
@@ -202,6 +203,7 @@ RSASSA
202203
rtrack
203204
SBCON
204205
SECP
206+
smsc
205207
sntp
206208
Sntp
207209
SNTP
@@ -219,6 +221,7 @@ suppr
219221
SYSWDOG
220222
TALGORITHMS
221223
testThing
224+
tflite
222225
TGENERAL
223226
THEIGHT
224227
tinycbor
@@ -239,11 +242,13 @@ uncrustify
239242
unusued
240243
utilises
241244
USART
245+
utilises
242246
UYVY
243247
Vbex
244248
VCLK
245249
VECTACTIVE
246250
venv
251+
visualisation
247252
vmean
248253
vsocket
249254
vsync

0 commit comments

Comments
 (0)