一乐电子

 找回密码
 请使用微信账号登录和注册会员

QQ登录

只需一步,快速开始

微信扫码登录

搜索
查看: 12166|回复: 3

硬盘主引导扇区、分区表和分区引导扇区(MBR、DPT、DBR、BPB)详解

[复制链接]
发表于 2010-3-19 22:11 | 显示全部楼层 |阅读模式
本帖最后由 kenson 于 2010-3-19 22:46 编辑 5 [5 Q& U- o! E- Z

8 ^/ Y* \! _+ v/ t- U5 X硬盘主引导扇区、分区表和分区引导扇区(MBR、DPT、DBR、BPB)详解!. |4 ^6 m- x6 Y6 c& a/ [! f
  硬盘的0柱面、0磁头、1扇区称为主引导扇区(也叫主引导记录MBR),该记录占用512个字节,它用于硬盘启动时将系统控制权转给用户指定的、在分区表中登记了某个操作系统分区。MBR的内容是在硬盘分区时由分区软件(如FDISK)写入该扇区的,MBR不属于任何一个操作系统,不随操作系统的不同而不同,即使不同,MBR也不会夹带操作系统的性质,具有公共引导的特性。但安装某些多重引导功能的软件或LINUX的LILO时有可能改写它;它先于所有的操作系统被调入内存并发挥作用,然后才将控制权交给活动主分区内的操作系统(图一)。
+ \% l2 i. v+ ~  r- V, a( l& |9 C9 B
  MBR由三部分构成:
& A) v/ W+ v- u% L  1.主引导程序代码,占446字节
, m2 @' o4 Z7 O0 W. s0 v  2.硬盘分区表DPT,占64字节7 X  U. _; v0 x
  3.主引导扇区结束标志AA55H" |* x/ d5 d" w* J$ V# Z
       一、硬盘的主引导程序代码是从偏移0000H开始到偏移01BDH结束的446字节;主引导程序代码包括一小段执行代码。启动PC 机时,系统首先对硬件设备进行测试,成功后进入自举程序INT 19H;然后读系统磁盘0柱面、0磁头、1扇区的主引导扇区MBR的内容到内存指定单元0:7C00 首地址开始的区域,并执行MBR程序段。* N3 Q6 K: Y6 O5 O, O& S
  主引导代码实现下列功能:% n2 b2 C& r- V5 v* C) o
  1.扫描分区表查找活动分区;
4 @1 o* u5 O3 p- S' P2 j; g  2.寻找活动分区的起始扇区;
0 M4 t- ^, @& t( C" Y# \# {  3.将活动分区的引导扇区读到内存;
; `% d1 w: e- a4 ~$ d0 g% o3 [, x9 X$ R  4.执行引导扇区的运行代码。
* e/ G' W4 s6 _" D; U  F2 U  如果主引导代码未完成这些功能,系统显示下列错误信息:
$ L. @- d2 W3 f: ^  Invalid partition table
" [1 a6 [6 [! {6 X8 h  Error loading operating system
$ x$ }% Q. \& l0 u3 H  Missing operating system5 c$ `5 p3 i. [+ y6 H
二、硬盘分区表DPT是从偏移01BEH开始到偏移01FDH结束的64字节(图二);硬盘分区表分为四小部分,每一小部分表示一个分区的信息,占16字节。在这里我们可以看出,硬盘的总分区数为什么不能大于4。其中可激活分区数不得大于3,扩展分区数不得大于1,当前活动分区数必须小于等于1。) D( q1 S/ f3 S' O5 \: `  L
- p) l; u' B1 z) ^3 C6 s
  分区表的每一分区的第0个字节是自举标志,其值为80H时,表示该分区是当前活动分区,可引导,其值为00H时,表示该分区不可引导。
7 u1 _# c8 n& r& F: f( W  第4字节是分区类型(图三)。2 g9 u0 H  P3 W0 I) ]

* _4 m7 ]7 M& _0 {  P3 I8 c; p
; }$ i9 V: i' L9 Z1 A+ Y  每一分区的第1至第3字节是该分区起始地址。其中第1字节为起始磁头号(面号);第2字节的低6位为起始扇区号,高2位则为起始柱面号的高2位;第3字节为起始柱面号的低8位。因此,分区的起始柱面号是用10位二进制数表示的,最大值为2^10 = 1024,因逻辑柱面号从0开始计,故柱面号的显示最大值为1023。同理,用6位二进制数表示的扇区号不会超过2^6 - 1 = 63;用8位二进制数表示的磁头号不会超过2^8 - 1 = 255。每一分区的第5至第7字节表示分区的终止地址,各字节的释义与第1至第3字节相同。这里我们假设一种极端的情况:如果让第5至第7字节的所有二进制位都取1,就获得了柱面号、磁头号和扇区号所能表示的最大值,从而得到最大绝对扇区号为:
$ k1 U9 B, C/ t1 X  1024 × 256 × 63 = 16,515,072% b" t  r2 j+ p4 q$ a
  这个扇区之前的所有物理扇区所包含的字节数为:
8 V5 r2 S$ j$ S) x+ s- p. ~9 W- B; r  16,515,072 × 512Bytes ≈ 8.46×109Bytes = 8.46GB。
( D' S6 G3 i# V0 Z! Y  y  由此可知硬盘的容量设计为什么会有8.4GB这一档,分区表每一分区的第1至第3字节以及第5至第7字节的数据结构已经不能满足大于8.46GB的大容量硬盘的需要。考虑到向下兼容的需要,业界并未对从DOS时代就如此定义的硬盘分区表提出更改意见,否则改动所牵涉的面太广,会造成硬件和软件发展上的一个断层,几乎无法被业界和用户所接受。硬盘厂商解决这一问题的方法是定义了新的INT 13服务扩展标准。新的INT 13服务扩展标准不再使用操作系统的寄存器传递硬盘的寻址参数,而使用存储在操作系统内存里的地址包。地址包里保存的是64位LBA地址,如果硬盘支持LBA寻址,就把低28位直接传递给ATA接口,如果不支持,操作系统就先把LBA地址转换为CHS地址,再传递给ATA接口。通过这种方式,能实现在ATA总线基础上CHS寻址的最大容量是136.9 GB,而LBA寻址的最大容量是137.4GB。新的硬盘传输规范ATA 133规范又把28位可用的寄存器空间提高到48位,从而支持更大的硬盘。$ m4 N. l2 |2 r+ C
分区表每一分区的第8至第11字节表示该分区的起始相对扇区数(即该扇区之前的绝对扇区个数),高位在右,低位在左;第12至第15字节表示该分区实际占用的扇区数,也是高位在右,低位在左;分区表这类数据结构的表达方式与机器中数据的实际存储方式在顺序上是一致的,即低位在前,高位在后。因此,在从16进制向十进制作数值转换时,需将字段中的16进制数以字节为单位翻转调位,用4个字节可以表示最大2^32个扇区,即2TB=2048GB。
) A+ V/ ^$ c: |4 E  系统在分区时,各分区都不允许跨柱面,即均以柱面为单位,这就是通常所说的分区粒度。在未超过8.4GB的分区上,C/H/S的表示方法和扇区数的表示方法所表示的分区大小是一致的。超过8.4GB的/H/S/C一般填充为FEH/FFH/FFH,即C/H/S所能表示的最大值;有时候也会用柱面对1024的模来填充。不过这几个字节是什么其实都无关紧要了。$ K" x# l, i( o
  扩展分区中的每个逻辑驱动器都存在一个类似于MBR的扩展引导记录(Extended Boot Record,EBR)(图四)。
