2016-06-27 05:12 AM
Hi,
I want to write some data to a file on a usb stick. I have setup a new project with STM32CubeMX for the STM32F429I discovery board. My STM32CubeMX configuration:USB_OTG_HS: Internal FS Phy - Host OnlyUSB_HOST: Class for HS IP: Mass Storage Host ClassFATFS: USB DiskMy Code in the main-loop:while(1) {
/* USER CODE END WHILE */ MX_USB_HOST_Process(); /* USER CODE BEGIN 3 */ switch(Appli_state) { case APPLICATION_START: if (retUSBH != 0) { Error_Handler(); } fres = f_mount(&USBFatFs, (TCHAR const*)USBH_Path, 0); if(fres != FR_OK) { Error_Handler(); } fres = f_open(&MyFile, ''STM32.TXT'', FA_READ); if(fres != FR_OK) { Error_Handler(); } ... break; default: break; }When I try to open a file, f_open returns FR_DISK_ERR. Can anyone give me some advice, what might be wrong.1. ''FatFS: Link the USBH driver'' is successful => retUSBH = 02. Mount is successful => FR_OK3. Opening file fails => FR_DISK_ERRSo there might be some configuration issue for FATFS or with USB.2016-06-27 05:36 AM
Hi,
It might be useful to debug the lower layers. The fatFS library f_open should boil down to some lower layer function in HAL USB lib. For Chan fatFS lib the connection between the fatFS lib and HAL lib is in a file called diskio.c (or similar) if I recall correctly.When you get the FR_DISK_ERR I think that it is actually the lower layer HAL function that gives error and that the fatFS is just reacting to this.2016-06-27 07:17 AM
Okay, I have analyzed the lower levels.
The call stack is:f_open => find_volume => check_fs => move_window => disk_read => USBH_read => USBH_MSC_Read
Edit 1:And USBH_MSC_Read returns USBH_FAIL. In USBH_MSC_Read the pHost->gState and the MSC_Handle->unit[lun].state have the wrong values.The MSC_Handle unit is MSC_NOT_READY instead of MSC_IDLE. And the gState is HOST_DEV_ATTACHED instead of HOST_CLASS.Edit 2:So, the cause of the error is that the USB state does not change from HOST_USER_CONNECTION to HOST_USER_CLASS_ACTIVE. But I have no clue, what's the problem. :(2016-06-27 12:05 PM
Ok, sounds like a good debug session.
I would say that it could be something wrong with either the hardware itself, HAL library error or the USB stick not working together with the hardware. Do you have more than one USB stick to test with ?2016-06-27 11:34 PM
I have finally found the error(s). I think I made a second error.
First, the USB stick has to be mounted after the USBH_UserProcess changes its state HOST_USER_CLASS_ACTIVE. The generated code from STM32CubeMX has two ''confusing'' application states APPLICATION_START on HOST_USER_CONNECTION and APPLICATION_READY on HOST_USER_CLASS_ACTIVE. Any FatFs commands should be executed after APPLICATION_STATE_READY is reached.Second, after some hours of unsuccessful debugging, i have created a fresh project, where I mistakenly chose the wrong USB class.2016-06-28 07:07 AM
Great ! I personally discourage the use of auto generated stuff. Better to create the main bulk of the code yourself if possible. Usually pays off in the long run :)
2016-09-03 03:42 AM
Can you give the explanation about the way you solve your problem ? I faced the same problem like yours and I already stuck on it for couple of days
thank you2016-09-06 12:48 AM
I have described my solution in a previous post. Hope that helps.
''First, the USB stick has to be mounted after the USBH_UserProcess changes its state HOST_USER_CLASS_ACTIVE. The generated code from STM32CubeMX has two ''confusing'' application states APPLICATION_START on HOST_USER_CONNECTION and APPLICATION_READY on HOST_USER_CLASS_ACTIVE. Any FatFs commands should be executed after APPLICATION_STATE_READY is reached.''