FAT文件系统操作系统课程设计实验报告

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

F A T文件系统操作系统

课程设计实验报告

文档编制序号:[KKIDT-LLE0828-LLETD298-POI08]

操作系统课程设计之三

设计任务:模拟OS文件系统

在任一OS(Window或者Dos;也可以是在Linux下,但要求能将结果演示给

老师看)下,建立一个大文件,把它假象成一张盘,在其中实现一个简单的模拟

OS文件系统。

1、在现有机器硬盘上开辟10M(共10000个盘块,每盘块大小为1k)的硬盘空间

(生成一个10M的用户文件即可),作为设定的硬盘空间。

2、编写一管理程序SDisk,对此空间进行管理,以模拟OS文件系统,要求:

⑴、盘块大小1k

⑵、空闲盘块的管理:采用位示图法

⑶、文件空间管理:采用FAT(文件分配表),每个盘块号占2个字节

⑷、目录项管理:

①、每个目录项占用32字节,其中前8个字节(0-7)为文件名,之后跟3个字

节(8-10)的扩展名,26-27字节,存放文件的第一个盘块号,最后四个字节

(28-31),存放文件长度(如果目录项对应的是下一级子目录(文件),其

文件长度部分为0)

②、目录按文件方式管理,每个目录仅用一个盘块(即1k,最多装32个目录项)

③、第0个目录项为本目录,即“.”,第0个字节为“.”,即0x2E,第26-27字节

指明本目录所在盘块。

④、第1个目录项为父目录,即“..”,第0,1个字节为“..”即0x2E,0x2E,第

26-27字节指明父目录所在盘块。

⑤、每个目录实际能放下文件或子目录30项。

⑸、文件系统空间分配:

①、第0个盘块(1k)存放磁盘信息(可以设定为格式说明“FAT32”、盘块大小,盘块数等内

容)

②、第1个盘块起,至125盘块,共125个盘块(125k)存放FAT内容

③、第126、127(2个)盘块,存放位示图

④、从第128盘块至10000盘块,皆为数据(区)盘块,其逻辑编号从0开始,至

9872号数据盘块,即第0数据盘块为128号盘块,第1数据盘块为129号盘块,…

⑤、第0数据盘块(即128号盘块),存放根目录(同样只用一个盘块作根目

录),由于第0、1目录项为“.”(本目录), “..”(父目录),因此根目录下同样只能存放30个文件或目录,并且从第2个目录项开始。

⑥、文件或子目录数据,放在第1数据盘块及以后的数据盘块中,由用户按需要使

用。

3、SDisk管理程序的功能要求如下:

⑴、正常情况下,显示等待命令输入符号#

⑵、改变目录命令:

#cd 目录名,改变当前工作目录,目录不存在时给出出错信息

#cd ..,返回上一级目录,如果是根目录,给出提示信息

⑶、生成新目录

#md 目录名,创建新目录(需要更改FAT内容和位示图内容)

⑷、删除目录

#rd 目录名,删除目录,如果目录不存在时给出出错信息(需要更改FAT内容和位示图内容)

⑸、显示目录

#dir,显示指定目录下或当前目录下的信息,包括文件名、扩展名、物理地址(文件或目录第一个盘块号)、文件长度、子目录

⑹、创建新文件

#CreateFile 文件名.扩展名文件长度,根据文件名.扩展名,创建一个目录项(fcb),根据文件长度和位示图中空闲盘块情况,分配足够多的连续盘块,给新文件(需要更改FAT内容和位示图内容)。

⑺、删除文件

#DelFile 文件名.扩展名,在文件所在的目录项中,将第一个字节变为0xE5,并同时修改FAT内容和位示图内容;如果文件不存在,给出出错信息

⑻、文件拷贝

#CopyFile 老文件,新文件,为新文件创建一个目录项,并将老文件内容复制到新文件中,并同时修改FAT内容和位示图内容

⑼、显示位示图内容

#ShowBitMP,将位示图内容(已有信息部分),显示在屏幕上(按十六进制)⑽、显示FAT内容

#ShowFAT,将FAT内容(已有信息部分),显示在屏幕上(按十六进制)

4、程序的总体流程为:

⑴、输出提示符#,等待接受命令,分析键入的命令;

⑵、对合法的命令,执行相应的处理程序,否则输出错误信息,继续等待新命令(1、请参考“文件系统简介.doc”中,有关文件系统的规定;

2、请参考WinHex中,目录所显示的信息进行编程)

name,".");

strcpy(filedir->list[0].exname,"dir");

filedir->list[0].fnum=currentdir;

filedir->list[0].length=0;

strcpy(filedir->list[1].fname,"..");

strcpy(filedir->list[1].exname,"dir");

filedir->list[1].fnum=currentdir;

filedir->list[1].length=0;

fp=fopen(FilePath,"w+");

fwrite(file,sizeof(char),DISK_SIZE,fp);

fclose(fp);

printf("初始化已经完成,现在可以进行操作了!\n\n");

}

/*

*创建子目录

*/

int mkdir(char *str)

{

int i,j;

int blockid; name,str)==0)

{

printf("目录下有同名文件夹\n");

return 0;

}

}

for(i=2;i

{

if(strcmp(dir->list[i].fname,"")==0) name,str);

dir->list[i].fnum=blockdir;

strcpy(dir->list[i].exname,"dir");

dir->list[i].length=0;

dir=(struct DIR *)(file+blockdir*BLOCK_SIZE); name,".");

strcpy(dir->list[0].exname,"dir");

dir->list[0].fnum=blockdir;

dir->list[0].length=0;

相关文档
最新文档