# ?7 j/ [3 }2 Z4 y5 v* Q3 v+ i) `  z& M1 J2 \1 d

8 a$ ]  x5 B6 x1 E9 k  扩展引导记录包括一个扩展分区表和扇区结束标志55AA。一个逻辑驱动器中的引导扇区一般位于相对扇区32或63。如果磁盘上没有扩展分区,那么就不会有扩展引导记录和逻辑驱动器。第一个逻辑驱动器的扩展分区表中的第一项指向它自身的引导扇区;第二项指向下一个逻辑驱动器的EBR,如果不存在进一步的逻辑驱动器,第二项就不会使用,而被记录成一系列零。如果有附加的逻辑驱动器,那么第二个逻辑驱动器的扩展分区表的第一项会指向它本身的引导扇区,第二个逻辑驱动器的扩展分区表的第二项指向下一个逻辑驱动器的EBR。扩展分区表的第三项和第四项永远都不会被使用。- Y3 `+ P  F: c) K, L, J5 A
  扩展分区表项中的相对扇区数是从扩展分区开始的扇区到该逻辑驱动器中第一个扇区的扇区数;占用的扇区数是指组成该逻辑驱动器的扇区数目。' S9 X# Z) }( P) F# r
          有时候在磁盘的末尾会有剩余空间,由于分区是以1柱面的容量为分区粒度的,那么如果磁盘总空间不是整数个柱面的话,不够一个柱面的剩下的空间就是剩余空间了,这部分空间并不参与分区,所以一般无法利用。
2 R2 E! n+ W9 p三、主引导扇区的最后两个字节(偏移1FEH和偏移1FFH),其值为AA55H,它表示该扇区是个有效的引导扇区,可用来引导硬磁盘系统。0 f# m2 j! ?" ~# [
分区引导扇区DBR(DOS BOOT RECORD)是由FORMAT高级格式化命令写到该扇区的内容;DBR是由硬盘的MBR装载的程序段。DBR装入内存后,即开始执行该引导程序段,其主要功能是完成操作系统的自举并将控制权交给操作系统。每个分区都有引导扇区,但只有被设为活动分区的DBR才会被MBR装入内存运行。
/ o5 s" B$ C! e) YDBR主要由下列几个部分组成:/ a2 g( t) w; E2 U; T$ P4 `$ k
  1.跳转指令,占用3个字节的跳转指令将跳转至引导代码。
  p$ ^5 k* C& a  {: {  2.厂商标识和DOS版本号,该部分总共占用8个字节。( b9 x% u$ C$ N/ a$ Z7 D" K) Z
  3.BPB(BIOS Parameter Block, BIOS 参数块)。
  F0 Q% P1 o" x- ?- ~  4.操作系统引导程序。; X5 o) j/ `1 Y4 K, s( Q1 t
  5.结束标志字,结束标志占用2个字节,其值为AA55
4 J3 H8 M+ ^0 |" q  DBR中的内容除了第5部分结束标志字固定不变之外,其余4个部分都是不确定的,其内容将随格式化所用的操作系统版本及硬盘的逻辑盘参数的变化而变化。
# _0 m, |) J* f( B6 P% N" y  一、FAT32的分区引导扇区
5 }: U& }! K- f( Q  |6 D0 |  为了使加载文件的操作更加灵活,加上FAT32文件系统采用"活动"的FDT表,,同时考虑到引导程序的代码量和为今后发展保留适当的余量,FAT32文件系统分区引导扇区占据了6个扇区,只有前3个扇区作为系统的分区引导扇区,其余3个扇区保留暂未使用。分区引导扇区对于操作系统的启动和磁盘文件的访问具有至关重要的作用;引导程序代码的损坏将导致操作系统不能正常启动,磁盘读写参数的破坏将造成存储在磁盘上的文件不能正常读写。
; ^/ g: e5 D8 B7 B- H( b7 h# p  由于分区引导扇区的重要性,FAT32文件系统在在第一个分区引导扇区的6个扇区后的6个扇区里保留了分区引导扇区的备份,在启动时操作系统可以对两份引导扇区进行比较,以便选择正确的引导扇区来引导系统。由于在磁盘正常工作过程中系统不再对引导扇区的程序和数据进行修改,因此备份的分区引导扇区损坏的可能性非常小。; q5 F0 b) C" q! O( p0 ?+ b
分区引导扇区的第一个扇区(图六)的前三个字节是一条跳转指令,然后是8个字节长的OEM ID(厂家标识)和版本号,其后是简称为BPB的BIOS参数块(BIOS Parameter Block)。对于FAT32其各部分的意义如下表: . n- X/ P; F, H! G
偏移地址长度(字节)意    义
0BH2每个扇区的字节数,常取512
0DH1每簇扇区数;可以是1, 2, 4, 8, 16, 32, 64, 128,取决于文件系统格式及分区大小。
0EH2为操作系统保留的扇区数;FAT32时多为十进制的32,FAT16时为1,有的格式化工具可能将它设为36或63。
10H1FAT表的个数;常取2
11H2FAT16中存放系统根目录中允许登记的目录项个数,FAT32中用于标注系统采用的是否为FAT32文件系统。其值为0000H表示磁盘使用FAT32文件系统。
13H2值为00H,为保持兼容性而保留,未使用。
15H1磁盘介质标志,硬盘为F8
16H2未使用,值为00H
18H2每个磁道的扇区数。
1AH2磁盘的磁头数。
1CH4分区前隐藏扇区的个数。
20H4逻辑磁盘中的扇区总数。
24H4每个FAT表所占的扇区数。
28H2FAT表镜像标志,值为0表示系统保存2份互为备份的FAT表,值为1表示系统仅保存1FAT表。
2AH2文件系统的主次版本(保留)。
2CH4磁盘根目录的起始簇号。
30H2文件系统参数的扇区号,通常位于引导扇区的下一个扇区。
32H2备份分区引导扇区的逻辑扇区号。
34H12保留,未使用。
40H1中断13呼叫的预设值,指明访问的设备;软盘为00H,硬盘为80H。
41H1用于中断13呼叫。
42H1磁盘读写参数扩展标志,其值为29H
43H4格式化时随机产生的磁盘卷的序列号。
47H11格式化时人工输入的磁盘卷标号。
52H8文件系统的标识号(FAT32)。
; Z, G6 z" t$ E1 G8 D
  从偏移0x5A开始的数据为操作系统引导代码。这是由偏移0x00开始的跳转指令所指向的,此段指令在不同的操作系统上和不同的引导方式上,其内容也是不同的。  b! z: x' |# @
  扇区的最后两个字节存储值为0x55AA的DBR有效标志,对于其他的取值,系统将不会执行DBR相关指令。' F3 x3 C' l8 g7 w
& s+ d4 Y+ {7 W" ^6 f

. I* J# w' Q! u$ T分区引导扇区的第2个扇区作为文件系统相关参数存储标识扇区(图七),除了保存扇区的标识信息(RraA(00H)和rrAa(1E4H))外,还可能在偏移地址1E8H处存储了文件系统有关的信息。其中扇区偏移地址1E8H~1EBH的4个字节存储了逻辑磁盘中未使用的簇数,通常用于快速计算逻辑磁盘的剩余空间(典型的操作是在资源管理器状态栏上列出的"可用磁盘空间"参数),而1ECH~1EFH 4个字节给出了逻辑盘中下一个可以分配给文件使用的空闲簇的簇号,这样操作系统可以不访问FAT表就直接获得磁盘剩余空间和可以分配的簇号。[
# H$ k5 V3 k; ^. q$ c" e- n9 l, P% x
1 j* X1 w" \4 M
' p& U" v  ~8 a7 G& G, a2 c( }
  分区引导扇区的第3个扇区则存储了引导扇区的后一部分引导系统的程序代码(图八)。6 x/ Z) z3 _! A3 Z6 l6 x% f1 X0 n
+ Q3 A8 p6 C5 t$ ?/ G0 w  T; n

8 P6 B/ T1 l# n  ^8 v+ l( _- @, H
二、NTFS的分区引导扇区
3 I3 q" O/ D* a  P8 b5 ]/ I# }4 s3 H
  对于NTFS分区来说,分区引导扇区DBR只占用一个扇区(图五),并且在该分区的最后一个扇区做了备份;NTFS的引导扇区也是完成引导和定义分区参数,NTFS分区的引导扇区不是分区的充分条件,它要求必须MFT中的系统记录如$MFT等正常该分区才能正常访问。其BPB参数如下表所示:      
偏移地址长度(字节)常用值意  义
0x0B20x0002每扇区字节数
0x0D10x08每簇扇区数
0x0E20x0000保留扇区
0x1030x000000总为0
0x1320x0000NTFS未使用,为0
0x1510xF8 介质描述
0x1620x0000总为0
0x1820x3F00每磁道扇区数
0x1A20xFF00磁头数
0x1C40x3F000000隐藏扇区数
0x2040x00000000NTFS未使用,为0
0x2880x4AF57F0000000000扇区总数
0x3080x0400000000000000 $MFT的逻辑簇号
0x3880x54FF070000000000$MFT Mirr的逻辑簇号
0x4040xF6000000MFT记录簇数
0x44 40x01000000每索引簇数
0x4880x14A51B74C91B741C卷标
0x5040x00000000检验和& |) j. z6 ]9 l6 _& _4 P# j5 Q
 楼主| 发表于 2010-3-19 22:52 | 显示全部楼层
现在出现了利用MBR来传播病毒' z" J; K: I0 \$ B$ w7 f. d$ K

2 @* w) v9 |6 D; u0 L以前,常听用户说,中毒了没关系,大不了重装系统。但现在,这句话将成为历史。3月15日,金山安全实验室捕获一种被命名为"鬼影"的电脑病毒,该病毒寄生在磁盘主引导记录(MBR),即使格式化重装系统,也无法将该病毒清除。当系统再次重启时,该病毒会早于操作系统内核先行加载。而当病毒成功运行后,在进程中、系统启动加载项里找不到任何异常,病毒就象"鬼影"一样在中毒电脑上"阴魂不散"。
% T7 e6 u8 Y: y/ a$ H% q7 ?$ R: }8 h; u9 Y' _& v& t3 U
颠覆传统  重装系统无法清除" m" D9 E2 f7 v/ d2 f9 Q" `+ l

