【教程】关于各种USB启动模式的解读 MBR、PBR

  [复制链接]

该用户从未签到

7

主题

51

回帖

90

积分

[INTOHARD]班长

Rank: 2

积分
90
发表于 2010-10-12 20:31:57 | 显示全部楼层 |阅读模式
1楼MBR介绍,2楼是分区PBR介绍。
(转载请注明出处:http://bbs.wuyou.com/viewthread.php?tid=166641&highlight=


系统开机或者重启过程:
BIOS 加电自检 ( Power On Self Test -- POST )。BIOS执行内存地址为 FFFF:0000H 处的跳转指令,跳转到固化在ROM中的自检程序处,对系统硬件(包括内存)进行检查。
读取主引导记录(MBR)。当BIOS检查到硬件正常并与 CMOS 中的设置相符后,按照 CMOS 中对启动设备的设置顺序检测可用的启动设备。BIOS将相应启动设备的第一个扇区(也就是MBR扇区)读入内存地址为0000:7C00H 处。
检查0000:7DFEH-0000:7DFFH(MBR的结束标志位)是否等于 AA55H,若不等于则转去尝试其他启动设备,如果没有启动设备满足要求则显示"NO ROM BASIC"然后死机。
当检测到有启动设备满足要求后,BIOS将控制权交给相应启动设备。启动设备的MBR将自己复制到0000:0600H处, 然后继续执行。
根据MBR中的引导代码启动引导程序。

1.MBR知识图:  硬盘主引导扇第一扇区(0柱面0磁头1扇区)

      硬盘的0柱面、0磁头、1扇区称为主引导扇区(也叫主引导记录MBR),该记录占用512个字节,它用于硬盘启动时将系统控制权转给用户指定的、在分区表中登记了某个操作系统分区。MBR的内容是在硬盘分区时由分区软件(如FDISK)写入该扇区的,MBR不属于任何一个操作系统,不随操作系统的不同而不同,即使不同,MBR也不会夹带操作系统的性质,具有公共引导的特性。但安装某些多重引导功能的软件或LINUX的LILO时有可能改写它;它先于所有的操作系统被调入内存并发挥作用,然后才将控制权交给活动主分区内的操作系统.
      天涯海角1216注:特殊形式的MBR会占用多个扇区,如Lvyanan的1JF9占用2个扇区,GRUB的MBR占用18个扇区,FBINST占用64个扇区,PloP Boot Manage 占用62个扇区(总共63个扇区)



2.分区引导扇区知识 (2楼有详细介绍)
    分区引导扇区DBR(DOS BOOT RECORD)是由FORMAT高级格式化命令写到该扇区的内容;DBR是由硬盘的MBR装载的程序段。DBR装入内存后,即开始执行该引导程序段,其主要功能是完成操作系统的自举并将控制权交给操作系统。每个分区都有引导扇区,但只有被设为活动分区的DBR才会被MBR装入内存运行。
DBR主要由下列几个部分组成:
 1.跳转指令,占用3个字节的跳转指令将跳转至引导代码。
 2.厂商标识和DOS版本号,该部分总共占用8个字节。
 3.BPB(BIOS Parameter Block, BIOS 参数块)。
 4.操作系统引导程序。
 5.结束标志字,结束标志占用2个字节,其值为AA55
 DBR中的内容除了第5部分结束标志字固定不变之外,其余4个部分都是不确定的,其内容将随格式化所用的操作系统版本及硬盘的逻辑盘参数的变化而变化。



    详细的MBR和分区PBR内容可参看:
【原创】HDD模式U盘双重MBR系列之—— PloP Boot Manage + FBINST(多版本.11.6更新)

3. 各种USB启动模式:
【1】、USB-HDD:(占用1个扇区)硬盘仿真模式,DOS启动后显示C:盘,HP(惠普) U盘格式化工具制作的U盘即采用此启动模式。此模式兼容性很高,但对于一些只支持USB-ZIP模式的电脑则无法启动。
电脑启动后首先读取此MBR,然后从指定的激活主分区启动(所以你要启动的分区必须激活,且有指定的引导文件存在),读入PBR引导扇区,再由引导扇区指定的引导文件,从而启动系统或PE或GRLDR等。。。。
常见引导过程为:MBR → 分区PBR → 引导文件(如:XP的NTLDR,VISTA的BOOTMGR ,GRUB的GRLDR。)

【2】、USB-HDD+:(占用1个扇区)增强的USB-HDD模式,DOS启动后显示C:盘,兼容性极高。其缺点在于对仅支持USB-ZIP的电脑无法启动。
电脑启动后首先读取此MBR,然后从指定的激活主分区启动,读入PBR引导扇区,再由引导扇区指定的引导文件,从而启动系统或PE或GRLDR等。。。。
引导过程为:MBR → 分区PBR → 引导文件

【3】、USB-ZIP:大容量软盘仿真模式,DOS启动后显示A盘,FlashBoot制作的USB-ZIP启动U盘即采用此模式。此模式在一些比较老的电脑上是唯一可选的模式,但对大部分新电脑来说兼容性不好,特别是大容量U盘。
引导过程为:分区PBR → 引导文件

【4】、USB-ZIP+::(占用1个扇区)增强的USB-ZIP模式,支持USB-HDD/USB-ZIP双模式启动(根据电脑的不同,有些BIOS在DOS启动后可能显示C:盘,有些BIOS在DOS启动后可能显示A:盘),从而达到很高的兼容性。其缺点在于有些支持USB-HDD的电脑会将此模式的U盘认为是USB-ZIP来启动,从而导致4GB以上大容量U盘的兼容性有所降低。
引导过程为:MBR → 分区PBR → 引导文件

【5】. USB-FDD:    是指把U盘模拟成软驱模式,启动后U盘的盘符是A:,
引导过程为:分区PBR → 引导文件

【6】、USB-CDROM:光盘仿真模式,DOS启动后可以不占盘符,兼容性比较高,新老主板一般都可以。优点可以像光盘一样使用(如,进行Windows系统安装)。缺点,把U盘量产成该模式时,我们将失去对这部分U盘空间的写权利,剩余空间会被识别成为一个独立的U盘,可以为Removable盘,当然也可以做成Fixed盘,进一步分区。制作时一般需要具体U盘型号/批号所对应的量产工具来制作,对于U盘网上有相应的量产工具。

【7】.FBINST:    (占用64个扇区)FBINST 在MBR的每个扇区(前64扇区)都写入了引导代码,并在每个扇区记录扇区号,这样无论U盘被识别为何种格式,都可以正常启动,启动的时候需要在1~64扇区读取计算好的信息,电脑就可以迅速而正确地获得参数,从而引导UD区的GRLDR,使得电脑正常启动。。。
引导过程为:MBR → UD区 → 引导文件

【8】.GRUB4DOS:(占用18个扇区,老版本占用16个扇区)是强大的引导程序,可以安装在MBR ,也可以安装在分区 PBR ,若安装在MBR,则可以搜索所有分区,启动其指定文件-GRLDR(不需读入分区PBR),从而正常启动。
引导过程为:MBR → grldr

【9】.  NT 5.x:       (占用1个扇区)此MBR依然是从激活的主分区启动,遇到多个激活分区就报分区表错误。
引导过程为:MBR → 分区PBR → 引导文件

【10】. NT 6.x:      (占用1个扇区)此MBR依然是从激活的主分区启动,支持多个激活分区,从第一个激活分区启动。
引导过程为:MBR → 分区PBR → 引导文件

【11】.PLoP Boot Manager(占用62个扇区)* 支持 USB 磁盘启动,其一是从 USB 介质上启动,也能转入到 USB 介质启动(无论 BIOS 是否支持 USB 启动)。从开发日志上看,对于 EHCI/OHCI/UHCI 三种接口是都支持的,但外接 USB HUB 还不支持。这个功能,的确激动人心,虽然之前看 Filo 里面有 USB 栈,是保护模式下的,而这个是实模式下的。 * 支持光盘启动这个是两层意思: 既能从光盘上启动,也能从其他介质启动后转入光驱启动。* 超小体积和对图形界面的支持,只有 40-50kb 的个头,但是能实现 USB 栈,和 cdrom mini 驱动的确是个奇迹,而它还包括了图形支持与启动特效。
引导过程为:MBR → 分区PBR → 引导文件




模式
MBR(主引导记录)

PBR(分区引导扇区)

备注说明
优点
缺点

    USB-HDD+
      USB-HDD+ /有MBR和分区表

过程:MBR → 分区PBR → 引导文件
NTLDR/GRLDR/SYSLINUX/BOOTMGR..
需激活主分区,从激活的主分区启动
(NTFS分区不支持SYSLINUX下同)

用UltraISO写入USB

兼容性很高,启动成功率很高


兼容性很高
对只支持USB-ZIP模式的电脑则无法启动
     USB-HDD

     USB-HDD /有MBR和分区表
过程:MBR → 分区PBR → 引导文件
NTLDR/GRLDR/SYSLINUX/BOOTMGR..
需激活主分区,从激活的主分区启动
用UltraISO写入USB

兼容性高

硬盘仿真模式,

兼容性较高

对仅支持USB-ZIP的电脑无法启动
     USB-ZIP+
              USB-ZIP+ /有MBR和分区表

过程:MBR → 分区PBR → 引导文件

NTLDR/GRLDR/SYSLINUX/BOOTMGR..
需激活主分区,从激活的主分区启动
用UltraISO写入USB

启动成功率很高
与USB-HDD+接近

支持USB-HDD/USB-ZIP双模式启动

仅支持USB-HDD的电脑会将此模式的U盘认为是USB-ZIP来启动,从而导致4GB以上大容量U盘的兼容性有所降低
     USB-ZIP

         无MBR和分区表
过程:分区PBR → 引导文件
直接从分区引导扇区启动
IO.SYS/NTLDR....

整个盘就是一个分区

用UltraISO写入USB


大容量软盘仿真模式

在一些比较老的电脑上是唯一可选的模式

但对大部分新电脑来说兼容性不好,特别是大容量U盘。
        USB-FDD
                       无MBR和分区表

过程:分区PBR → 引导文件
直接从分区引导扇区启动
IO.SYS/NTLDR....

整个盘就是一个分区

用UltraISO写入USB


软盘仿真模式

在一些比较老的电脑上是唯一可选的模式
启动兼容性差


    USB-CDROM

          光盘模式
整个盘就是一个分区
对应量产工具写入,光盘仿真模式,DOS启动后可以不占盘符,兼容性比较高,新老主板一般都可以。




采用量产U盘方式,有些电脑不支持



         NT 5.x

            NT 5.x /有MBR和分区表
过程:MBR → 分区PBR → 引导文件
NTLDR/GRLDR/SYSLINUX/BOOTMGR..
需激活主分区,只容许1个激活分区

从激活的主分区启动

用分区软件或BOOTICE写入
微软默认的主引导代码

2000、XP、2003等系统默认引导代码

兼容性一般

    NT 6.x
         NT 6.x /有MBR和分区表
过程:MBR → 分区PBR → 引导文件
NTLDR/GRLDR/SYSLINUX/BOOTMGR..
需激活主分区,容许多个激活分区

从第1个激活的主分区启动

用分区软件或BOOTICE写入
微软默认的主引导代码

2000、XP、2003等系统默认引导代码
兼容性一般



    grub4dos
       18个主引导扇区 /有MBR和分区表
过程:MBR  → grldr
不需要分区引导
从任意分区根目录grldr启动

用bootlace或BOOTICE写入
需在某分区根目录有grldr文件


可以搜索U盘、硬盘根目录的grldr

兼容性一般
       FBINST
有MBR和分区表 / 前64个扇区一样的引导代码,在主数据区的每个扇区尾部记录扇区号
过程:MBR → UD区→ grldr
无需分区引导
从GRLDR能够识别的UD区文件启动
用fbinst或 FbinstTool写入

目前最强大的USB引导模式,仍在增强中

启动兼容性最高
有个防毒的UD区
1.前64个扇区都有主引导代码
2. C.H.S寻址非常准确






   PLoP Boot

   Manager
              占用62个扇区 /有MBR和分区表

可以实现U盘多分区引导,很酷的图形启动界面

过程:MBR → 分区PBR → 引导文件
NTLDR/GRLDR/SYSLINUX/BOOTMGR..
需激活主分区,从激活的主分区启动




无USB和CDROM、FDD选项的电脑增加支持!




老电脑硬盘上安装,可增加USB启动支持

USB介质上安装,启动兼容性一般















4. 各种模式兼容性顺序(由强到弱):

1.  fbinst      2.  USB-HDD+       3.  USB-ZIP+       4.  USB-CDROM        5.  USB-HDD       6.  USB-ZIP    7.  USB-FDD/NT5/6/GRUB/PLOP


不足和错误之处,请各位批评指正!
(查看扇区的方法看57楼)

该用户从未签到

7

主题

51

回帖

90

积分

[INTOHARD]班长

Rank: 2

积分
90
 楼主| 发表于 2010-10-12 20:35:31 | 显示全部楼层
分区PBR详解:
分区引导扇区知识

一、FAT32的分区引导扇区

分区引导扇区DBR(DOS BOOT RECORD)是由FORMAT高级格式化命令写到该扇区的内容;DBR是由硬盘的MBR装载的程序段。DBR装入内存后,即开始执行该引导程序段,其主要功能是完成操作系统的自举并将控制权交给操作系统。每个分区都有引导扇区,但只有被设为活动分区的DBR才会被MBR装入内存运行。
DBR主要由下列几个部分组成:
 1.跳转指令,占用3个字节的跳转指令将跳转至引导代码。(天涯海角1216注:看下图,以FAT32为例,EB 58 指跳转至偏移5A执行,即从图中 FA 33 .. 开始执行引导程序)
 2.厂商标识和DOS版本号,该部分总共占用8个字节。
 3.BPB(BIOS Parameter Block, BIOS 参数块)。       (天涯海角1216注:这个包含BIOS操作的参数,很重要,破坏将显示分区错误)
 4.操作系统引导程序。                             (天涯海角1216注:该分区若需引导,则由该程序决定引导文件或系统)
 5.结束标志字,结束标志占用2个字节,其值为AA55。     (天涯海角1216注:很重要,若为00 00 ,则显示未格式化)
 DBR中的内容除了第5部分结束标志字固定不变之外,其余4个部分都是不确定的,其内容将随格式化所用的操作系统版本及硬盘的逻辑盘参数的变化而变化。




FAT32的BPB参数如下表所示:
(天涯海角1216注:FAT32中,BPB即指从偏移0B到偏移59止。其他略有不同,BPB 都是指跳转指令跳转位置之前的一段代码。)




分区引导扇区的第2个扇区作为文件系统相关参数存储标识扇区(下图),除了保存扇区的标识信息(RraA(00H)和rrAa(1E4H))外,还可能在偏移地址1E8H处存储了文件系统有关的信息。其中扇区偏移地址1E8H~1EBH的4个字节存储了逻辑磁盘中未使用的簇数,通常用于快速计算逻辑磁盘的剩余空间(典型的操作是在资源管理器状态栏上列出的"可用磁盘空间"参数),而1ECH~1EFH 4个字节给出了逻辑盘中下一个可以分配给文件使用的空闲簇的簇号,这样操作系统可以不访问FAT表就直接获得磁盘剩余空间和可以分配的簇号。




二、NTFS的分区引导扇区
  对于NTFS分区来说,分区引导扇区DBR只占用一个扇区(下图),并且在该分区的最后一个扇区做了备份;NTFS的引导扇区也是完成引导和定义分区参数,NTFS分区的引导扇区不是分区的充分条件,它要求必须MFT中的系统记录如$MFT等正常该分区才能正常访问






NTFS的BPB参数如下表所示:




三、各类分区引导扇区列举





    类型

      占用扇区
                   BPB表
             引导文件
     优点
     缺点

     NTFS


16

从偏移00到偏移53止,偏移54开始是分区引导代码,直至该扇区结束标志55AA止。
其后紧随15个扇区,可以随意用。

若是启动分区,则其代码很重要,起到引导系统文件作用,若是非启动分区,则无所谓。

如常见的系统引导代码:NTLDR 、BOOTMGR 、GRLDR 等


文件加密、磁盘压缩、安全、产生的磁盘碎片少




    FAT32


1(约32个保留扇区)


从偏移00到偏移59止,偏移5A开始是分区引导代码,直至该扇区结束标志55AA止。
其后隔一个扇区后,有30个扇区可以随意用。

若是启动分区,则其代码很重要,起到引导系统文件作用,若是非启动分区,则无所谓。

如常见的系统引导代码:NTLDR 、BOOTMGR 、GRLDR 、IO.SYS 、SYSLINUX等


FAT16的增强版本,FAT32使用的簇比FAT16小,有效地节约了硬盘空间。
单个文件不能超过4G,产生的磁片碎片很多


    FAT16

1(约8个保留扇区)

从偏移00到偏移49止,偏移4A开始是分区引导代码,直至该扇区结束标志55AA止。
其后紧随7个扇区,可以随意用。


同上







    FAT12


1(约8个保留扇区)


从偏移00到偏移4D止,偏移4E开始是分区引导代码,直至该扇区结束标志55AA止。
其后紧随7个扇区,可以随意用。

同上
















































































































[ 本帖最后由 天涯海角1216 于 2010-8-1 18:02 编辑 ]
回复 支持 反对

使用道具 举报

该用户从未签到

7

主题

51

回帖

90

积分

[INTOHARD]班长

Rank: 2

积分
90
 楼主| 发表于 2010-10-12 20:36:53 | 显示全部楼层
本人来自“无忧启动论坛”,此文最先发表于“无忧启动论坛”
如有错误之处,请各位批评指正!
回复 支持 反对

使用道具 举报

该用户从未签到

6

主题

154

回帖

1854

积分

[INTOHARD]营长

Rank: 6Rank: 6

积分
1854
发表于 2010-10-16 00:36:16 | 显示全部楼层
好详细呀!ZL!  辛苦了!
回复 支持 反对

使用道具 举报

该用户从未签到

2

主题

133

回帖

1918

积分

[INTOHARD]营长

Rank: 6Rank: 6

积分
1918
发表于 2010-10-26 16:31:44 | 显示全部楼层
好东西 谢谢了
回复 支持 反对

使用道具 举报

  • TA的每日心情
    奋斗
    2014-6-17 08:54
  • 签到天数: 13 天

    [LV.3]八品县丞

    0

    主题

    103

    回帖

    336

    积分

    [INTOHARD]排长

    Rank: 3Rank: 3

    积分
    336
    QQ
    发表于 2010-10-30 21:33:33 | 显示全部楼层
    为什么发俩遍啊……
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    5

    主题

    388

    回帖

    553

    积分

    [INTOHARD]连长

    Rank: 4

    积分
    553
    发表于 2010-11-12 20:44:59 | 显示全部楼层
    好东西 谢谢了
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    开心
    2021-4-15 16:36
  • 签到天数: 504 天

    [LV.9]二品侍郎

    25

    主题

    1427

    回帖

    8万

    积分

    [INTOHARD]师长

    Rank: 10Rank: 10Rank: 10

    积分
    86907
    发表于 2010-12-7 12:08:06 | 显示全部楼层
    顶一下,顺便学习一下
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    0

    主题

    33

    回帖

    61

    积分

    [INTOHARD]班长

    Rank: 2

    积分
    61
    发表于 2011-10-27 14:53:45 | 显示全部楼层
    很受用,非常感谢楼主
    回复 支持 反对

    使用道具 举报

  • TA的每日心情

    2017-11-14 09:43
  • 签到天数: 4 天

    [LV.2]九品芝麻官

    0

    主题

    84

    回帖

    160

    积分

    [INTOHARD]班长

    Rank: 2

    积分
    160
    QQ
    发表于 2011-12-28 17:36:30 | 显示全部楼层
    很详细,获益匪浅,谢谢楼主分享。
    回复 支持 反对

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

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