一、硬盘的物理结构:
硬盘存储数据是根据电、磁转换原理实现的。硬盘由一个或几个表面镀有磁性物质的金属或玻璃等物质盘片以及盘片两面所安装的磁头和相应的控制电路组成(图1),其中盘片和磁头密封在无尘的金属壳中。
硬盘工作时,盘片以设计转速高速旋转,设置在盘片表面的磁头则在电路控制下径向移动到指定位置然后将数据存储或读取出来。当系统向硬盘写入数据时,磁头中“写数据”电流产生磁场使盘片表面磁性物质状态发生改变,并在写电流磁场消失后仍能保持,这样数据就存储下来了;当系统从硬盘中读数据时,磁头经过盘片指定区域,盘片表面磁场使磁头产生感应电流或线圈阻抗产生变化,经相关电路处理后还原成数据。因此只要能将盘片表面处理得更平滑、磁头设计得更精密以及尽量提高盘片旋转速度,就能造出容量更大、读写数据速度更快的硬盘。这是因为盘片表面处理越平、转速越快就能越使磁头离盘片表面越近,提高读、写灵敏度和速度;磁头设计越小越精密就能使磁头在盘片上占用空间越小,使磁头在一张盘片上建立更多的磁道以存储更多的数据。
二、硬盘的逻辑结构。
硬盘由很多盘片(platter)组成,每个盘片的每个面都有一个读写磁头。如果有n个盘片。就有2n个面,对应2n个磁头(heads),从0、1、2开始编号。每个盘片被划分成若干个同心圆磁道(逻辑上的,是不可见的。)每个盘片的划分规则通常是一样的。这样每个盘片的半径均为固定值r的同心圆再逻辑上形成了一个以电机主轴为轴的柱面(cylinders),从外至里编号为0、1、2……每个盘片上的每个磁道又被划分为几十个扇区(sector),通常的容量是512byte,并按照一定规则编号为1、2、3……形成cylinders×heads×sector个扇区。这三个参数即是硬盘的物理参数。我们下面的很多实践需要深刻理解这三个参数的意义。
三、磁盘引导原理。
3.1 mbr(master boot record)扇区:
计算机在按下power键以后,开始执行主板bios程序。
进行完一系列检测和配置以后。开始按bios中设定的系统引导顺序引导系统。假定现在是硬盘。bios执行完自己的程序后如何把执行权交给硬盘呢。交给硬盘后又执行存储在哪里的程序呢。其实,称为mbr的一段代码起着举足轻重的作用。mbr(master boot record),即主引导记录,有时也称主引导扇区。位于整个硬盘的0柱面0磁头1扇区(可以看作是硬盘的第一个扇区),bios在执行自己固有的程序以后就会jump到mbr中的第一条指令。将系统的控制权交由mbr来执行。在总共512byte的主引导记录中,mbr的引导程序占了其中的前446个字节(偏移0h~偏移1bdh),随后的64个字节(偏移1beh~偏移1fdh)为dpt(disk partitiontable,硬盘分区表),最后的两个字节“55 aa”(偏移1feh~偏移1ffh)是分区有效结束标志。
mbr不随操作系统的不同而不同,意即不同的操作系统可能会存在相同的mbr,即使不同,mbr也不会夹带操作系统的性质。具有公共引导的特性。
我们来分析一段mbr。下面是用winhex查看的一块希捷120gb硬盘的mbr。
你的硬盘的mbr引导代码可能并非这样。不过即使不同,所执行的功能大体是一样的。这是wowocock关于磁盘mbr的反编译,已加了详细的注释,感兴趣可以细细研究一下。
我们看dpt部分。操作系统为了便于用户对磁盘的管理。加入了磁盘分区的概念。即将一块磁盘逻辑划分为几块。磁盘分区数目的多少只受限于c~z的英文字母的数目,在上图dpt共64个字节中如何表示多个分区的属性呢? microsoft通过链接的方法解决了这个问题。在dpt共64个字节中,以16个字节为分区表项单位描述一个分区的属性。也就是说,第一个分区表项描述一个分区的属性,一般为基本分区。第二个分区表项描述除基本分区外的其余空间,一般而言,就是我们所说的扩展分区。这部分的大体说明见表1。
表1 图2分区表第一字段字节位移字段长度值字段名和定义0x01bebyte0x80引导指示符(boot indicator)指明该分区是否是活动分区。0x01bfbyte0x01开始磁头(starting head)0x01c06位0x01开始扇区(starting sector)只用了0~5位。后面的两位(第6位和第7位)被开始柱面字段所使用0x01c110位0x00开始柱面(starting cylinder)除了开始扇区字段的最后两位外,还使用了1位来组成该柱面值。开始柱面是一个10位数,最大值为10230x01c2byte0x07系统id(system id)定义了分区的类型,详细定义,请参阅图40x01c3byte0xfe结束磁头(ending head)0x01c46位0xff结束扇区(ending sector)只使用了0~5位。最后两位(第6、7位)被结束柱面字段所使用0x01c510位0x7b结束柱面(ending cylinder)除了结束扇区字段最后的两位外,还使用了1位,以组成该柱面值。结束柱面是一个10位的数,最大值为10230x01c6dword0x0000003f相对扇区数(relative sectors) 从该磁盘的开始到该分区的开始的位移量,以扇区来计算0x01cadword0x00daa83d总扇区数(total sectors)该分区中的扇区总数
发表评论