本帖最后由 kenson 于 2010-2-22 12:23 编辑 4 J& e. g9 O" E9 H: F; i( i
. ?% O, Y2 d4 r+ x( C我对硬盘MBR、DBR、BPB、FAT和FDT的理解(gliethttp) m0 w1 Q; l2 A m
文章来源:http://gliethttp.cublog.cn[转载请声明出处]
I; j6 b: E* R9 h! ^1 j0 m5 _
/ s( g: n9 Y9 W/ } 硬盘存储数据是根据电、磁转换原理实现的。硬盘由一个或几个表面镀有磁性物质的金属或玻璃等物质盘片以及盘片两面所安装的磁头和相应的控制电路组成(图1),其中盘片和磁头密封在无尘的金属壳中。
+ I$ L. T/ m' n: I! y硬盘工作时,盘片以设计转速高速旋转,设置在盘片表面的磁头则在电路控制下径向移动到指定位置然后将数据存储或读取出来。当系统向硬盘写入数据时,磁头中“写数据”电流产生磁场使盘片表面磁性物质状态发生改变,并在写电流磁场消失后仍能保持,这样数据就存储下来了;当系统从硬盘中读数据时,磁头经过盘片指定区域,盘片表面磁场使磁头产生感应电流或线圈阻抗产生变化,经相关电路处理后还原成数据。因此只要能将盘片表面处理得更平滑、磁头设计得更精密以及尽量提高盘片旋转速度,就能造出容量更大、读写数据速度更快的硬盘。这是因为盘片表面处理越平、转速越快就能越使磁头离盘片表面越近,提高读、写灵敏度和速度;磁头设计越小越精密就能使磁头在盘片上占用空间越小,使磁头在一张盘片上建立更多的磁道以存储更多的数据。
, p/ R; Q3 u* Q1 A: e 硬盘由很多盘片(platter)组成,每个盘片的每个面都有一个读写磁头。如果有N个盘片。就有2N个面,对应2N个磁头(Heads),从0、1、2开始编号。每个盘片被划分成若干个同心圆磁道(逻辑上的,是不可见的。)每个盘片的划分规则通常是一样的。这样每个盘片的半径均为固定值R的同心圆再逻辑上形成了一个以电机主轴为轴的柱面(Cylinders),从外至里编号为0、1、2……每个盘片上的每个磁道又被划分为几十个扇区(Sector),通常的容量是512byte,并按照一定规则编号为1、2、3……形成Cylinders×Heads×Sector个扇区。这三个参数即是硬盘的物理参数。 [摘自:《FAT文件系统原理》]
3 R% f1 `) h2 r: P. O0 T以下为我的理解(gliethttp)4 L1 N. L' v" h6 \1 Y. t$ z2 F' J- V
Cylinders柱面个数为同心不同径的磁道个数$ `- N# ^! u2 q+ j# j- u
Heads磁头个数为一个存放Cylinders个磁道的存储介质表面的面数# L6 [# u% |% L, n% @
Sector就是一个磁道上的扇区个数# u ?7 Q, g% Q7 h- J" E" Z) \* Q
所以Cylinders×Heads×Sector就是这个物理硬盘的扇区总数.* Y3 {" ~) ~* K* w' f6 E) d9 D$ ~
MBR->DPT
$ R! S6 }# M# h$ g" _- c- Y主分区1-->起始扇区DBR[包括BPB和扩展BPB]-->FAT1-->FAT2-->FDT-->数据区$ `6 R3 _2 s6 [' y! p5 v
主分区2-->下一个扩展分区信息描述/ ^( y& I O+ }2 v! l) J
主分区3
9 n4 `5 T. Q+ T: _主分区4( a! a D: s- a1 t- b; B
MBR-->位于绝对的第0扇区/ J6 }8 C i8 S+ w# s
MBR的引导程序占了其中的前446个,紧接着的后64个字节是硬盘分区表DPT,最后2个字节是"55 AA",为磁盘有效结尾标志值0 k$ z1 b6 S( ]6 E; |7 ]8 M* D. e: y
[0x000~0x1BD]存放MBR--对于pc电脑bios执行完自举之后,会将cpu控制权交给此间的最大446个字节的loader程序
' I/ d$ A7 D: [* e! Z# A0 s& V* { [0x1BE~0x1FD]存放MBR--DPT硬盘分区表,每16个字节描述一个主分区,根据分区类型字节域,我们可以知道该分区类型
9 r* d. x4 _" U4 p5 d+ Y 所以pc上主分区最多只能有4个.[gliethttp]
& ^) h( a4 _5 X6 q6 w8 [! w(注:DPT中对于>1字节的组合类型数据的存储,按小端模式[little endian]存储)! |: m: S8 N4 M8 X+ q
几个常见的分区类型值:# R3 V& j: B) ^" \- k1 M4 t
0x01 --- FAT32: x9 K6 Y# p4 _3 P* w4 L
0x04 --- FAT16<32M
Q& ]" L2 c8 `" L8 }; k0x05 --- Extended(扩展分区)
& M, Z) n5 i2 D* _" e1 G- y( b0x06 --- FAT16
$ ~- [# j r6 P4 [" o0x07 --- NTFS/ A9 X- y) B: G4 n' O
0x0B --- WIN95 FAT32
8 W! E: G; t7 \0 \5 x0x0C --- WIN95 FAT32
% k6 |& K' J2 i) ?# d+ J0x0E --- WIN95 FAT16
5 {1 d$ b$ b* B2 |0 E& ?+ r0x0F --- WIN95 Extended>8GB
5 q: q7 I( J0 H, m r& P, h9 A$ I0x11 --- Hidden FAT126 k2 Z6 i' b8 C0 A' d
0x14 --- Hidden FAT16<32GB
# |9 ~& p5 ?" d, ]& F/ }0x16 --- Hidden FAT162 A1 x0 Q2 n4 i* G4 _: B3 U
0x17 --- Hidden NTFS1 J+ k8 `& K- D/ @/ e- B. u7 A8 g
0x1B --- Hidden FAT322 [. f, E9 U. W" i* i& h$ D
0x82 --- Linux swap9 i6 c H ~/ x4 {: u
0x83 --- Linux- L: q$ O' i4 ? K
0x85 --- Linux extended
1 Y$ Q: U, n) u; }0 o0xA6 --- Open BSD& q8 y- p- c- X4 @ K. a
pc执行完bios之后,将cpu控制权交给MBR的前446个字节的loader程序,位于MBR中的loader程序会加载活动主分区对应的DBR区,即—操作系统
% e* i3 d" I W5 @: a* C( G5 `启动程序,之后MBR将cpu控制权交给DBR,所以DBR的第1个扇区的前3个字节必须对应x86的跳转指令”E8 58 90”,该指令负责跳过接下来的几个不可执行的字节(BPB和扩展BPB),跳到操作系统引导代码部分。
* E! O8 |2 Q( A- S5 h {DBR位于当前分区的起始扇区,比如c盘的第1个起始扇区地址,就是c盘对应的DRB区,% O0 U5 u. a7 M" I: @$ C
同样D盘的第1个起始扇区地址,就是D盘对应的DBR区,; y& [3 F* i8 [0 C; u
对于usb盘,也一样,usb的第1个起始扇区就是该U盘的DBR区% B7 _5 v$ Z$ R0 g" A
DBR的BPB区域描述本分区的大小,起始、终止磁盘、柱面、扇区号以及细分内容:fat的个数、每扇区字节数、
6 X! Y) n C5 u- v. ?7 x/ X每簇扇区数、当前分区保留扇区数、根目录FDT项数、本分区对应的存储介质类型、每个fat需要的扇区数、
0 f4 ?- I6 `4 G- N+ l/ @总扇区数、根目录FDT簇号等
6 h. R, _% A5 i9 @- n3 }$ B& hBPB地址 ---0x0B~0x407 X) |# x. v! B% L3 g% k& ]' H7 Y
扩展BPB地址 ---0x40~0x577 B. q- F O- X% f0 {
还记得前面提到的x86跳转指令”E8 58 90”吧,这个指令翻译过来就是从指令处开始向后跳转几个字节到0x5A处继续执行程序,
0 v$ o0 }# N% M, ^# B所以DBR的0x5A处开始存放了windows操作系统的引导代码,DBR扇区的最后两个字节一般存储值为0x55AA的DBR有效标志,
, Z; _/ L6 p; m, e如果是其他值,系统将不会执行DBR中的操作系统引导代码.! h6 K' Z0 c9 c: E' r
还有一个知识点,就是“保留扇区”(也叫“隐藏扇区”或“系统扇区”),“保留扇区”指从管理本逻辑磁盘,如C盘:D盘:U盘等的DBR! {% @1 F) Q% F( Y; M7 a0 b
扇区开始的供当前逻辑盘使用的用来描述本逻辑盘信息或者操作系统启动代码之类数据的扇区总数.
+ i: o" m ^+ G) c7 s" Z' A: G5 x对于DBR管理的当前分区,如:C盘、D盘等来说,DBR所在的扇区为相对于当前分区的0扇区,
* U1 x: J1 D G- F' u9 F3 j所以使用winhex,打开整个硬盘时, 看到的是该硬盘的绝对地址[gliethttp]+ i! V# @* }- `% @; m s6 O
即:第0扇区为MBR,第63扇区为C盘的DBR,对于我的硬盘还有D、E和F
0 x! y+ S- U. p- o% h. A% b KC盘:分区表DPT---0扇区 ,它对应的DBR扇区---DPT+63=63扇区
: B- c0 S# ^& E% Q/ x$ q2 eD盘:分区表DPT---81931500扇区(无用) ,它对应的DBR扇区---DPT+63=81931563扇区
i, A' u9 c: |E盘:分区表DPT---163863000扇区(无用),它对应的DBR扇区---DPT+63=163863063扇区
7 [; w c4 b# ?9 KDBR又叫做该分区盘的起始扇区,在绝对地址下, 该分区盘的DBR就是绝对偏移扇区值,8 M- [/ y; O. Q
使用winhex打开该分区盘(如D盘)之后,DBR在该分区盘(如D盘)内部的相对扇区值为0,3 k: N! {) s. J5 Y; z0 S/ m3 p% S
我的硬盘中[gliethttp]4 y' o1 f! \7 ? [1 g: A. ^ r
C盘的DBR相对扇区为0 [$ x) a9 ~# o& a `
C盘的FAT1相对C盘的扇区偏移值为34
, ^ t0 E* }+ o) j) f8 A9 xD盘的DBR相对扇区为0
, S/ T( X( W# D" n5 vD盘的FAT1相对D盘的扇区偏移值为34, B; w: r% K! s4 M8 f% r
E盘的DBR相对扇区为04 B3 \- u: r- Y( R8 y4 |0 ^ p
E盘的FAT1相对E盘的扇区偏移值为386 Q6 ]$ j. e( s$ V+ d, i
U盘的DBR相对扇区为0
, s6 }! b, ~4 @; o, t/ UU盘的FAT1相对U盘的扇区偏移值为36
& d0 p& m7 U. x2 V! ?以上这些偏移值都在每个分区盘的DBR中的BPB里有描述.
; E7 f' A+ @' }% u8 E. p2 ghttp://blogimg.chinaunix.net/blog/upfile/070920165541.jpg(winhex操作图例1)http://blogimg.chinaunix.net/blog/upfile/070920165624.jpg(进入C盘之后,DBR即起始扇区为相对地址0) http://blogimg.chinaunix.net/blog/upfile/070920165656.jpgwinhex操作图例2http://blogimg.chinaunix.net/blog/upfile/070920165624.jpg(进入D盘之后,DBR即起始扇区为相对地址0) 虽然进入D盘或E盘等分区盘之后使用winhex打开的“起始扇区(模板)”的DBR相对地址不一样,但实际上都是指向同一个绝对物理地址,% Q- f# D; f' C! M; C# |: W" V( j
DBR的内容都是一样的. 对于存在扩展分区的硬盘,比如我的硬盘有C、D、E和F共4个盘符
$ W4 {6 z# {. i2 N: ?/ \那么C盘将真正的使用硬盘的MBR,对于扩展分区是如何被系统识别的,以及他们之间是如何串联起来的,
/ u( y$ r: u1 O$ [4 P U4 K有这样一个规定,使用MBR的第2个主分区作为下一个扩展分区相对与本分区的偏移扇区描述体4 ^8 ]1 v! G. l$ y9 c
那么如果在扩展分区中,也没有MBR啊,是的,所以我们虚拟出一个MBR,认为下一个扩展分区是一个虚拟的物理硬盘,它也存在MBR# ^* I D+ _$ j# N2 ~' K( z
这样在虚拟MBR中只需要填写第2个主分区,即这个扩展分区对应的下一个扩展分区的偏移扇区描述体即可,这样循环下去.2 E. _- \' z4 _7 u% _; C% _
http://blogimg.chinaunix.net/blog/upfile/070920165906.jpg http://blogimg.chinaunix.net/blog/upfile/070920165925.jpg http://blogimg.chinaunix.net/blog/upfile/070920165953.jpg |