1 c8 j, V$ i, ]7 {' h. `金山安全反病毒专家表示,"一般的电脑病毒是Windows系统下的应用程序,在Windows加载之后才运行。而"鬼影"病毒的主要代码是寄生在硬盘的主引导记录(MBR),在电脑启动过程中先于系统核心程序直接加载到电脑内存中运行。对于已经寄生于MBR中的病毒,安全软件无法进行拦截。因病毒比安全软件的启动还要早。
6 h8 G' W/ ]- A% l' H0 k* B3 `5 e& s2 s
李铁军表示,"鬼影"病毒是国内首个引导区下载者病毒,颠覆了传统病毒的感染特点以及用户处理病毒问题的思维定势,不仅做到了"三无"特性--无文件、无系统启动项、无进程模块,而且即使用户重装了系统,该病毒依然会再次进入用户新系统;全新的病毒技术,突破了普通杀毒软件的自保护,"鬼影"病毒可以说是一个具有"划时代"特征的电脑病毒。3 I9 T! I3 i3 @2 W' U! E- H0 T
# k+ T. K# |7 c4 ?5 V4 I! e) c
安全软件失效 电脑明显变慢( l& |# n+ e! A
( U0 A5 Z+ F7 o4 ~" I( n/ i
金山安全实验室的研究人员分析发现,这个"鬼影"病毒是随某些共享软件捆绑安装进入电脑的,目前的日感染电脑约2-3万台。"鬼影"病毒入侵后,会释放驱动程序改写硬盘MBR(主引导记录),驱动程序在开机过程中攻击众多杀毒软件,令杀毒软件失效,再下载传统的AV终结者木马下载器,最终目的依然是通过传播盗号木马,窃取用户虚拟财产牟利。中毒后,最直观的现象是安全软件无法正常运行,电脑明显变慢,IE主页被改。
6 |2 ~+ T: t, f' E4 s' b9 q1 }* c1 |" I
罕见技术型病毒  源于国外5 A8 ^- ]% K! g( e) `! z$ Q0 L

: l9 G3 U5 C3 Z% s& j: n"鬼影"病毒是近年来较为罕见的技术型病毒,病毒作者具有高超的编程技巧。因WinXP系统的限制,一般手法改写MBR会被系统判定为非法,这也是引导区病毒接近消亡的重要因素。这种绕过Winxp的安全限制,直接改写MBR的技术主要在国外技术论坛传播,在"鬼影"病毒之前,这一技术少有被黑客实际大规模利用的案例。金山安全实验室工程师说,目前"鬼影"病毒只针对Winxp系统,该病毒尚不能破坏Vista和Windows 7系统。
( h% _' \! U% J7 Y% Q2 p
+ N' L4 s0 J0 O另据金山安全实验室研究人员透露,在目前国内安全厂商和民间反病毒高手中,能够完整分析"鬼影"病毒的人屈指可数。因病毒寄生于硬盘的主引导记录(MBR),病毒释放的驱动程序能够破坏大多数安全工具和系统辅助工具,在已经中毒的情况下,很难使用现有工具完成病毒清除,金山安全实验室正在编写针对"鬼影"病毒的专杀工具。# Y: E( f1 q& n. B
2 k$ ?9 u  i4 s4 j- z5 ~
金山毒霸已经升级,可查杀传播"鬼影"病毒的母体文件,避免更多用户受"鬼影"病毒之害,用户只需要在线升级即可获得相应防御能力。金山网盾已将传播该病毒的恶意网页加入阻止访问的列表,防止更多用户下载这个神秘的"鬼影"病毒。
回复

使用道具 举报

发表于 2010-3-26 15:26 | 显示全部楼层
这会不会是噱头?利用MBR和其后的保留扇区存放病毒体,造成无文件的表象,这个可以理解,但如何能先于系统加载,然后在系统加载后再将自身破坏和传染模块插入到系统模块中,并获得执行权,这有点不可思议。因为windows是动态加载的,不同的模块在不同条件下会加载到内存中不同的位置,软件、硬件条件一变,这个加载位置也会变的,不同配置的系统模块的多少也不同,而且系统文件都加有微软的数字签名,要把先于系统调入的破坏模块动态插入到系统中,并能获得调用,其复杂程度相当于一台“虚拟机”了,就是类似于vmware那样的,这个病毒得多大?
回复

使用道具 举报

 楼主| 发表于 2010-3-28 09:49 | 显示全部楼层
本帖最后由 kenson 于 2010-3-28 09:52 编辑 - ^0 [& @. K8 b  v/ Y$ f
1 f9 {6 P* J3 [3 G4 O
如果你对MBR和8086汇编的精通的话其实也不是不可能的! 主要修改MBR的引导程序去引导你自己的写的病毒程序到内存,第一个执行程序就是你的程序你想怎么样就怎么样了.还有你还要对XP的系统了如指掌才行,总之能懂这些的人真的是天才。
回复

使用道具 举报

本版积分规则

QQ|一淘宝店|手机版|商店|一乐电子 ( 粤ICP备09076165号 ) 公安备案粤公网安备 44522102000183号

GMT+8, 2025-8-20 12:13 , Processed in 0.040041 second(s), 21 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表