您的位置 首页 FPGA

FATFS简介

一、概述1、目的在移植之前,先将源代码大概的阅读一遍,主要是了解文件系统的结构、各个函数的功能和接口、与移植相关的代码等等。2、准备

一、概述

1、意图
在移植之前,先将源代码大约的阅览一遍,首要是了解文件体系的结构、各个函数的功用和接口、与移植

相关的代码等等。
2、准备工作
在官方网站下载了0.07c版别的源代码,运用记事本进行阅览。

二、源代码的结构
1、源代码组成
源代码压缩包解压后,共两个文件夹,doc是阐明,src里便是代码。src文件夹里共五个文件和一个文

件夹。文件夹是option,还有00readme.txt、diskio.c、diskio.h、ff.c、ff.h、integer.h。比照网上

的文章,版别现已不同了,现已没有所谓的tff.c和tff.h了,估量现在都选用条件编译处理这个问题了,

当然文件更少,或许编译选项或许越杂乱。

2、00readme.txt的阐明
Low level disk I/O module is not included in this archive because the FatFs
module is only a generic file system layer and not depend on any specific
storage device. You have to provide a low level disk I/O module that written
to control your storage device.首要是说不包含底层IO代码,这是个通用文件体系能够在各种介质

上运用。咱们移植时针对详细存储设备供给底层代码。
接下来做了版权声明-能够自在运用和传达。
然后对版别的变迁做了阐明。

3、源代码阅览次第
先读integer.h,了解所用的数据类型,然后是ff.h,了解文件体系所用的数据结构和各种函数声明,然

后是diskio.h,了解与介质相关的数据结构和操作函数。再把ff.c和diskio.c两个文件所完成的函数大致

扫描一遍。最终依据用户应用层程序调用函数的次第仔细阅览相关代码。

三、源代码阅览
1、integer.h头文件
这个文件首要是类型声明。以下是部分代码。
typedef int INT;
typedef unsigned int UINT;
typedef signed char CHAR;
都是用typedef做类型界说。移植时能够修正这部分代码,特别是某些界说与你地点工程的类型界说有冲

突的时分。

2、ff.h头文件
以下是部分代码的剖析
#include “integer.h” 运用integer.h的类型界说
#ifndef _FATFS
#define _FATFS 0x007C 版别号007c,0.07c
#define _WORD_ACCESS 0 //假如界说为1,则能够运用word拜访。
中心有一些看着阐明很简单弄清楚意思。这儿就不例举了。

#define _CODE_PAGE 936

#define _FS_REENTRANT 0 //假如要支撑文件体系可重入,有必要参加几个函数。
#define _TIMEOUT 1000
#define _SYNC_t HANDLE

#elif _CODE_PAGE == 936
#define _DF1S 0x81
#define _DF1E 0xFE
#define _DS1S 0x40
#define _DS1E 0x7E
#define _DS2S 0x80
#define _DS2E 0xFE
接下来很大一部分都是与言语相关的要素,略过。

三个宏判别是否大写、小写、数字。
#define IsUpper(c) (((c)>=A)&&((c)<=Z))
#define IsLower(c) (((c)>=a)&&((c)<=z))
#define IsDigit(c) (((c)>=0)&&((c)<=9))

#if _DF1S 双字节编码相关的设定,暂时不理睬它。

#if _MULTI_PARTITION

//该变量界说为1时,支撑一个磁盘的多个分区。

typedef struct _PARTITION {

BYTE pd;

BYTE pt;

} PARTITION;

Extern const PARTITION Drives[];//假如支撑分区,则声明变量Drivers

#define LD2PD(drv) (Drives[drv].pd)

#define LD2PD(drv) (drv)

#define LD2PT(drv) 0

#if _MAX_SS == 512 //一般扇区长度取512字节。

#define SS(fs) 512U

#if _LFN_UNICODE && _USE_LFN

typedef WCHAR XCHAR; XCHAR是文件名的码型所用。

#else

typedef char XCHAR;

#endif

