Fatfs文件系统常用函数:f_mount、f_open、f_close、f_read、f_write、f_lseek、f_truncate、f_sync、f_opendir

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卷执行哪些操作。

1.f_mount:在FatFs模块上注册/注销一个工作区(文件系统对象)

2.f_open:创建/打开一个用于访问文件的文件对象

3.f_close:关闭一个打开的文件

4.f_read:从一个文件读取数据

5.f_write:写入数据到一个文件

6.f_lseek:移动一个打开的文件对象的文件读/写指针。也可以被用来扩展文件大小(簇预分配)。

7.f_truncate:截断文件大小

8.f_sync:冲洗一个写文件的缓存信息

9.f_opendir:打开一个目录

。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

1.f_mount:在FatFs模块上注册/注销一个工作区(文件系统对象)

原型:FRESULT f_mount ( BYTE Drive, FATFS* FileSystemObject );

参数:Drive:注册/注销工作区的逻辑驱动器号(0-9)。FileSystemObject工作区(文件系统对象)指针。

返回值:FR_OK (0):函数成功。FR_INVALID_DRIVE:驱动器号无效

描述:f_mount函数在FatFs模块上注册/注销一个工作区。在使用任何其他文件函数之前,必须使用该函数为每个卷注册一个工作区。要注销一个工作区,只要指定FileSystemObject为NULL即可,然后该工作区可以被丢弃。该函数只初始化给定的工作区,以及将该工作区的地址注册到内部表中,不访问磁盘I/O层。卷装入过程是在f_mount函数后或存储介质改变后的第一次文件访问时完成的。

2.f_open:创建/打开一个用于访问文件的文件对象

原型:FRESULT f_open ( FIL* FileObject, const XCHAR* FileName,BYTE ModeFlags );

参数:FileObject:将被创建的文件对象结构的指针。FileName:NULL结尾的字符串指针,该字符串指定了将被创建或打开的文件名。ModeFlags:指定文件的访问类型和打开方法。它是由下列标志的一个组合指定的。

注意:当 _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:由于下列原因,所需的访问被拒绝:

(1)以写模式打开一个只读文件。

(2)由于存在一个同名的只读文件或目录,而导致文件无法被创建。

(3)由于目录表或磁盘已满,而导致文件无法被创建。

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函数为驱动器注册一个工作区。只有这样,其他文件函数才能正常工作。

3. 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函数关闭一个打开的文件对象。无论向文件写入任何数据,文件的缓存信息都将被写回到磁盘。该函数成功后,文件对象不再有效,并且可以被丢弃。如果文件对象是在只读模式下打开的,不需要使用该函数,也能被丢弃。

4. f_read:从一个文件读取数据

