cancel
Showing results for 
Search instead for 
Did you mean: 

STM32WB55 - Stuck waiting for FLASH_FLAG_CFGBSY during OTA update & running FreeRTOS

chris24
Associate II

Hi Everyone,

I'm using the P-NUCLEO-WB55 board and seeing an an issue when attempting an OTA firmware using the STBLESensorClassic mobile app running on iOS device. Execution is blocked waiting for the "FLASH_FLAG_CFGBSY"  to clear in FLASH_WaitForLastOperation() in stm32wbxx_hal_flash.c. Please see screenshot below of call stack and location. 

 

Setup

CubeIDE v1.14.1

STM32Cube_FW_WB_V1.21.0

ST BLE Sensor Classic 4.20.1

 

Background

If I use the out of the box OTA example "BLE_Ota" on the P-NUCLEO-WB55 board the OTA update works fine.  However, this example uses the sequencer which is not representative of our end application. We are using FreeRTOS in our end application. In an effort to create an application that is somewhat representative of our end application I've combined/merged the "BLE_Ota" & "BLE_HeartRateFreeRTOS" examples into a single project. With this merged project running on the P-NUCLEO-WB55 board the issue is reproducible. I've attached the project to this thread. The BLE_HeartRateFreeRTOS uses timer 17 for the FreeRTOS time source unlike the BLE_Ota/sequencer example which uses systick. 

 

There are some old posts about similar issues like this one https://forums.freertos.org/t/stm32wb55-flash-sr-cfgbsy-never-clears-when-using-freertos-and-tim1/12300/15 that refer to interrupts firing before the timer instance is initialized. Their solution was to add a NULL guard around the  HAL_TIM_IRQHandler(). I've tried this but the issue persists.

 

I appreciate any input you can provide.

 

Thanks,

 

chris24_0-1735767129032.png

 

7 REPLIES 7
STTwo-32
ST Employee

Hello @chris24 and welcome to the ST Community.

I suggest you to ensure that your project migration was fine. You can use the attached guide for help.

Also, please use the last STM32CubeIDE V1.17.0 and try using other mobile app such as the last version of the ST BLE Toolbox or the https://github.com/stm32-hotspot/STM32WB-Web-Bluetooth-App-Interfaces

Best Regards.

STTwo-32

To give better visibility on the answered topics, please click on Accept as Solution on the reply which solved your issue or answered your question.

Hi @STTwo-32 ,

 

Thank you for the quick reply.

 

Yes I am familiar with the document you shared and confirmed the project migration follows the instructions in that document. However, the issue still persists. Also, the issue exists with latest version of BLE Toolbox.

 

Thanks,

Chris

Hi @STTwo-32 ,

 

I marked this post as a solution as resolved by accident. Can you please reopen it as its not resolved?

 

Is there any update on this? This issue is reproducible using the P-NUCLEO-WB55 board with the BLE_Ota example running FREERTOS instead of the sequencer as per instructions in Seq_to_FreeRTOS_over_cmsis_os2.docx.

 

Thanks,

Chris 

OliM
Senior

Unexpected FLASH_FLAG_CFGBSY is with a 99,9% chance a null pointer error somewhere in your code. Multiple colleagues have managed to get this on STM32WB. As soon as you try to write to such a pointer, the controller actually tries to write to flash (since zero is the start of flash if you have boot from flash active) and fails because it wasn't unlocked -> FLASH_FLAG_CFGBSY is set until the next reset.

(this is WBxx specific behavior, e.g. on U5 it is a secure exception, and L0 just ignores it)

Hi @OliM ,

 

Thanks for the response. That explanation makes sense however, I put a watchpoint/data breakpoint at address 0x0 unlocked the flash and repeated the test but the breakpoint never gets hit. Am I missing something? 

chris24_0-1736280052426.png

 

Since this issue is reproducible with the BLE_Ota example + FreeRTOS port (as per Seq_to_FreeRTOS_over_cmsis_os2.docx) perhaps your colleagues have encountered this specific issue?

 

Thanks,

Chris

Hi @OliM,

 

Is there any update on this? It is reproducible using the two ST examples.

 

Thanks,

Chris

@chris24 we do not use modified examples but write our own code from scratch, only using those examples as reference for some ideas. This is were I have seen your issue in combination with nullpointers.
So unfortunately no more updates for you on this topic.