typedef struct _FATFS_ {

BYTE fs_type;

BYTE drive;

BYTE csize;

先查一下簇的含义:应该是文件数据分配的基本单位。

BYTE n_fats;

FAT文件体系顺次应该是:引导扇区、文件分配表两个、根目录区和数据区。

BYTE wflag;

//文件是否改动的标志,为1时要回写。

WORD id;

WORD n_rootdir;

#if _FS_REENTRANT

_SYNC_t sobj;

#endif

#if _MAX_SS != 512

WORD s_size;

#endif

#if !_FS_READONLY //文件为可写

BYTE fsi_flag;

//文件需要回写的标志

DWORD last_clust;

DWORD free_clust;

DWORD fsi_sector;

#endif

#if _FS_RPATH

DWORD cdir;

//现在的扇区在win[]里边,这个win[]数组暂时还不知道含义。

BYTE win[_MAX_SS];

//这是一个win[512]数组,存储着一个扇区,如同作为扇区缓冲运用。

} FATFS;

typedef struct _DIR_ {

FATFS* fs;指向相应文件体系目标。

WORD id;

WORD index; 现在读写索引代码

DWORD sclust; 文件数据区开端簇

DWORD clust; 现在处理的簇

DWORD sect; 现在簇里对应的扇区

BYTE* dir;

BYTE* fn;

#if _USE_LFN

WCHAR* lfn; 指向长文件名缓冲。

WORD lfn_idx;

#endif

} DIR;

typedef struct _FIL_ {

FATFS* fs;

WORD id;

BYTE flag; 文件状况标志

BYTE csect; 扇区偏移

DWORD fptr; 读写指针

DWORD fsize;

DWORD org_clust; 文件开端簇

DWORD curr_clust; 当时簇

DWORD dsect; 文件当时扇区

#if !_FS_READONLY

DWORD dir_sect; 该文件目录项对应地点的扇区

BYTE* dir_ptr;

#endif

#if !_FS_TINY

BYTE buf[_MAX_SS];文件读写缓冲

#endif

} FIL;

typedef struct _FILINFO_ {

DWORD fsize;

WORD fdate;

WORD ftime;

BYTE fattrib;

char fname[13];

#if _USE_LFN

XCHAR* lfname;

int lfsize;

#endif

} FILINFO; 这个结构首要描绘文件的状况信息,包含文件名13个字符(8+.+3+)、特点、修正时刻等。

接下来是函数的界说,先大约阅读一遍。

FRESULT f_mount (BYTE, FATFS*); //加载文件体系,BYTE参数是ID,后一个是文件体系界说。

FRESULT f_open (FIL*, const XCHAR*, BYTE);//翻开文件,第一个参数是文件信息结构,第二个参数是文件名,第三是文件翻开形式

FRESULT f_read (FIL*, void*, UINT, UINT*); //文件读取函数,参数1为文件目标(文件翻开函数中得到),参数2为文件读取缓冲区,参数3为读取的字节数,参数4含义不明晰,等读到源代码就清楚了。

FRESULT f_write (FIL*, const void*, UINT, UINT*);//写文件,参数跟读差不多

FRESULT f_lseek (FIL*, DWORD); //移动文件的读写指针,参数2应该是移动的数目。

FRESULT f_close (FIL*);

FRESULT f_opendir (DIR*, const XCHAR*); 翻开目录,回来目录目标

FRESULT f_readdir (DIR*, FILINFO*); 读取目录,取得文件信息

FRESULT f_stat (const XCHAR*, FILINFO*);

FRESULT f_getfree (const XCHAR*, DWORD*, FATFS**);

FRESULT f_truncate (FIL*);

FRESULT f_sync (FIL*); 将缓冲区数据写回文件

FRESULT f_unlink (const XCHAR*); 删去目录中的一个文件

FRESULT f_mkdir (const XCHAR*);

FRESULT f_chmod (const XCHAR*, BYTE, BYTE);

FRESULT f_utime (const XCHAR*, const FILINFO*);

FRESULT f_rename (const XCHAR*, const XCHAR*);

FRESULT f_forward (FIL*, UINT(*)(const BYTE*,UINT), UINT, UINT*); 这个函数还要供给一个回调函数。

FRESULT f_mkfs (BYTE, BYTE, WORD);

FRESULT f_chdir (const XCHAR*); 改动当时目录

FRESULT f_chdrive (BYTE);

应该说基本能理解这些函数用于干什么。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/fangan/fpga/259700.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部