1. 初始FATFS
FATFS 是一个通用的文件系统(FAT/exFAT)模块,用于在小型嵌入式系统中实现FAT文件系统。由于FATFS组件的编写遵循ANSI C(C89),完全分离于磁盘 I/O 层,故而不需要通过任何修改便可以嵌入到资源有限的MCU中,如 8051, PIC, AVR, ARM, Z80, RX等等。除此之外,FatFs可以让使用者仅通过调用其提供的一些接口函数(例如f_open等),就可以在指定的区域中读写数据,且可以不考虑由于磁盘内部预先的数据分区不够使得文件储存出现错误的情况。
2. FATFS的接口函数及其作用
FatFs 提供下面的函数(简单了解即可):
f_mount | 注册/注销一个工作区域(Work Area) |
f_open | 打开/创建一个文件 |
f_close | 关闭一个文件 |
f_read | 读文件 |
f_write | 写文件 |
f_lseek | 移动文件读/写指针 |
f_truncate | 截断文件 |
f_sync | 冲洗缓冲数据 Flush Cached Data |
f_opendir | 打开一个目录 |
f_readdir | 读取目录条目 |
f_getfree | 获取空闲簇 Get Free Clusters |
f_stat | 获取文件状态 |
f_mkdir | 创建一个目录 |
f_unlink | 删除一个文件或目录 |
f_chmod | 改变属性(Arribute) |
f_utime | 改变时间戳(Timestamp) |
f_rename | 重命名/移动一个文件或文件夹 |
f_mkfs | 在驱动器上创建一个文件系统 |
f_forward | 直接转移文件数据到一个数据流 |
f_gets | 读一个字符串 |
f_putc | 写一个字符 |
f_puts | 写一个字符串 |
f_printf | 写一个格式化的字符的磁盘I/O接口 |
3. FATFS的移植
FATFS的源码可以通过http://elm-chan.org/fsw/ff/00index_e.html 下载。通常情况下,我们只需要对ffconf.h(与平台无关)和diskio.c(和平台有关)进行修改便可以满足我们的实际需求。下面我们来讲讲 FATFS 的移植,主要分为 3 步:
① 数据类型:在 integer.h 里面去定义好数据的类型。这里需要了解你用的编译器的数据类型,并根据编译器定义好数据类型。
② 配置:通过 ffconf.h 配置 FATFS 的相关功能,以满足你的需要。以下是一些重要的配置选项:
_FS_TINY | 是FATFS 和 Tiny FATFS的整合,直接定义为 0 即可 |
_FS_READONLY | 用来配置是不是只读/读写(1/0) |
_USE_STRFUNC | 用来设置是否支持字符串类操作(1),如 f_putc |
_USE_MKFS | 用来定时是否使能格式化(1) |
_USE_FASTSEEK | 用来使能快速定位(1) |
_USE_LABEL | 用来设置是否支持磁盘盘符(名字)读取与设置(1) |
_CODE_PAGE | 用于设置语言类型,包括很多选项(见 FATFS 官网说明),我们这里设置为 936,即简体中文(GBK 码,需要 c936.c 文件支持,该文件在 option 文件夹) |
_USE_LFN | 用于设置是否支持长文件名(还需要_CODE_PAGE 支持),取值范围为 0~3。 0: Disable LFN,关闭长文件功能。 |
_VOLUMES | 用于设置 FATFS 支持的逻辑设备数目 |
_MAX_SS | 扇区缓冲的最大值,一般设置为 512 |
免责声明:本文所引用的各种资料均用于自己学习使用,这里感谢正点原子和野火官方的资料以及各位优秀的创作者。