
f_mkfs的介绍
f_mkfs是FatFs库中的一个函数,用于在指定的磁盘上执行格式化操作。它可以用于创建新的文件系统或重新格式化已有的文件系统。
函数原型如下:
FRESULT f_mkfs (
    const TCHAR* path,  // 磁盘路径
    BYTE opt,           // 格式化选项
    DWORD au,           // 簇大小(字节)
    void* work,         // 工作区缓冲区
    UINT len            // 工作区缓冲区大小(字节)
);
参数说明:
- path:磁盘路径,例如:“0:” 表示物理磁盘0,“1:” 表示物理磁盘1,“2:” 表示逻辑磁盘2等。
- opt:格式化选项,可以是以下之一:- FM_FAT:格式化为FAT12/FAT16文件系统。
- FM_FAT32:格式化为FAT32文件系统。
- FM_EXFAT:格式化为exFAT文件系统。
 
- au:簇大小,以字节为单位。对于FAT12/FAT16,簇大小应为512的倍数,并且在4KB到32KB之间。对于FAT32和exFAT,簇大小可以在512字节到32MB之间选择,但必须是2的幂。
- work:工作区缓冲区,用于执行格式化操作时的临时存储。缓冲区的大小应为- len字节。
- len:工作区缓冲区的大小,以字节为单位。
函数返回值为FRESULT类型,表示操作的结果。常见的返回值有:
- FR_OK:操作成功。
- FR_DISK_ERR:磁盘错误,无法访问磁盘。
- FR_INT_ERR:内部错误,发生了意外的错误。
- FR_INVALID_DRIVE:无效的磁盘号。
- FR_NOT_ENABLED:文件系统不可用。
- FR_NO_FILESYSTEM:指定的磁盘上没有文件系统。
使用f_mkfs函数进行格式化时,需要注意以下几点:
- 格式化操作将擦除磁盘上的所有数据,请确保提前备份重要的数据。
- 格式化选项opt应选择对应的文件系统类型。
- 簇大小au的选择应符合文件系统的要求,并且要在合法的范围内。
- 工作区缓冲区work应提供足够的空间来执行格式化操作,通常建议将其大小设置为磁盘的扇区大小。
- 格式化操作可能需要一些时间,具体时间取决于磁盘的大小和性能。
使用示例
f_mkfs是FatFs库中的一个函数,用于在指定的磁盘上执行格式化操作。它可以用于创建新的文件系统或重新格式化已有的文件系统。
函数原型如下:
FRESULT f_mkfs (
    const TCHAR* path,  // 磁盘路径
    BYTE opt,           // 格式化选项
    DWORD au,           // 簇大小(字节)
    void* work,         // 工作区缓冲区
    UINT len            // 工作区缓冲区大小(字节)
);
参数说明:
- path:磁盘路径,例如:“0:” 表示物理磁盘0,“1:” 表示物理磁盘1,“2:” 表示逻辑磁盘2等。
- opt:格式化选项,可以是以下之一:- FM_FAT:格式化为FAT12/FAT16文件系统。
- FM_FAT32:格式化为FAT32文件系统。
- FM_EXFAT:格式化为exFAT文件系统。
 
- au:簇大小,以字节为单位。对于FAT12/FAT16,簇大小应为512的倍数,并且在4KB到32KB之间。对于FAT32和exFAT,簇大小可以在512字节到32MB之间选择,但必须是2的幂。
- work:工作区缓冲区,用于执行格式化操作时的临时存储。缓冲区的大小应为- len字节。
- len:工作区缓冲区的大小,以字节为单位。
函数返回值为FRESULT类型,表示操作的结果。常见的返回值有:
- FR_OK:操作成功。
- FR_DISK_ERR:磁盘错误,无法访问磁盘。
- FR_INT_ERR:内部错误,发生了意外的错误。
- FR_INVALID_DRIVE:无效的磁盘号。
- FR_NOT_ENABLED:文件系统不可用。
- FR_NO_FILESYSTEM:指定的磁盘上没有文件系统。
使用f_mkfs函数进行格式化时,需要注意以下几点:
- 格式化操作将擦除磁盘上的所有数据,请确保提前备份重要的数据。
- 格式化选项opt应选择对应的文件系统类型。
- 簇大小au的选择应符合文件系统的要求,并且要在合法的范围内。
- 工作区缓冲区work应提供足够的空间来执行格式化操作,通常建议将其大小设置为磁盘的扇区大小。
- 格式化操作可能需要一些时间,具体时间取决于磁盘的大小和性能。




















