《FatFS源代码阅读分析》.pdf
文本预览下载声明
/282280072/home
/282280072/home
来自:hhttttpp::////hhii..bbaaiidduu..ccoomm//hhoommee
FatFS
FatFS
FFaattFFSS源代码阅读分析(一)
一、概述
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;/* 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).(百度所得)
继续往下阅读。
#defi
显示全部