Secure boot for 32-bit Microcontrollers!
Go to file
Kristine Jassmann 73c38c6fde bootutil: Allow larger minimum flash write
[kristine.jassmann@renesas.com: Allow larger minimum flash write]
[michael.thomas@renesas.com: Add changes for 1.8]
[michael.thomas@renesas.com: Add magic alignment fix]
[gustavo.nihei@espressif.com: bootutil: Address issues from PR 949]

Co-authored-by: Kristine Jassmann <kristine.jassmann@renesas.com>
Co-authored-by: Michael Thomas <michael.thomas@renesas.com>
Co-authored-by: Gustavo Henrique Nihei <gustavo.nihei@espressif.com>
Signed-off-by: Kristine Jassmann <kristine.jassmann@renesas.com>
Signed-off-by: Michael Thomas <michael.thomas@renesas.com>
Signed-off-by: Gustavo Henrique Nihei <gustavo.nihei@espressif.com>
2021-12-16 13:19:12 -07:00
.github/workflows ci: Enable build of espressif port for supported chips 2021-11-04 06:32:43 -03:00
boot bootutil: Allow larger minimum flash write 2021-12-16 13:19:12 -07:00
ci ci: Enable build of espressif port for supported chips 2021-11-04 06:32:43 -03:00
docs doc: Updated index.md and readme.md 2021-12-08 13:50:43 -07:00
ext doc: Fix case in titles 2021-11-03 17:05:40 +01:00
ptest
samples samples: zephyr: Use move swap for Zephyr tests 2021-12-15 17:15:56 -07:00
scripts bootutil: Allow larger minimum flash write 2021-12-16 13:19:12 -07:00
sim sim: Remove unused variables 2021-12-16 07:34:50 -03:00
testplan/mynewt
zephyr
.gitignore sim: Move Cargo package to top level 2021-09-17 10:45:53 -06:00
.gitmodules boot/espressif: Add hal subdirectory for IDF sources and headers 2021-08-09 14:57:53 -06:00
.mbedignore Ignore nuttx files for Mbed-OS builds 2021-08-20 14:10:42 -03:00
.travis.yml-disabled ci: disable Travis 2021-09-27 14:23:19 -03:00
CODE_OF_CONDUCT.md
Cargo.lock sim: Move Cargo package to top level 2021-09-17 10:45:53 -06:00
Cargo.toml sim: Move Cargo package to top level 2021-09-17 10:45:53 -06:00
LICENSE
NOTICE
README.md doc: Updated index.md and readme.md 2021-12-08 13:50:43 -07:00
enc-aes128kw.b64
enc-aes256kw.b64
enc-ec256-priv.pem
enc-ec256-pub.pem
enc-rsa2048-priv.pem
enc-rsa2048-pub.pem
enc-x25519-priv.pem
enc-x25519-pub.pem
go.mod
project.yml
repository.yml Preps for 1.8.0 2021-10-13 10:03:58 -06:00
root-ec-p256-pkcs8.pem
root-ec-p256.pem
root-ed25519.pem
root-rsa-2048.pem
root-rsa-3072.pem

README.md

MCUboot

Package on PyPI Coverity Scan Build Status Build Status (Sim) Build Status (Mynewt) Publishing Status (imgtool) Build Status (Travis CI) Apache 2.0

This is MCUboot version 1.8.0

MCUboot is a secure bootloader for 32-bits microcontrollers. It defines a common infrastructure for the bootloader and the system flash layout on microcontroller systems, and provides a secure bootloader that enables easy software upgrade.

MCUboot is not dependent on any specific operating system and hardware and relies on hardware porting layers from the operating system it works with. Currently, MCUboot works with the following operating systems and SoCs:

RIOT is supported only as a boot target. We will accept any new port contributed by the community once it is good enough.

MCUboot How-tos

See the following pages for instructions on using MCUboot with different operating systems and SoCs:

There are also instructions for the Simulator.

Roadmap

The issues being planned and worked on are tracked using GitHub issues. To give your input, visit MCUboot GitHub Issues.

Source files

You can find additional documentation on the bootloader in the source files. For more information, use the following links:

  • boot/bootutil - The core of the bootloader itself.
  • boot/boot_serial - Support for serial upgrade within the bootloader itself.
  • boot/zephyr - Port of the bootloader to Zephyr.
  • boot/mynewt - Bootloader application for Apache Mynewt.
  • boot/nuttx - Bootloader application and port of MCUboot interfaces for Apache NuttX.
  • boot/mbed - Port of the bootloader to Mbed OS.
  • boot/espressif - Bootloader application and MCUboot port for Espressif SoCs.
  • boot/cypress - Bootloader application and MCUboot port for Cypress/Infineon SoCs.
  • imgtool - A tool to securely sign firmware images for booting by MCUboot.
  • sim - A bootloader simulator for testing and regression.

Joining the project

Developers are welcome!

Use the following links to join or see more about the project: