admin 管理员组

文章数量: 1184232


2024年3月13日发(作者:seajs从入门到原理)

FatFS源代码阅读分析

一、概述

1、目的

在移植之前,先将源代码大概的阅读一遍,主要是了解文件系统的结构、各个函数的功能和

接口、与移植

相关的代码等等。

2、准备工作

在官方网站下载了0.07c版本的源代码,利用记事本进行阅读。

二、源代码的结构

1、源代码组成

源代码压缩包解压后,共两个文件夹,doc是说明,src里就是代码。src文件夹里共五个

文件和一个文

件夹。文件夹是option,还有、diskio.c、diskio.h、ff.c、ff.h、integer.h。对比网

的文章,版本已经不同了,已经没有所谓的tff.c和tff.h了,估计现在都采用条件编译解决

这个问题了,

当然文件更少,可能编译选项可能越复杂。

2、的说明

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;/* These types must be 8-bit integer */

都是用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

/* The _CODE_PAGE specifies the OEM code page to be used on the target system.

OEM code page什么意思不大明白。

/ 936 - Simplified Chinese GBK (DBCS, OEM, Windows)跟据这个中国应该是936.

打开option文件夹看一下。打开cc936.c文件,里面有一个很大的数组static const WCHAR

uni2oem[] 。

根据英文说明,这个数组用于unicode码和OEM码之间的相互转换。

接下来又有两个函数ff_convert()和ff_wtoupper()具体执行码型转换和将字符转换为大写。

百度一下:看OEM码什么意思。

unicode是一种双字节字符编码,无论中文还是英文,或者其他语言统一到2个字节。与现

有的任何编码(

ASCII,GB等)都不兼容。WindowsNT(2000)的内核即使用该编码,所有数据进入内核前转

换成UNICODE,退

出内核后在转换成版本相关的编码(通常称为OEM,在简体中文版下即为GB).(百度所得)

继续往下阅读。

#define _USE_LFN 1 //这个估计是长文件名支持了,以前的0.06版本好像是不支持。

#define _MAX_LFN 255 //最长支持255个双字节字符。

#define _FS_RPATH 0 //是否文件相对路径选项。


本文标签: 代码 源代码 版本 相关 说明