2024-12-13 07:39 AM - edited 2024-12-13 08:22 AM
I have a STM32H7 and I use USB MSC. I do not use an RTOS.
If I plug in my USB thumb drive I append a counter to a file and close it.
This works.
If I remove the thumb drive very quickly at precisely the wrong moment I get a hardfault.
if Appli_state == APPLICATION_READY I set a flag and call f_open in the main loop. But then the USB drive is already gone, but there is no NULL pointer check.
We call the USBH_Process() and USBH_MSC_AppProcess() in a timer interrupt and have modified it to have non-blocking delays. I wonder if this could be the cause or if there is an actual bug in the driver that misses to check the USB drive is not available.
The following modification made to USBH_MSC_RdWrProcess() fixes the problem of hardfaults.
static USBH_StatusTypeDef USBH_MSC_RdWrProcess(USBH_HandleTypeDef *phost, uint8_t lun)
{
USBH_StatusTypeDef error = USBH_BUSY;
USBH_StatusTypeDef scsi_status = USBH_BUSY;
if (phost->pActiveClass == NULL)
{
error = USBH_FAIL;
return error;
}
MSC_HandleTypeDef *MSC_Handle = (MSC_HandleTypeDef *) phost->pActiveClass->pData;
Edit: I found an old thread that mentions the same problem:
Another modification I made is to call an idle handler in busy waiting loops. This is not the cause of the issue, but it does address the issue mentioned by @NAgha.1 in that topic:
while (USBH_MSC_RdWrProcess(phost, lun) == USBH_BUSY)
{
if (((phost->Timer - timeout) > (10000U * length)) || (phost->device.PortEnabled == 0U))
{
return USBH_FAIL;
}
// start of modification
else
{
// prevent blocking other processes from main context
usbIdleLoop();
}
// end of modification
}
main:
void usbIdleLoop()
{
//does non-usb things
}
int main(){
...
while(1)
{
usbIdleLoop();
usbApplication();//does fat-fs things with usb and calls usbIdleLoop in loops that were previously busy waiting to prevent blocking
}
}
2024-12-14 05:49 AM
Thanks for reporting the issue!
Would you share an example project to reproduce on my end?
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.
2024-12-16 01:12 AM - edited 2024-12-16 01:13 AM
That's going to be difficult, because I use a custom board. I do have a development board (STM32H735G-DK), but this one doesn't have a USB-A receptacle. I can strip the code I have right now, but pins might be different. Is that ok?
Also the problem is hard to reproduce since it requires disconnecting the thumb drive at exactly the right moment.
Maybe I can modify the code so it does more reading and writing to increase the odds of a crash.
2025-01-06 02:40 AM
Would you please share your project I will check pinout and adapt your code to work with it on STM32H735G-DK board. This will greatly assist our team in diagnosing and addressing the problem more efficiently.
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.
2025-01-06 07:39 AM
I stripped the project and attached it.
I can compile it with STM32CubeIDE 1.17.0 and load it in my board.
To trigger the error it requires you to unplug it at exactly the right time. Somehow when I filmed it it worked the first attempt. Normally it takes 5-10 attempts.