MCUXpresso_MIMXRT1052xxxxB/boards/evkbimxrt1050/ota_examples/mcuboot_opensource
Yilin Sun 6baf4427ce
Updated to v2.15.000
Signed-off-by: Yilin Sun <imi415@imi.moe>
2024-03-18 23:15:10 +08:00
..
armgcc Updated to v2.15.000 2024-03-18 23:15:10 +08:00
flash Updated to v2.15.000 2024-03-18 23:15:10 +08:00
include Updated to v2.15.000 2024-03-18 23:15:10 +08:00
keys Updated to v2.14.0 2023-11-30 20:55:00 +08:00
linkscripts Updated to v2.14.0 2023-11-30 20:55:00 +08:00
board.c Updated to v2.15.000 2024-03-18 23:15:10 +08:00
board.h Updated to v2.15.000 2024-03-18 23:15:10 +08:00
boot.c Updated to v2.14.0 2023-11-30 20:55:00 +08:00
boot.h Updated to v2.14.0 2023-11-30 20:55:00 +08:00
bootutil_hooks.c Updated to v2.14.0 2023-11-30 20:55:00 +08:00
clock_config.c Updated to v2.14.0 2023-11-30 20:55:00 +08:00
clock_config.h Updated to v2.14.0 2023-11-30 20:55:00 +08:00
dcd.c Updated to v2.14.0 2023-11-30 20:55:00 +08:00
dcd.h Updated to v2.14.0 2023-11-30 20:55:00 +08:00
flash_partitioning.c Updated to v2.14.0 2023-11-30 20:55:00 +08:00
flash_partitioning.h Updated to v2.14.0 2023-11-30 20:55:00 +08:00
keys.c Updated to v2.14.0 2023-11-30 20:55:00 +08:00
main.c Updated to v2.14.0 2023-11-30 20:55:00 +08:00
mcuboot_opensource_v3_14.xml Updated to v2.15.000 2024-03-18 23:15:10 +08:00
os.c Updated to v2.14.0 2023-11-30 20:55:00 +08:00
pin_mux.c Updated to v2.14.0 2023-11-30 20:55:00 +08:00
pin_mux.h Updated to v2.14.0 2023-11-30 20:55:00 +08:00
readme.md Updated to v2.15.000 2024-03-18 23:15:10 +08:00
sbl_boot.c Updated to v2.14.0 2023-11-30 20:55:00 +08:00
sblconfig.h Updated to v2.14.0 2023-11-30 20:55:00 +08:00

readme.md

Overview

The mcuboot_opensource is a second stage bootloader based on MCUBoot project. It is primarily meant to be used together with OTA (over-the-air) update examples to demonstrate functionality of application self-upgrade.

Flash memory layout

Flash memory is divided into multiple regions to allocate space for bootloader, main application and application update:

  • MCUBoot partition (reserved for bootloader itself, starts at the beginning of the FLASH memory)
  • Primary application partition (active application image)
  • Secondrary application partition (candidate application - place to download OTA image to be used for update)

The partitioning is defined by definitions in flash_partitioning.h header file. The MCUBoot partition starts at the very beginning of the FLASH memory and spans up to BOOT_FLASH_ACT_APP. The primary partition occupies range starting from BOOT_FLASH_ACT_APP up to BOOT_FLASH_CAND_APP. The secondary partition starts at BOOT_FLASH_CAND_APP and it is automatically assigned the same size as the primary one. The rest of the memory may be used by the application for arbitrary purposes.

Important notice: should you need to change the partitioning please make sure to update also the header file used by the OTA application! If the partitioning information used by the bootloader and the application is not in sync, it may lead to malfunction of boot/OTA process or to upredictable behavior.

Flash remapping functionality The default upgrade mechanism in MCUBoot is SWAP algorithm. There are several NXP processors which support flash remapping functionality what can be used to speed up the OTA update process and prolong the flash memory wear process by just switching the valid images. The boards with such processors have example projects configured to use this feature. This is achieved by using MCUBoot DIRECT-XIP mechanism and by activating flash remapping when needed. Both projects (MCUBoot and evaluated OTA example) using the flash remapping funcionality can be also configured to use and evaluate default SWAP mechanism if needed. For more information see "MCUBoot upgrade mode" in sblconfig.h (MCUBoot project).

IMPORTANT NOTE: Signed application images directly programmed into flash memory by a programmer require additional "--pad --confirm" parameter for imgtool. This parameter adds additional trailer to the signed image and is required by bootloader direct-xip process (see MCUBoot documentation for more information). Signed images used in OTA process do not require "-pad" parameter.

List of boards with projects supporting flash remapping function: - MIMXRT1040-EVK - MIMXRT1060-EVK - MIMXRT1060-EVKB - MIMXRT1064-EVK - MIMXRT1160-EVK - MIMXRT1170-EVK - MIMXRT1170-EVKB

Signing the application image

MCUBoot expects signed application image in specific format to be present in the primary partition. The very same image format it also used for OTA updates.

A dedicated tool (imgtool) is used to obtain application image in the desired format. It is implemented as a Python script which can be found in the SDK package in middleware/mcuboot_opensource/scripts folder.

Alternatively the tool can be installed by the Python package manager:

  • "pip install imgtool"

Please note that imgtool version installed by the Python package manager is not guaranteed to be compatible with MCUBoot present in you SDK package.

The mcuboot_opensource SDK project comes with its set of private-public keys. The key pair is stored in the keys subdirectory (e.g. boards/[board]/mcuboot_opensource/keys). The public key is already pre-configured in the source code of MCUBoot in a form of an array initializer.

To sign an application binary, imgtool must be provided with respective private key and a set of parameters as in the following example:

imgtool sign --key sign-rsa2048-priv.pem --align 4 --header-size 0x400 --pad-header --slot-size 0x200000 --max-sectors 800 --version "1.0.0-0" app_binary.bin app_binary_SIGNED.bin

The parameters used in the example above are tested with out-of-the-box configuration of MCUBoot and OTA examples in the SDK package. However, some of them may depend on the application or board setup and thus may need to be modified. See the MCUBoot documentation for the meaning of the parameters and align them with your project setup if necessary. https://docs.mcuboot.com/imgtool.html

SDK version

  • Version: 2.15.000

Toolchain supported

  • IAR embedded Workbench 9.40.1
  • Keil MDK 5.38.1
  • GCC ARM Embedded 12.2
  • MCUXpresso 11.8.0

Hardware requirements

  • Mini/micro USB cable
  • EVKB-IMXRT1050 board
  • Personal Computer

Board settings

No special settings are required.

Prepare the Demo

  1. Connect a USB cable between the PC host and the OpenSDA(or USB to Serial) USB port on the target board.
  2. Open a serial terminal on PC for OpenSDA serial(or USB to Serial) device with these settings:
    • 115200 baud rate
    • 8 data bits
    • No parity
    • One stop bit
    • No flow control
  3. Build project and program it to the target board.
  4. Either press the reset button on your board or launch the debugger in your IDE to begin running the demo.

Running the demo

  1. When the demo runs successfully, the terminal will display the following: hello sbl. Bootloader Version 1.0.0
  2. Further messages printed to the terminal depend on the content of the FLASH memory. In case there was no application programmed so far (i.e. the FLASH was blank), the following would be printed: 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 Swap type: none erasing trailer; fa_id=2 Unable to find bootable image
  3. At this point the bootloader is in place, resident in the FLASH memory. You may stop debuger, switch to an OTA example and follow the relevant readme.