STM32MP153 NOR Flash boot issue with 32Mb
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2023-10-04 07:45 AM
Hi all,
Our product uses an STM32MP153 processor, booting its first and second stage bootloaders (TF-A and uboot respectively) from QUADSPI NOR FLASH. It boots Linux from eMMC. The NOR FLASH we have been using are either IS25LP016D-JNLE or AT25SF161B-SSHB-B which are both 16Mbit.
We are experimenting with using a larger 32Mb NOR FLASH due to customer request. We have built a batch of PCBAs with IS25LP032D-JNLE instead of the IS25LP016D.
However on 4 out of 12 boards, we see the below:
- Programming works ok, all stages are flashed onto the respective parts. stm32 cube programmer reports success
- When rebooted after programming, the MP1 still boots in DFU mode.
- Checked BOOT mode pins and they are set to 001, not 000, so its not the boot mode.
- NORFLASH chip has been written to and read back correctly and program has been verified, so there is no data corruption
- Re-ran stm32 cube programmer several times, and MP1 always reboots in DFU mode
- We suspect that there is a timing issue, the larger NORFLASH is not responding quick enough for the MP1. At this stage it is only ST's own BOOTROM that is running so we have no control over this
Please let us know if you have any solutions to this problem
Thanking you very much in advance
Solved! Go to Solution.
- Labels:
-
STM32MP15 Lines
Accepted Solutions
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2023-10-04 11:33 PM
HI @nk_narayanan ,
one usual pitfall is the Serial-NOR hold pin (usually IO3) not driven, so Serial-NOR does not output any data.
BootROM uses Serial-NOR in legacy SPI and does not drive IO2/IO3 (where uBoot or Linux use it in 4 bit mode).
This is highlighted in AN5031.
Hold pin pull-up could be done at board level (discrete 10K pull-up) or by enabling internal pullup by using one of OTP Word5-7 settings (please refer to https://wiki.st.com/stm32mpu/wiki/STM32MP15_OTP_mapping#AFmux_configuration)
Regards.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2023-10-04 08:40 AM
Not sure, at boot time the power can be unstable, Have you tried a PU , PD res or a cap on the boot pins to make sure there isn't a glitch ?
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2023-10-04 11:33 PM
HI @nk_narayanan ,
one usual pitfall is the Serial-NOR hold pin (usually IO3) not driven, so Serial-NOR does not output any data.
BootROM uses Serial-NOR in legacy SPI and does not drive IO2/IO3 (where uBoot or Linux use it in 4 bit mode).
This is highlighted in AN5031.
Hold pin pull-up could be done at board level (discrete 10K pull-up) or by enabling internal pullup by using one of OTP Word5-7 settings (please refer to https://wiki.st.com/stm32mpu/wiki/STM32MP15_OTP_mapping#AFmux_configuration)
Regards.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2023-10-06 03:04 AM
Thanks for your help, the 10K pullup resistor on IO3 (HOLD) pin worked. What was strange was that the 16Mbit NORFLASH from the same family worked fine without the 10K pullup on IO3.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2023-10-06 03:04 AM
Thanks, checked the boot pins and they seem stable
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Email to a Friend
- Report Inappropriate Content
‎2023-10-06 04:57 AM
An open input signal is per definition 'undefined', so with some chances it was seen as logic '1' by the memory, but at some point of time it might stop to work due to product aging and with varying conditions such as temperatures.
I would recommend to test the 16MBit board with a weak pull-down on IO3 (e.g. 100k-1M) to see if it still boot correctly. If not, it is strongly recommended to add the pull-up too (externally or by OTP).