文档详情

《FatFS源代码阅读分析》.pdf

发布:2016-01-02约字共12页下载文档
文本预览下载声明
/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
显示全部
相似文档