This example demonstrates the runtime Key Revision update to switch the Root of Trust to the programmed Backup Keys (BMPK/BMEK). The example reads the programmed Key Count and Key Revision and perform checks on the read values to validate if the Key Revision can be updated. If validated, the example enables the VPP and performs the Key Revision update procedure using the dual signed certificate. If the procedure is successful, it means the Root of Trust has been switched to the Backup Keys.
This example is supported only in HS-SE devices. This is a special example, and is booted by ROM. Because of this it is to be treated like a bootloader application. It makes use of Sciclient API calls to do this, there are wrapper functions provided in the example for this.
{SDK_PATH}/examples/otp/runtime_keyrev/am64x-evm/r5fss0-0_nortos/main.c
to update the KEY Revision.Parameter | Value |
---|---|
CPU + OS | r5fss0-0 nortos |
Toolchain | ti-arm-clang |
Board | am64x-evm |
Example folder | examples/otp/runtime_keyrev/ |
This examples requires a dual signed certificate to securely update the KEYREV. This dual signed certificate is a concatenation of BMPK signed certificate and SMPK signed certificate. The dual signed certificate can be generated with the following steps:
{SDK_PATH}/source/security/security_common/tools/boot/signing
.dual_cert_keyrev.bin
in the same directory. Replace the {SMPK_PATH}
and {BMPK_PATH}
with the actual paths to the SMPK and BMPK key respectively. python3 dualCertGen.py -s {SMPK_PATH} -b {BMPK_PATH}
dual_cert_keyrev.bin
into a header file dual_cert_keyrev.h
using the following command. cd `{SDK_PATH}/tools/bin2c` python3 bin2c.py dual_cert_keyrev.bin dual_cert_keyrev.h KEYREV_CHANGE_CERT
dual_cert_keyrev.h
file in the {SDK_PATH}/examples/otp/runtime_keyrev
folder with the file generated from dual signed certificate binary( file generated from above step).For example, cp dual_cert_keyrev.h {SDK_PATH}/examples/otp/runtime_keyrev/
DEVICE_TYPE
in {SDK_PATH}/devconfig/devconfig.mak
must be set to HS.This example is a bootloader application and so can be booted over any ROM supported boot media. For typical use cases, following are the steps to flash and boot the example from OSPI.
{SDK_PATH}/tools/boot
python uart_uniflash.py -p {COM_PORT} --cfg=../../examples/otp/runtime_keyrev/am64x-evm/r5fss0-0_nortos/default_runtime_keyrev_hs.cfg
Shown below is a sample output when the application is run:
If this example runs successfully, it means the KEYREV has been updated to 2
switching the Root of Trust to the backup keys (BMPK/BMEK). So, any existing images signed with SMPK and optionally encrypted with SMEK will fail to boot. The images needs to signed with the BMPK and optionally encrypted with the BMEK.
Backup Keys are named bmpk.pem
and bmek.key
, following are the steps to configure the signing of the images with Backup Keys:
bmek.key
to a hex string and save as bmek.txt
. CUST_MPK
and CUST_MEK
variables according to the device in {SDK_PATH}/devconfig/devconfig.mak
to refer to the Backup Keys. After the above changes, rebuild the libs and examples being used.