汤园园课程设计_第1页
汤园园课程设计_第2页
汤园园课程设计_第3页
汤园园课程设计_第4页
汤园园课程设计_第5页
已阅读5页,还剩43页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、操作系统课程设计报告题 目: 文件系统模拟实验 学生姓名: 汤园园 学 号: 200917030133 专业班级: 网工09101班 同组姓名: 彭丽娜 郭双 武娟 何巧林 指导教师: 熊 齐 设计时间: 2012.2.132012.2.26 指导老师意见: 评定成绩: 签名: 日期:一、设计目的该实验的目的是通过学习文件系统的模拟实验使我们能够更好的了解与掌握unix系统下的文件系统的基本设计原理,及unix系统下的基本操作方法,另外,通过这次实验能够提高我们的实践动手能力,以及团队合作分工能力。总之,该实验的主要目的是在掌握基本原理及基本方法的情况下,锻炼我们的实际操作能力。二、设计内容(

2、1)概述为linux 设计一个简单的二级文件系统。要求做到以下几点:1、可以实现下列几条命令(至少4条)。login 用户登录dir 列文件目录create 创建文件delete 删除文件open 打开文件close 关闭文件read 读文件write 写文件2、列目录时要列出文件名、物理地址、保护码和文件长度。3、源文件可以进行读写保护。(2)设计原理和系统总体功能框架图 设计原理:首先本文件系统采用两级目录,其中第一级对应于用户账户,第二级对应于用户账户下的文件。另外,为了简单本文件系统未考虑文件共享,文件系统安全以及管道文件与设备文件等特殊内容。另外该文件系统依据以下数据结构及主要函数而

3、设计的。【1】主要的一些数据结构 1)i节点struct inode struct inode *i_forw; struct inode *i_back; char i_flag; unsigned int i_ino; /*磁盘i节点标号*/ unsigned int i_count; /*引用计数*/ unsigned short di_number; /*关联文件数,当为0时,则删除该文件*/ unsigned short di_mode; /*存取权限*/ unsigned short di_uid; /*磁盘i节点用户id*/ unsigned short di_gid; /*磁盘

4、i节点组id*/ unsigned int di_addrnaddr; /*物理块号*/ 2)磁盘i节点 struct dinode unsigned short di_number; /*关联文件数*/unsigned short di_mode; /*存取权限*/unsigned short di_uidunsigned short di_gid;unsigned long di_size; /*文件大小*/unsigned int di_addrnaddr; /*物理块号*/3)目录项结构struct direct char d_namedirsiz; /*目录名*/unsigned i

5、nt d_ino; /*目录号*/4)超级块struct filsys unsigned short s_isize; /*i节点块块数*/unsigned long s_fsize; /*数据块块数*/unsigned int s_nfree; /*空闲块块数*/unsigned short s_pfree; /*空闲块指针*/unsigned int s_freenicfree; /*空闲块堆栈*/unsigned int s_ninode; /*空闲i节点数*/unsigned short s_pinode; /*空闲i节点指针*/unsigned int s_inodenicinod;

6、 /*空闲i节点数组*/unsigned int s_rinode; /*铭记i节点*/char s_fmod; /*超级块修改标记*/5)用户密码struct pwd unsigned short p_uid;unsigned short p_gid;char passwordpwosiz;6)目录struct dir struct direct direct dirnum;int size;7)查找内存i节点的hash表 struct hinode struct inode *i_forw;8)系统打开表struct file char f_flag; /*文件操作标志*/unsigned

