2024-12-12 02:54 AM
In the case of a root of trust with two boot stages (STiRoT + OEMuRoT), I'm looking to update the OEMuRoT or the firmware. From STM32CubeProgrammer I can do this via the bootloader. However, when I use the ST-LINK probe and try to program the new firmware (the encrypted and signed hex that worked in the case of the bootloader) I get the following error: ‘failed to download firmware’.
I am in PRODUCT_STATE = OPEN
the logs indicate that the flash cannot be programmed
Is it possible to update encrypted and signed firmware using the ST-LINK probe?
2024-12-12 03:36 AM
Hello @axel_lagrange ,
I assume that you have Trustzone enabled.
just to make it clear, what you are trying to do is not the described path for OEMuROT solution. I recommend that you check the dedicated wiki article:
How to start with STiRoT_OEMuRoT on STM32H573 - stm32mcu
in the meanwhile, if your use case is not as the intended Wiki description let me know.
Regards
2024-12-12 05:05 AM
Yes TrustZone is enabled
Regardless of the boot stage chosen, my question is why can't I download code in the download area with the ST-LINK probe?
If you look at the logs (st-link.txt) with the ST-LINK probe, you can see that you can't even delete the Flash sectors in the download area.
Is it possible to make the download area sectors accessible to the ST-LINK probe?
Regards
2024-12-12 06:24 AM
Hello @axel_lagrange ,
Can you share the log of bootloader operation which was done successfully as the address you are using is not the default address of flash when TZ enabled. See Table 24 of R0481:
Could you specify the version of CubeProgrammer you are using as well.
Regards
2024-12-30 06:36 AM
Hello @axel_lagrange
any updates on this issue?
Regards
2025-01-06 03:05 AM
Hello
In this wiki (https://wiki.st.com/stm32mcu/wiki/Security:How_to_start_with_STiRoT_on_STM32H573) it is written:
There are different solutions to upload the new code image for this tutorial example. (The code is installed by the STiRoT at next hardware reset)
By manual flashing I understsand using the ST-Link probe. Is this true?
In my case, when the erasing/programming phase is launched from CubeProgrammer connected to the board with the ST-link, the processor is in non secure state and the area where sector 0x080C4000 is located outside the secure watermark area defined (SECWM1_STRT=0x0 and SECWM1_END=0xe).
Trustzone is enabled, PRODUCT STATE = OPEN
As requested, here is the log when access to this sector is OK from the bootloader
cubeprogrammer was installed from en.stm32cubeprg-lin-v2-17-0.zip
2025-01-06 07:01 AM
Hello @axel_lagrange ,
I'm able to download the nonsecure code using stlink as you are trying to do in the same address here is a screenshot:
Maybe share the Hex file that you are trying to download and make sure that all other OB are in their default state.
Regards
2025-01-08 12:30 AM
OK, I'll do some research on my own to find out what's going wrong in my case.
thanks