(FatFS执行流程分析.doc
文本预览下载声明
FatFS执行流程分析(一)
在网上找了一个FatFS移植的例子,并含有源代码。
/jjldc/190753/message.aspx
在主程序中,有FatFS操作的流程,我的流程分析就以这个为基础。
?
一、读文件流程。
1、程序结构
res = f_mount(0, fs);
res = f_open(file, data.txt, FA_OPEN_EXISTING | FA_READ);
while(1)
{ if(fgets(data, sizeof(data), file)==NULL)
{ break; }
prints(data);
}
f_close(file);
总共四个与文件系统相关的函数,下面就沿着函数执行路径去探索一下。
?
2、f_mount(0, fs)的执行
参数0是卷号,就像电脑上的CDE盘等。fs是一个未初始化的一个文件系统对象,其定义在此:FATFS fs。这个函数好像就做了两个个事,使全局文件系统指针FatFS指向fs对象,并使fs.fstype=0。
?
3、f_open(file, data.txt, FA_OPEN_EXISTING | FA_READ)的执行
参数file是提供一个文件对象指针,打开文件过程中获得的一些信息都填入这个结构体。FA_OPEN_EXISTING | FA_READ表示要打开和读取相应的文件。源程序如下:
FRESULT f_open (
FIL *fp, /* fp就指向传入的对象file */
const char *path, /*path指向data.txt的地址 */
BYTE mode /* Access mode and file open mode flags */
)
{
DIR dj; 目录对象
BYTE *dir; 目录项指针
char fn[8+3+1]; 8.3文件名。 // 程序开头定义了这么三个变量,007c版本中由于支持长文件名,最好一个改为NAMEBUF(sfn, lfn)。
fp-fs = NULL; 每个文件对象都指向具体的文件系统,这里先清0
auto_mount(path, dj.fs, (BYTE)(mode) ); //这个函数看来很关键了。旧版的函数没有中间这个参数。
Path本来就是一个指针,path就是一个指向指针的指针,dj.fs因为dj对象还未设置,这个指针传入应该是供auto_mount函数设置的。
?
4、auto_mount(path, dj.fs, (BYTE)(mode) )的执行
先分析旧版的:
FRESULT auto_mount ( /* FR_OK(0): successful, !=0: any error occured */
const char **path, /* Pointer to pointer to the path name (drive number) */
BYTE chk_wp /* !=0: Check media write protection for write access)
{
DWORD bootsect, fatsize, totalsect, maxclust;
const char *p = *path; //指针p现在就指向文件名字符串了。
FATFS *fs;
?
memset(fs, 0, sizeof(FATFS)); /*将全局文件系统结构清0 */
stat = disk_initialize(0); /*磁盘初始化程序,在这里调用的 */
?
fmt = check_fs(bootsect = 0); /* Check sector 0 as an SFD format */
这里主要是调用了check_fs(bootsect = 0)函数检测是否存在FAT文件系统。
?
下面是源代码:
BYTE check_fs ( /* 0:The FAT boot record, 1:Valid boot record but not an FAT, 2:Not a boot record or error */
DWORD sect /* Sector# to check if it is an FAT boot record or not */
)
{ FATFS *fs = FatFs;
if (disk_read(0, fs-win, sect, 1) != RES_OK) /* Load boot record */
return 2;
if (LD_WORD(fs-win[BS_55AA]) != 0xAA55) /*Check record signature */
return 2;
if (!memcmp(fs-w
显示全部