How to recover from FR_DISK_ERR during f_write in STM32
Hi all,
I am now using SYM32F103RE to read data from codec via I2S & write into SD card. I use the HAL library in STM32CubeMX w/ Chen's fatfs & I2S DMA. Unlucky, f_write will sometime return FR_DISK_ERR. According to fatfs, I can only f_close the file in this case. But it only return FR_INVAILD_OBJECT no matter what I do. If I add a 1ms polling delay (HAL_Delay(1)) between each f_write, it works fine. So is there any way to avoid or recover from the problem?
Here is my code:
FRESULT u8_sd_fat_status = FR_DISK_ERR; // 0 = SD card FAT file system is ok, otherwise 1.
uint16_t u32_array_codec_in[512];
f_mount(&SDFatFS, (TCHAR const*)SDPath, 0);
f_unlink("record.wav");
u8_sd_fat_status = f_open(&SDFile, "record.wav", FA_CREATE_NEW | FA_READ | FA_WRITE);
for(unsigned char i = 0; i < 10 && u8_sd_fat_status != FR_OK; i++)
{
HAL_Delay(100);
u8_sd_fat_status = f_open(&SDFile, "record.wav", FA_CREATE_NEW | FA_READ | FA_WRITE);
}
if(u8_sd_fat_status == FR_OK)
{
uint16_t u16_array_mic_adc[512];
uint32_t u32_rec_file_ptr = 0;
uint32_t u32_i2s_ptr = 22;
f_sync(&SDFile);
HAL_I2S_Receive_DMA(&hi2s2, u32_array_codec_in, sizeof(u32_array_codec_in)/sizeof(uint16_t));
while(u32_rec_file_ptr < 512000)
{
UINT u32_i = 0;
u32_i2s_ptr += CodecRead(u16_array_mic_adc, sizeof(u16_array_mic_adc)/sizeof(uint16_t) - u32_i2s_ptr);
if(u32_i2s_ptr >= sizeof(u16_array_mic_adc)/sizeof(uint16_t))
{
u8_sd_fat_status = f_write (&SDFile, u16_array_mic_adc, sizeof(u16_array_mic_adc), &u32_i);
if(u8_sd_fat_status != FR_OK)
{
u8_sd_fat_status = f_close(&SDFile);
if(u8_sd_fat_status != FR_OK)
__asm("nop");
u8_sd_fat_status = f_open(&SDFile, "record.wav", FA_OPEN_ALWAYS | FA_READ | FA_WRITE);
if(u8_sd_fat_status != FR_OK)
__asm("nop");
u8_sd_fat_status = f_lseek (&SDFile, u32_rec_file_ptr);
if(u8_sd_fat_status != FR_OK)
__asm("nop");
break;
}
f_sync(&SDFile);
}
u32_rec_file_ptr += u32_i;
u32_i2s_ptr = 0;
}
}
f_close(&SDFile);
}Thanks,
Sin
