首页 > 代码库 > FATFS 初学之 f_sync
FATFS 初学之 f_sync
1 /*-----------------------------------------------------------------------*/ 2 /* Synchronize the File Object */ 3 /*-----------------------------------------------------------------------*/ 4 5 FRESULT f_sync ( 6 FIL *fp /* Pointer to the file object */ 7 ) 8 { 9 FRESULT res;10 DWORD tim;11 BYTE *dir;12 13 14 res = validate(fp->fs, fp->id); /* Check validity of the object */15 if (res == FR_OK) {16 if (fp->flag & FA__WRITTEN) { /* Has the file been written? */17 #if !_FS_TINY /* Write-back dirty buffer */18 if (fp->flag & FA__DIRTY) {19 if (disk_write(fp->fs->drv, fp->buf, fp->dsect, 1) != RES_OK)20 LEAVE_FF(fp->fs, FR_DISK_ERR);21 fp->flag &= ~FA__DIRTY;22 }23 #endif24 /* Update the directory entry */25 res = move_window(fp->fs, fp->dir_sect);26 if (res == FR_OK) {27 dir = fp->dir_ptr;28 dir[DIR_Attr] |= AM_ARC; /* Set archive bit */29 ST_DWORD(dir+DIR_FileSize, fp->fsize); /* Update file size */30 ST_CLUST(dir, fp->sclust); /* Update start cluster */31 tim = get_fattime(); /* Update updated time */32 ST_DWORD(dir+DIR_WrtTime, tim);33 fp->flag &= ~FA__WRITTEN;34 fp->fs->wflag = 1;35 res = sync(fp->fs);36 }37 }38 }39 40 LEAVE_FF(fp->fs, res);41 }
函数功能:冲洗一个写文件的缓存信息
描述:
f_sync函数当 _FS_READONLY == 0时可用。
f_sync函数和 f_close函数执行同样的过程,但是文件仍处于打开状态,并且可以继续对文件执行读/写/移动
指针操作。这适用于以写模式长时间打开文件,比如数据记录器。定期的或f_write后立即执行f_sync可以将
由于突然断电或移去磁盘而导致数据丢失的风险最小化。在 f_close前立即执行 f_sync没有作用,因为在
f_close中执行了f_sync。换句话说,这两个函数的差异就是文件对象是不是无效的。
---------------------------------------- 我是分割线 ----------------------------------------
当对FAT文件系统的写操作由于默写意外而中断,如突然断电,不正确的磁盘移除或不可恢复的磁盘错误,FAT结构可以被毁坏。下面的图片显示了FatFs的临界段。
红色区域的中断会导致一个交叉链接,结果,正在修改的文件/目录可能会丢失。而黄色区域中断可能导致的效果在下面列出:
正在重写的文件数据被毁坏。
正在添加内容的文件回到初始状态。
丢失新建的文件。
一个新建或覆盖的文件保持长度为0。
因为丢失关联,磁盘的使用效率变坏。
在文件不是用写模式打开时,这些情况不会发生。为了最小化磁盘数据的丢失,临界段可以像图表5显示的那样最小化,通过最小化文件处于写模式打开的时间或者适当的使用f_sync函数。
---------------------------------------- 我是分割线 ----------------------------------------