FatFs
FatFS是一个为小型嵌入式系统设计的通用FAT(File Allocation Table)文件系统模块。FatFs 的编写遵循ANSI C,并且完全与磁盘I/O层分开。因此,它独立(不依赖)于硬件架构。它可以被嵌入到低成本的微控制器中,如AVR, 8051, PIC, ARM, Z80, 68K 等等,而不需要做任何修改。
特点
•Windows兼容的FAT文件系统•不依赖于平台,易于移植•代码和工作区占用空间非常小•多种配置选项:
多卷(物理驱动器和分区)
多ANSI/OEM代码页,包括DBCS
在ANSI/OEM或Unicode中长文件名的支持
RTOS的支持
多扇区大小的支持
只读,最少API,I/O缓冲区等等
应用程序接口
FatFs 模块为应用程序提供了下列函数,这些函数描述了FatFs能对FAT卷执行哪些操作。f_mount
在FatFs模块上注册/注销一个工作区(文件系统对象)
FRESULT f_mount (
BYTE  Drive,            /* 逻辑驱动器号*/
truncate删除数据FATFS*  FileSystemObject /* 工作区指针*/
);
参数
Drive注册/注销工作区的逻辑驱动器号(0-9)。
FileSystemObject工作区(文件系统对象)指针。
返回值
FR_OK (0)函数成功。
FR_INVALID_DRIVE驱动器号无效
描述
f_mount函数在FatFs模块上注册/注销一个工作区。在使用任何其他文件函数之前,必须使用该函数为每
个卷注册一个工作区。要注销一个工作区,只要指定FileSystemObject为NULL即可,然后该工作区可以被丢弃。
该函数只初始化给定的工作区,以及将该工作区的地址注册到内部表中,不访问磁盘I/O层。卷装入过程是在f_mount函数后或存储介质改变后的第一次文件访问时完成的。
f_open
创建/打开一个用于访问文件的文件对象
FRESULT f_open (
FIL* FileObject,        /* 空白文件对象结构指针*/
const XCHAR* FileName,  /* 文件名指针*/
BYTE ModeFlags          /* 模式标志*/
);
参数
FileObject将被创建的文件对象结构的指针。
FileName
NULL结尾的字符串指针,该字符串指定了将被创建或打开的文件名。
ModeFlags指定文件的访问类型和打开方法。它是由下列标志的一个组合指定的。
模式描述
FA_READ 指定读访问对象。可以从文件中读取数据。与FA_WRITE结合可以进行读写访问。
FA_WRITE 指定写访问对象。可以向文件中写入数据。与FA_READ结合可以进行读写访问。
FA_OPEN_EXISTING 打开文件。如果文件不存在,则打开失败。(默认)
FA_OPEN_ALWAYS 如果文件存在,则打开;否则,创建一个新文件。
FA_CREATE_NEW 创建一个新文件。如果文件已存在,则创建失败。
FA_CREATE_ALWAYS 创建一个新文件。如果文件已存在,则它将被截断并覆盖。
注意:当_FS_READONLY == 1 时,模式标志FA_WRITE, FA_CREATE_ALWAYS, FA_CREATE_NEW, FA_OPEN_ALWAYS 是无效的。返回值
FR_OK (0)函数成功,该文件对象有效。
FR_NO_FILE不到该文件。
FR_NO_PATH不到该路径。
FR_INVALID_NAME文件名无效。
FR_INVALID_DRIVE驱动器号无效。
FR_EXIST该文件已存在。
FR_DENIED由于下列原因,所需的访问被拒绝:
•以写模式打开一个只读文件。
•由于存在一个同名的只读文件或目录,而导致文件无法被创建。
•由于目录表或磁盘已满,而导致文件无法被创建。FR_NOT_READY由于驱动器中没有存储介质或任何其他原因,而导致磁盘驱动器无法工作。
FR_WRITE_PROTECTED在存储介质被写保护的情况下,以写模式打开或创建文件对象。
FR_DISK_ERR由于底层磁盘I/O接口函数中的一个错误,而导致该函数失败。
FR_INT_ERR由于一个错误的FAT结构或一个内部错误,而导致该函数失败。
FR_NOT_ENABLED逻辑驱动器没有工作区。
FR_NO_FILESYSTEM磁盘上没有有效地FAT卷。
描述
如果函数成功,则创建一个文件对象。该文件对象被后续的读/写函数用来访问文件。如果想要关闭一个打开的文件对象,则使用f_close函数。如果不关闭修改后的文件,那么文件可能会崩溃。
在使用任何文件函数之前,必须使用f_mount函数为驱动器注册一个工作区。只有这样,其他文件函数才能正常工作。
例子(文件拷贝)
void main (void)
{
FATFS fs[2];        /* 逻辑驱动器的工作区(文件系统对象) */
FIL fsrc, fdst;      /* 文件对象*/
BYTE buffer[4096];  /* 文件拷贝缓冲区*/
FRESULT res;        /* FatFs 函数公共结果代码*/    UINT br, bw;        /* 文件读/写字节计数*/
/* 为逻辑驱动器注册工作区*/
f_mount(0, &fs[0]);
f_mount(1, &fs[1]);
/* 打开驱动器1 上的源文件*/
res = f_open(&fsrc, "1:srcfile.dat", FA_OPEN_EXISTING | FA_READ);
if (res) die(res);
/* 在驱动器0 上创建目标文件*/    res = f_open(&fdst, "0:dstfile.dat", FA_CREATE_ALWAYS | FA_WRITE);
if (res) die(res);
/* 拷贝源文件到目标文件*/
for (;;) {
res = f_read(&fsrc, buffer, sizeof(buffer), &br);
if (res || br == 0) break; /* 文件结束错误*/
res = f_write(&fdst, buffer, br, &bw);
if (res || bw < br) break; /* 磁盘满错误*/
}
/* 关闭打开的文件*/
f_close(&fsrc);
f_close(&fdst);
/* 注销工作区(在废弃前) */
f_mount(0, NULL);
f_mount(1, NULL);
}
f_close
关闭一个打开的文件
FRESULT f_close (
FIL* FileObject          /* 文件对象结构的指针*/
)
;
参数
FileObject指向将被关闭的已打开的文件对象结构的指针。
返回值
FR_OK (0)文件对象已被成功关闭。>FR_DISK_ERR由于底层磁盘I/O函数中的错误,而导致该函数失败。FR_INT_ERR由于一个错误的FAT结构或一个内部错误,而导致该函数失败。
FR_NOT_READY由于驱动器中没有存储介质或任何其他原因,而导致磁盘驱动器无法工作。
FR_INVALID_OBJECT文件对象无效。
描述
f_close函数关闭一个打开的文件对象。无论向文件写入任何数据,文件的缓存信息都将被写回到磁盘。该函数成功后,文件对象不再有效,并且可以被丢弃。如果文件对象是在只读模式下打开的,不需要使用该函数,也能被丢弃。
f_read 从一个文件读取数据
FRESULT f_read (
FIL* FileObject,        /* 文件对象结构的指针*/
void* Buffer,            /* 存储读取数据的缓冲区的指针*/
UINT ByteToRead,        /* 要读取的字节数*/
UINT* ByteRead          /* 返回已读取字节数变量的指针*/
);
FileObject指向将被读取的已打开的文件对象结构的指针。
Buffer指向存储读取数据的缓冲区的指针。
ByteToRead要读取的字节数,UINT范围内。
ByteRead指向返回已读取字节数的UINT变量的指针。在调用该函数后,无论结果如何,数值都是有效的。返回值
FR_OK (0)函数成功。
FR_DENIED由于文件是以非读模式打开的,而导致该函数被拒绝。
FR_DISK_ERR由于底层磁盘I/O函数中的错误,而导致该函数失败。FR_INT_ERR由于一个错误的FAT结构或一个内部错误,而导致该函数失败。
FR_NOT_READY由于驱动器中没有存储介质或任何其他原因,而导致磁盘驱动器无法工作。
FR_INVALID_OBJECT文件对象无效。
描述
文件对象中的读/写指针以已读取字节数增加。该函数成功后,应该检查*ByteRead 来检测文件是否结束。在读操作过程中,一旦*ByteRead < ByteToRead ,则读/写指针到达了文件结束位置。
f_write 写入数据到一个文件
FRESULT f_write (
FIL* FileObject,        /* 文件对象结构的指针*/
const void* Buffer,      /* 存储写入数据的缓冲区的指针*/
UINT ByteToWrite,        /* 要写入的字节数*/
UINT* ByteWritten        /* 返回已写入字节数变量的指针*/
);
参数
FileObject指向将被写入的已打开的文件对象结构的指针。
Buffer指向存储写入数据的缓冲区的指针。
ByteToRead要写入的字节数,UINT范围内。
ByteRead指向返回已写入字节数的UINT变量的指针。在调用该函数后,无论结果如何,数值都是有效的。
返回值
FR_OK (0)函数成功。
FR_DENIED由于文件是以非写模式打开的,而导致该函数被拒绝。
FR_DISK_ERR由于底层磁盘I/O函数中的错误,而导致该函数失败。FR_INT_ERR由于一个错误的FAT结构或一个内部错误,而导致该函数失败。
FR_NOT_READY由于驱动器中没有存储介质或任何其他原因,而导致磁盘驱动器无法工作。
FR_INVALID_OBJECT文件对象无效。
描述
文件对象中的读/写指针以已写入字节数增加。该函数成功后,应该检查*ByteWritten 来检测磁盘是否已满。在写操作过程中,一旦*ByteWritten < *ByteToWritten ,则意味着该卷已满。
f_lseek
移动一个打开的文件对象的文件读/写指针。也可以被用来扩展文件大小(簇预分配)。
FRESULT f_lseek (
FIL* FileObject,        /* 文件对象结构指针*/
DWORD Offset            /* 文件字节偏移*/
);
参数
FileObject打开的文件对象的指针
Offset相对于文件起始处的字节数
FR_OK (0)函数成功。
FR_DISK_ERR由于底层磁盘I/O函数中的错误,而导致该函数失败。
FR_INT_ERR由于一个错误的FAT结构或一个内部错误,而导致该函数失败。
FR_NOT_READY由于驱动器中没有存储介质或任何其他原因,而导致磁盘驱动器无法工作。
FR_INVALID_OBJECT文件对象无效。
描述
f_lseek函数当FS_MINIMIZE <= 2时可用。
offset只能被指定为相对于文件起始处的字节数。当在写模式下指定了一个超过文件大小的offset时,文件的大小将被扩展,并且该扩展的区域中的数据是未定义的。这适用于为快速写操作迅速地创建一个大的文件。f_lseek函数成功后,为了确保读/写指针已被正确地移动,必须检查文件对象中的成员fptr。如果fptr不是所期望的值,则发生了下列情况之一。
•文件结束。指定的offset被钳在文件大小,因为文件已被以只读模式打开。
•磁盘满。卷上没有足够的空闲空间去扩展文件大小。
例子
/* 移动文件读/写指针到相对于文件起始处偏移为5000字节处*/
res = f_lseek(file, 5000);
/* 移动文件读/写指针到文件结束处,以便添加数据*/
res = f_lseek(file, file->fsize);
/
* 向前3000字节*/
res = f_lseek(file, file->fptr + 3000);
/* 向后(倒带)2000字节(注意溢出) */
res = f_lseek(file, file->fptr - 2000);
/* 簇预分配(为了防止在流写时缓冲区上溢*/
res = f_open(file, recfile, FA_CREATE_NEW | FA_WRITE); /* 创建一个文件*/      res = f_lseek(file, PRE_SIZE);        /* 预分配簇*/    if (res || file->fptr != PRE_SIZE) ... /* 检查文件大小是否已被正确扩展*/
res = f_lseek(file, DATA_START);      /* 没有簇分配延迟地记录数据流*/
...
res = f_truncate(file);                /* 截断未使用的区域*/
res = f_lseek(file, 0);                /* 移动到文件起始处*/
...
res = f_close(file);
f_truncate
截断文件大小
FRESULT f_truncate (
FIL* FileObject          /* 文件对象结构指针*/ );
参数
FileObject待截断的打开的文件对象的指针。
返回值
FR_OK (0函数成功。
FR_DENIED由于文件是以非写模式打开的,而导致该函数被拒绝。
FR_DISK_ERR由于底层磁盘I/O函数中的错误,而导致该函数失败。FR_INT_ERR由于一个错误的FAT结构或一个内部错误,而导致该函数失败。
FR_NOT_READY由于驱动器中没有存储介质或任何其他原因,而导致磁盘驱动器无法工作。
FR_INVALID_OBJECT文件对象无效。
描述
f_truncate函数当_FS_READONLY == 0 并且_FS_MINIMIZE == 0时可用。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。