How to use Hardware-based downgrade protection

Hello.

I am trying to follow Downgrade protection using MCUboot to enable Hardware-based downgrade protection.
However, an error occurred, and the software did not start. It is also from the initial flash, not after the update.

*** Booting MCUboot v2.1.0-dev-12e5ee106034 ***
*** Using nRF Connect SDK v2.9.0-7787b2649840 ***
*** Using Zephyr OS v3.7.99-1f8f3dc29142 ***
I: Starting bootloader
I: Image index: 0, Swap type: none
I: Image index: 1, Swap type: none
E: Security counter update failed after image validation.
E: Unable to find bootable image

The "sysbuild.conf" is as follows.
It is the minimum configuration according to Exercise 5 – FOTA over Bluetooth Low Energy and Simultaneous updates for both cores of the nRF5340.
Naturally, if the last three lines related to downgrade protection are disabled, the software will start.

# STEP 2.1 Enable MCUboot
SB_CONFIG_BOOTLOADER_MCUBOOT=y

# STEP 6.3 - Configure project to use external flash for DFU
SB_CONFIG_PM_EXTERNAL_FLASH_MCUBOOT_SECONDARY=y

 # STEP 7.2 - Add b0n image
SB_CONFIG_SECURE_BOOT_NETCORE=y

# STEP 7.3 - Set up multiple partitions
SB_CONFIG_MCUBOOT_UPDATEABLE_IMAGES=2

# STEP 7.4 - Add support to netcore for DFU
SB_CONFIG_NETCORE_APP_UPDATE=y

# STEP 7.5 - Add support to mcuboot for updating
# two cores simultaneously
SB_CONFIG_MCUBOOT_NRF53_MULTI_IMAGE_UPDATE=y

# STEP 7.6 - Simultaneous FOTA does not support rollback
SB_CONFIG_MCUBOOT_MODE_OVERWRITE_ONLY=y

# Enable Hardware-based downgrade protection
SB_CONFIG_MCUBOOT_HARDWARE_DOWNGRADE_PREVENTION=y
SB_CONFIG_MCUBOOT_HW_DOWNGRADE_PREVENTION_COUNTER_SLOTS=24
SB_CONFIG_MCUBOOT_HW_DOWNGRADE_PREVENTION_COUNTER_VALUE=1

Also, a similar issue was reported in another person's ticket.
However, even following the configuration there, the issue did not change.

Thanks for reading.