7、 int f_count; /*引用计数*/struct inode *f_inode; /*指向内存i节点*/unsigned long f_off; /*读/写指针*/;9)用户打开表struct user unsigned short u_default_mode;unsigned short u_uid; /*用户标志*/unsigned short u_gid; /*用户组标志*/unsigned short u_ofilenofile; /*用户打开表*/;【2】主要的一些函数1、i节点内容获取函数iget( ) 2、i节点内容释放函数iput( ) 3、目录创建函数mkdir(

8、) 4、目录搜索函数namei( )5、磁盘块分配函数balloc( )6、磁盘块释放函数bfree( )7、分配i节点区函数ialloc( )8、释放i节点区函数ifree( )9、搜索当前目录下文件的函数iname( )10、访问控制函数access( )11、显示目录和文件用函数_dir( )12、改变当前目录用函数chdir( )13、打开文件函数open( )14、创建文件函数create( )15、读文件用函数read( )16、写文件用函数write( )17、用户登录函数login( )18、用户退出函数logout( )19、文件系统格式化函数format( )20、进入文件

9、系统函数install( )21、关闭文件系统函数close( )22、退出文件系统函数halt( )23、文件删除函数delete( )format开始 formatdir选择操作 install logout halt loginchdirmkdircreatwriteclosedeleteedeletee 结束(3)详细设计及少数重要编码的说明【1】头文件filesys.h的设计: 它包括文件系统中的数据结构,常量,全局变量等申明。 例如:1)i节点struct inode struct inode *i_forw; struct inode *i_back; char i_flag;

10、unsigned int i_ino; /*磁盘i节点标号*/ unsigned int i_count; /*引用计数*/ unsigned short di_number; /*关联文件数,当为0时,则删除该文件*/ unsigned short di_mode; /*存取权限*/ unsigned short di_uid; /*磁盘i节点用户id*/ unsigned short di_gid; /*磁盘i节点组id*/ unsigned int di_addrnaddr; /*物理块号*/ 2) 常量的设置:#define blocksiz 512#define sysopenfil

11、e 40#define dirnum 128#define dirsiz 14#define pwdsiz 12#define pwdnum 32#define nofile 20#define naddr 10#define nhino 128 /*must be power of 2 */#define usernum 10#define dinodesiz 32【2】主函数模块(main.c): 其中重要部分代码: printf(begin:n); printf(ndo you want to format the disk?n); if(getchar( )=y) printf(nfo

12、rmat will erase context on the disk n are you sure?n); getchar(); if(c=getchar( )=y) printf(format startsn); format( ); ihave_formated = 1; printf(format endedn); else printf(received char :%c from stdinn,c); printf(step 1 endedn); install( ); printf(step 2 endedn); _dir( ); printf(step 3 endedn); l

13、ogin(2118,abcd); user_id=0; printf(step 4 endedn); mkdir(a2118); _dir(); printf(step 5-1 endedn); chdir(a2118); _dir(); printf(step 5-2 endedn); ab_fd1=creat(2118,ab_file0.c,01777); _dir(); printf(step 6 endedn); buf=(char *)malloc(blocksiz*6+5); printf(step 7 endedn); write(2118,ab_fd1,buf,blocksiz

14、*6+5); printf(step 8 endedn); close(2118,ab_fd1);【3】初始化磁盘格式模块(format.c): 其中的一下重要的算法: /*给main()中的密码表pwdpwdnum填入内容*/ pwd0.p_uid=2116;pwd0.p_gid=03; strcpy(pwd0.password,dddd); pwd1.p_uid=2117;pwd1.p_gid=03; strcpy(pwd1.password,bbbb); pwd2.p_uid=2118;pwd2.p_gid=04; strcpy(pwd2.password,abcd); pwd3.p_u

15、id=2119;pwd3.p_gid=04; strcpy(pwd3.password,cccc); pwd4.p_uid=2220;pwd4.p_gid=05; strcpy(pwd4.password,eeee);该模块的流程图:结束开始 buf是为null? 是 否初始化用户登录初始化超级块创建主目录和副目录【4】进入文件系统模块(install.c): 其中的一下重要的算法: /*2. initialize the inode hash chain */ for (i=0;inhino;i+) hinodei.i_forw=null; /*3. initialize the sys_ofile */ for (i

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论