- 2
- 0
- 约 10页
- 2017-02-09 发布于重庆
- 举报
FatFS源代码阅读分析
一、概述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))
用source insight
继续分析ff.h文件内容。
#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 _
原创力文档

文档评论(0)