I am experiencing an issue with the ROM API for nor Flash programming on the IMXRT1061. My application runs entirely in OCRAM, but I have SPIFlash for booting and storing configuration data. For convenience, I have divided my SPIFlash into three sections with 64KiB sector boundaries: the boot loader (at location 0, obviously), the Application, and the Configuration data. The boot loader is 2 sectors, the Application is 4 sectors, the config data is 11 sectors. I can reprogram these sectors via USB-HS link which works most of the time. The problem is that when I am programming the large section, it may hang during one of the API Erase commands, after some number of sectors programmed. I found that if I "slow down" the sequence, by putting print statements to the console (serial UART, 115.2K baud), then the hang is avoided, although perhaps not eliminated. The watchdog does not reboot the CPU in this case, likely because the Erase command is retriggering it. Has anyone else encountered this issue, and is there a definitive way to ensure that it will not happen?
解決済! 解決策の投稿を見る。
Hi @MultipleMonomials ,
This just applies for HAB API, and OCRAM2 is also part of OCRAM, so the description is correct.
Hi @briancarrigan ,
I confirmed with the expert, the ROM Erase API doesn't trigger any watch dog at all, not sure if your application had enabled it so your solution fixed this issue, please kindly clarify.
Have a great day,
Kan
-------------------------------------------------------------------------------
Note:
- If this post answers your question, please click the "Mark Correct" button. Thank you!
- We are following threads for 7 weeks after the last post, later replies are ignored
Please open a new thread and refer to the closed one, if you have a related question at a later point in time.
-------------------------------------------------------------------------------
Have a great day,
Kan
-------------------------------------------------------------------------------
Note:
- If this post answers your question, please click the "Mark Correct" button. Thank you!
- We are following threads for 7 weeks after the last post, later replies are ignored
Please open a new thread and refer to the closed one, if you have a related question at a later point in time.
-------------------------------------------------------------------------------
It turns out that if I do a watchdog service immediately prior to calling the API Erase function, then it seems to complete without hanging. This is not a definitive solution, since testing small sample sizes on a prototype bench does not prove the general case.
Hi @briancarrigan ,
Have you checked if the following OCRAM space was not occupied by your application?
You may refer to the chapter 9 system boot in the RM for more details.
Hope that helps,
Have a great day,
Kan
-------------------------------------------------------------------------------
Note:
- If this post answers your question, please click the "Mark Correct" button. Thank you!
- We are following threads for 7 weeks after the last post, later replies are ignored
Please open a new thread and refer to the closed one, if you have a related question at a later point in time.
-------------------------------------------------------------------------------
Hi! I saw this post and it gave me some concerns, as we are using the ROM API in our product and have not reserved this RAM region. Two questions for clarification:
Thank you, hope this makes sense!
Hi @MultipleMonomials ,
This just applies for HAB API, and OCRAM2 is also part of OCRAM, so the description is correct.
Hi @briancarrigan ,
I confirmed with the expert, the ROM Erase API doesn't trigger any watch dog at all, not sure if your application had enabled it so your solution fixed this issue, please kindly clarify.
Have a great day,
Kan
-------------------------------------------------------------------------------
Note:
- If this post answers your question, please click the "Mark Correct" button. Thank you!
- We are following threads for 7 weeks after the last post, later replies are ignored
Please open a new thread and refer to the closed one, if you have a related question at a later point in time.
-------------------------------------------------------------------------------
Have a great day,
Kan
-------------------------------------------------------------------------------
Note:
- If this post answers your question, please click the "Mark Correct" button. Thank you!
- We are following threads for 7 weeks after the last post, later replies are ignored
Please open a new thread and refer to the closed one, if you have a related question at a later point in time.
-------------------------------------------------------------------------------
For informational purposes, I determine that my application and data reside entirely in OCRAM- FlexRAM, of which I use about 25%. I do not use the OCRAM2 at all. I have also enabled the watchdog timer, but for some reason the API Erase function timeout did not cause a reset of the processor; it just hung. I tested the WDOG function by coding an infiniloop, and it reset the processor as expected. This is still mysterious, but the project can continue with the fix to trigger the WDOG immediately prior to the API Flash Erase call. Perhaps it is also necessary to trigger immediately prior to other API calls as well, and for robustness, I will be doing this.
Hi @briancarrigan ,
Thanks for the information! Since you have also enabled the watchdog timer, the reason why it hang the MCU during the API Erase process might be due to the flash has been erased partially at that moment when the watchdog timeout, the MCU does reset by watchdog but it could not locate the image as the beginning of the whole flash should have already be erased before the watchdog timeout event, so it comes to serial download mode finally , and looks like "hang" in your case.
Hope that make senses,
Have a great day,
Kan
-------------------------------------------------------------------------------
Note:
- If this post answers your question, please click the "Mark Correct" button. Thank you!
- We are following threads for 7 weeks after the last post, later replies are ignored
Please open a new thread and refer to the closed one, if you have a related question at a later point in time.
-------------------------------------------------------------------------------