a.da

  • PR updated, should work now, please re-check.

  • Hi Amanda,

    Thanks to your help, I was able to successfully update the Network Core.
    The issue in the title has been resolved.

    However, I still have a few questions:

    • About the Downgrade Protection of the Network Core
      Even with Downgrade Protection enabled, the Network Core is still downgradeable.
      However, version mismatches between the App Core and the Network Core should be avoided.
      If you have any ideas on how to resolve this, please let me know.
    • About the monotonic counter
      Is there a way to retrieve the current value?
      I am assuming it will be displayed on a PC serial terminal or a smartphone app.
    • About Image Swap
      It seems that when the update count reaches the value of SB_CONFIG_MCUBOOT_HW_DOWNGRADE_PREVENTION_COUNTER_SLOTS, the Image Swap of the App Core is performed every time the software is rebooted.
      Is this the expected behavior?

    The logs during the update and reboot are as follows:

    monotonic counter < SB_CONFIG_MCUBOOT_HW_DOWNGRADE_PREVENTION_COUNTER_SLOTS

    Update

    [00:00:18.749,969] <err> mcumgr_img_grp: Failed to open flash area ID 1: -2
    [00:00:19.052,307] <inf> mcuboot_util: Image index: 0, Swap type: none
    [00:00:41.610,382] <inf> mcuboot_util: Image index: 1, Swap type: none
    *** Booting MCUboot v2.1.0-dev-12e5ee106034 ***
    *** Using nRF Connect SDK v2.9.0-7787b2649840 ***
    *** Using Zephyr OS v3.7.99-1f8f3dc29142 ***
    I: Starting bootloader
    I: Image index: 0, Swap type: perm
    I: Image index: 1, Swap type: perm
    I: Image 0 upgrade secondary slot -> primary slot
    I: Erasing the primary slot
    I: Image 0 copying the secondary slot to the primary slot: 0x44784 bytes
    D: writing magic; fa_id=4 off=0xebff0 (0xf7ff0)
    D: erasing secondary header
    D: erasing secondary trailer
    I: Image 1 upgrade secondary slot -> primary slot
    I: Erasing the primary slot
    I: Image 1 copying the secondary slot to the primary slot: 0x2a3c0 bytes
    D: writing magic; fa_id=1 off=0x3fff0 (0x3fff0)
    D: erasing secondary header
    D: erasing secondary trailer
    I: Bootloader chainload address offset: 0xc000
    *** Booting Mesh Light Fixture v2.9.0-d54b9798c66e ***
    *** Using nRF Connect SDK v2.9.0-7787b2649840 ***
    *** Using Zephyr OS v3.7.99-1f8f3dc29142 ***

    Reboot

    *** Booting MCUboot v2.1.0-dev-12e5ee106034 ***
    *** Using nRF Connect SDK v2.9.0-7787b2649840 ***
    *** Using Zephyr OS v3.7.99-1f8f3dc29142 ***
    I: Starting bootloader
    I: Image index: 0, Swap type: none
    I: Image index: 1, Swap type: none
    I: Bootloader chainload address offset: 0xc000
    *** Booting Mesh Light Fixture v2.9.0-d54b9798c66e ***
    *** Using nRF Connect SDK v2.9.0-7787b2649840 ***
    *** Using Zephyr OS v3.7.99-1f8f3dc29142 ***

    monotonic counter = SB_CONFIG_MCUBOOT_HW_DOWNGRADE_PREVENTION_COUNTER_SLOTS

    Update

    [00:00:30.237,457] <err> mcumgr_img_grp: Failed to open flash area ID 1: -2
    [00:00:30.538,299] <inf> mcuboot_util: Image index: 0, Swap type: none
    [00:00:53.067,932] <inf> mcuboot_util: Image index: 1, Swap type: none
    *** Booting MCUboot v2.1.0-dev-12e5ee106034 ***
    *** Using nRF Connect SDK v2.9.0-7787b2649840 ***
    *** Using Zephyr OS v3.7.99-1f8f3dc29142 ***
    I: Starting bootloader
    I: Image index: 0, Swap type: perm
    I: Image index: 1, Swap type: perm
    I: Image 0 upgrade secondary slot -> primary slot
    I: Erasing the primary slot
    I: Image 0 copying the secondary slot to the primary slot: 0x44784 bytes
    D: writing magic; fa_id=4 off=0xebff0 (0xf7ff0)
    E: Security counter update failed after image upgrade.
    I: Image 1 upgrade secondary slot -> primary slot
    I: Erasing the primary slot
    I: Image 1 copying the secondary slot to the primary slot: 0x2a3c0 bytes
    D: writing magic; fa_id=1 off=0x3fff0 (0x3fff0)
    D: erasing secondary header
    D: erasing secondary trailer
    I: Bootloader chainload address offset: 0xc000
    *** Booting Mesh Light Fixture v2.9.0-d54b9798c66e ***
    *** Using nRF Connect SDK v2.9.0-7787b2649840 ***
    *** Using Zephyr OS v3.7.99-1f8f3dc29142 ***

    Reboot

    *** Booting MCUboot v2.1.0-dev-12e5ee106034 ***
    *** Using nRF Connect SDK v2.9.0-7787b2649840 ***
    *** Using Zephyr OS v3.7.99-1f8f3dc29142 ***
    I: Starting bootloader
    I: Image index: 0, Swap type: perm
    I: Image index: 1, Swap type: none
    I: Image 0 upgrade secondary slot -> primary slot
    I: Erasing the primary slot
    I: Image 0 copying the secondary slot to the primary slot: 0x44784 bytes
    D: writing magic; fa_id=4 off=0xebff0 (0xf7ff0)
    E: Security counter update failed after image upgrade.
    I: Bootloader chainload address offset: 0xc000
    *** Booting Mesh Light Fixture v2.9.0-d54b9798c66e ***
    *** Using nRF Connect SDK v2.9.0-7787b2649840 ***
    *** Using Zephyr OS v3.7.99-1f8f3dc29142 ***

    Kind regards,

    a.da

  • Hi!

    Amanda is out of office.

    a.da said:
    Thanks to your help, I was able to successfully update the Network Core.
    The issue in the title has been resolved.

    Great!

    a.da said:
    However, I still have a few questions:

    Please open a new case for these new questions.

  • Hi Sigurd,

    You're right. I have written new questions here.

    a.da

Related