orange's学习--第九章: 文件系统理解

我们在第4章的时候就研究过FAT12。FAT12算是很简单的文件系统了,既然我们已经比较熟悉它,就让我们结合它的结构来分析一下一个文件系统都需要哪些要素。我们来参考图4.1,图分四个部分,分别是引导扇区、FAT表、根 目录区和数据区。其中引导扇区中不仅包含引导代码,而且包含BPB (见表4.1),它包含诸如根 目录文件数最大值之类的信息,可算是文件系统的Metadata;FAT表记录的是整个磁盘扇区的使用情况,有哪些扇区未被使用,以及每个文件占用哪些扇区等;根目录区则是文件的索引了,那里记录了文件的名称、属性等内容。 

   这么看来,一个简单的文件系统大致需要这么几个要素: 

       要有地方存放Metadata; 
       要有地方记录扇区的使用情况; 
       要有地方来记录任一文件的信息,比如占用了哪些扇区等; 
       要有地方存放文件的索引。 

这些要点不难理解,而且如果你分析其他文件系统的话,也基本是这些要素。与此同时,只要具备了这些要素,一个文件系统基本就可用了——至于好坏,那不是我们这样的初学者要考虑的问题。好了,根据这些要素,同时参照Minix的文件系统,我们就把我们的文件系统设计成如图9.6所示的样子。 

可以看到,总体上来看,它几乎是把前述的各要素一字排开: 

       要有地方存放Metadata—— 占用整整一个扇区的superblock; 
       要有地方记录扇区的使用情况——sectormap; 
       要有地方来记录任一文件的信息,比如占用了哪些扇区等──inode map以及被称作inode_array的i-node真正存放地; 
       要有地方存放文件的索引──root数据区。 

superblock通常也叫超级块,文件系统的Metadata我们统统记在这里。sector map是一个位图,它用来映射扇区的使用情况,用1表示扇区已被使用,0表示未使用。i-node是UNIX世界各种文件系统的核心数据结构之一,我们把它借用过来。每个i-node对应一个文件,用于存放文件名、文件属性等内容,inode_array就是把所有i-node都放在这里,形成一个较大的数组。而inode map就是用来映射inode_array这个数组使用情况的一个位图,用法跟sector map类似。root数据区类似于FAT12的根目录区,但本质上它也是个普通文件,由于它是所有文件的索引,所以我们把它单独看待。为了简单起见,我们的文件系统暂不支持文件夹,也就是说用来表示 目录的特殊文件只有这么一个。这种不支持文件夹的文件系统,其实也不是我们的首创,历史上曾经有过,而且这种文件系统还有个名字,叫做扁平文件系统 (Flat File System)。 

 

对x86架构的处理器,业界一向是褒贬不一。但是毫无疑问的是,x86架构的处理器是迄今为止在市场上最成功的处理器。它既催生了Intel、微软这样的业界巨头,也改变了普通人们的生活。到今天,虽然有arm的异军突起,但是大部分程序员所编写的程序依然在运行在x86架构上。 虽然很多上层的程序员绕过了对CPU架构本身的理解,而直接使用高级语言进行编程,但是对CPU本身的熟悉,其实依然是所有想被称为优秀的程序员所难以绕过的一道坎。对CPU的不熟悉,实际上限制了程序员的思维方式、对程序的理解和实际解决问题的能力。 对于普通的芯片,阅读几页的说明书就可以大致理解如何让它工作。CPU是比较复杂的一种,对于比较简单的CPU架构,阅读几十页的文档也能大致熟悉。然而 x86架构的CPU的说明可不是这么简单,其手册估计有一共有四、五千页之巨。不要说理解透彻,就是从头到尾翻一遍也不是一件简单的事情。并非Intel 有意将它做得复杂,这里有历史的原因。因为这个架构的应用实在太广了,全世界有无数的软件都在它的基础之上工作。为此它自身的升级也就变得举步维艰。每次升级都不得不要兼容之前的特性。这也就导致了新旧指令层层堆积,种种特性互相兼顾,最终变成如今的一团乱麻了。 对于入门级的选手,读完那些手册可不是一件容易的事情。但是于渊的这本《orange's:一个操作系统的实现》却是一条难得的终南捷径。因为要理解如何让一个芯片正常工作,最简单的办法就是从头开始去写程序让它运行起来,然后操作它做自己想做的事情。如果是平时的编程,这些下层的工作都已经有操作系统帮你做了,对理解x86架构的帮助就大为有限。如果去读那几千页的文档,不但读起来很痛苦,中间又没有多少可以实际操作的工作来帮助你温故而知新,这其中的枯燥乏味,绝对不是一般人可以忍受的了。而且更重要的手册中虽然包含了x86所有的特性,然而其中有些特性是现代操作系统根本就没有用到的。努力的去理解的话,又是吃力不讨好了。如果每个读者都可以随着这本书的介绍,去逐步的实现一个操作系统,不但这中间其乐无穷,而且实现到最后,对x86架构的理解也就不在话下。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值