原型:FRESULT f_read ( FIL* FileObject, void* Buffer, 首先要定义一个至少512的内存 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 ,则读/写指针到达了文件结束位置。

5. 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 ,则意味着该卷已满。

6. 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不是所期望的值,则发生了下列情况之一。

(1)文件结束。指定的offset被钳在文件大小,因为文件已被以只读模式打开。

(2)磁盘满。卷上没有足够的空闲空间去扩展文件大小。

用法:其实这个函数可以解决文件从头开始读的问题,如果你想打开一个文件,读取里面的内容,但又不想从头开始读,那么你可以使用这个函数来解决

7. 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时可用。f_truncate函数截断文件到当前的文件读/写指针。当文件读/写指针已经指向文件结束时,该函数不起作用。

8. f_sync:冲洗一个写文件的缓存信息

原型:FRESULT f_sync ( FIL* FileObject );

参数:FileObject:待冲洗的打开的文件对象的指针。

返回值:

FR_OK (0):函数成功。

FR_DISK_ERR:由于底层磁盘I/O函数中的错误,而导致该函数失败。

FR_INT_ERR:由于一个错误的FAT结构或一个内部错误,而导致该函数失败。

FR_NOT_READY:由于驱动器中没有存储介质或任何其他原因,而导致磁盘驱动器无法工作。

FR_INVALID_OBJECT 文件对象无效。

描述:f_sync函数当_FS_READONLY == 0时可用。f_sync函数和f_close函数执行同样的过程,但是文件仍处于打开状态,并且可以继续对文件执行读/写/移动指针操作。这适用于以写模式长时间打开文件,比如数据记录器。定期的或f_write后立即执行f_sync可以将由于突然断电或移去磁盘而导致数据丢失的风险最小化。在f_close前立即执行f_sync没有作用,因为在f_close中执行了f_sync。换句话说,这两个函数的差异就是文件对象是不是无效的。

9. f_opendir:打开一个目录

原型:FRESULT f_opendir ( DIR* DirObject, const XCHAR* DirName );

参数:

DirObject:待创建的空白目录对象的指针。

DirName:'\0'结尾的字符串指针,该字符串指定了将被打开的目录名。

返回值:

FR_OK (0):函数成功,目录对象被创建。该目录对象被后续调用,用来读取目录项。

FR_NO_PATH:找不到路径。

FR_INVALID_NAME:路径名无效。

FR_INVALID_DRIVE:驱动器号无效。

FR_NOT_READY:由于驱动器中没有存储介质或任何其他原因,而导致磁盘驱动器无法工作。

FR_DISK_ERR:由于底层磁盘I/O函数中的错误,而导致该函数失败。

FR_INT_ERR:由于一个错误的FAT结构或一个内部错误,而导致该函数失败。

FR_NOT_ENABLED:逻辑驱动器没有工作区。

FR_NO_FILESYSTEM:磁盘上没有有效的FAT卷。

描述:f_opendir函数当_FS_MINIMIZE <= 1时可用。f_opendir函数打开一个已存在的目录,并为后续的调用创建一个目录对象。该目录对象结构可以在任何时候不经任何步骤而被丢弃。

Fatfs文件系所有函数总结相关推荐

  1. 【转载】【FS】FATFS文件系统介绍(未完待续........2018.4.1)

    一.这是个什么玩意 它是一个文件系统,那文件系统是个什么玩意,直接从字面意思理解,它就是个管理文件的系统,所以叫文件系统,直白吧,也可以说是文件存储协议.但是继续追问的话会问,怎么来管理文件呢?好,基 ...

  2. Linux基础知识--2.Linux的文件系统和bash的基础特性(1)

    Linux基础知识--linux的文件系统和bash的基础特性 一.Linux文件系统: Linux文件系统中的文件是数据的集合,文件系统不仅包含着文件中的数据而且还有文件系统的结构,所有Linux ...

  3. Mysql复习计划(一)- 字符集、文件系统和SQL执行流程

    Mysql复习计划(一)- 字符集.文件系统和SQL执行流程 前言 一. Mysql字符集 1.1 Mysql5.7和8.0的默认字符集 1.1.1 修改默认的字符集 1.1.2 修改已有库表的字符集 ...

  4. FATFS 的几个函数使用方法

    转载:https://www.cnblogs.com/xidongs/archive/2011/02/08/1950018.html FATFS 的几个函数用法: FATFS *fs, fatfs; ...

  5. 【原创】【FS】FATFS文件系统介绍(未完待续........2018.4.1)

    一.这是个什么玩意 它是一个文件系统,那文件系统是个什么玩意,直接从字面意思理解,它就是个管理文件的系统,所以叫文件系统,直白吧,也可以说是文件存储协议.但是继续追问的话会问,怎么来管理文件呢?好,基 ...

  6. strstr函数头文件_C语言(函数)学习之strstr strcasestr

    一.strstr函数使用 [1] 函数原型 char *strstr(const char *haystack, const char *needle); [2] 头文件 #include [3] 函 ...

  7. python调用js库中的函数_Python 调用JS文件中的函数

    Python 调用JS文件中的函数 1.安装PyExecJS第三方库 2.导入库:import execjs 3.调用JS文件中的方法 Passwd = execjs.compile(open(r&q ...

  8. day3 集合、文件操作、函数、局部变量

    文章目录 1.集合 2.文件操作 3.函数 4.局部变量 1.集合   集合是一个无序的,不重复的数据组合,它的主要作用如下:   1)去重,把一个列表变成集合,就自动去重了   2)关系测试,测试两 ...

  9. Python开发【第三篇】:文件操作与函数

    内容概要 文件操作 初始函数 函数定义与调用 函数的返回值 函数的参数 函数进阶 函数参数--动态传参 名称空间 作用域 函数的嵌套 函数名的运用 gloabal,nonlocal 关键字 1.文件操 ...

最新文章

  1. 最短路-SPAF模板
  2. 《 面试又翻车了》这次竟然和 Random 有关?
  3. 基于STM32的SPI基本介绍
  4. 中粮集团对话农民丰收节交易会-万祥军:订单农业丰收经
  5. linux shell $# $* $@ $?
  6. 修改element-ui源码解决穿梭框选择后显示顺序问题
  7. 停止坐井观天,是时候让“我个人认为”见鬼去了!
  8. 华为云GaussDB(for MySQL)2.0全新升级,三大技术大揭秘
  9. ES6新特性_ES6模块化介绍_优势_以及产品---JavaScript_ECMAScript_ES6-ES11新特性工作笔记041
  10. python opencv3 —— 改变颜色空间(color space)
  11. 嵌入式ctags跳转和全局打印日志
  12. MPLS virtual private network路由信息的发布过程
  13. vue -- 正确的引入jquery
  14. 190614每日一句
  15. 网吧操作系统制作与优化
  16. 8051RTX编程一例
  17. 《组合数学全家桶》(ACM / OI 全网最全,清晰易懂)
  18. STM32F401RE Nucleo 在 keil MDK上的使用
  19. 基于java植物养护管理系统ssm
  20. php 公众号发表文章,微信公众号如何发布文章最基本教程

热门文章

  1. 小程序加载本地图片路径问题
  2. MODEL COMPRESSION VIA DISTILLATION AND QUANTIZATION 论文笔记
  3. Windows 中 SQLite3 使用(1) -- 配置
  4. 构建ASP.NET MVC5+EF6+EasyUI 1.4.3+Unity4.x注入的后台管理系统(61)-如何使用框架来开发?...
  5. G面经prepare: Pattern Match
  6. android入门之三【应用程序组成】
  7. OpenGL画矩形函数:glRectf,四个参数分别表示了位于对角线(左下到右上)上的两个点的横纵坐标
  8. 二叉树的递归遍历和层序遍历(c/c++)
  9. Python Web 框架:Django MVC搭建
  10. 关于Postfix邮件网关无法重启问题