跳至內容

主開機紀錄

本頁使用了標題或全文手工轉換
維基百科,自由的百科全書

主開機紀錄(英語:Master Boot Record,縮寫:MBR),又叫做主引導磁區,是電腦開機後訪問硬碟時所必須要讀取的首個磁區,它在硬碟上的三維位址為(柱面,磁頭,磁區)=(0,0,1)。在深入討論主引導磁區內部結構的時候,有時也將其開頭的446位元組內容特指為「主開機紀錄」(MBR),其後是4個16位元組的「磁碟分割區表」(DPT),以及2位元組的結束標誌(55AA)。因此,在使用「主開機紀錄」(MBR)這個術語的時候,需要根據具體情況判斷其到底是指整個主引導磁區,還是主引導磁區的前446位元組。

標準MBR結構
位址 描述 長度
位元組
Hex Oct Dec
0000 0000 0 代碼區 440
(最大446)
01B8 0670 440 選用磁碟標誌 4
01BC 0674 444 一般為空值; 0x0000 2
01BE 0676 446 標準MBR分割區表規劃
(四個16 byte的主分割區表入口)
64
01FE 0776 510 55h MBR有效標誌:
0x55AA
2
01FF 0777 511 AAh
MBR,總大小:446 + 64 + 2 = 512

主引導磁區記錄著硬碟本身的相關資訊以及硬碟各個分割區的大小及位置資訊,是資料資訊的重要入口。如果它受到破壞,硬碟上的基本資料結構資訊將會遺失,需要用繁瑣的方式試探性的重建資料結構資訊後才可能重新訪問原先的資料。主引導磁區內的資訊可以通過任何一種基於某種作業系統的分割區工具軟體寫入,但和某種作業系統沒有特定的關係,即只要建立了有效的主開機紀錄就可以引導任意一種作業系統(作業系統是建立在進階格式化硬碟分割區之上,是和一定的檔案系統相聯絡的)。

對於硬碟而言,一個磁區可能的位元組數為128×2n(n=0,1,2,3)。大多情況下,取n=2,即一個磁區(sector)的大小為512位元組。

主開機紀錄的組成

[編輯]

啟動代碼

[編輯]

主開機紀錄最開頭是第一階段引導代碼。其中的硬碟引導程式的主要作用是檢查分割區表是否正確並且在系統硬體完成自檢以後將控制權交給硬碟上的引導程式(如GNU GRUB)。它不依賴任何作業系統,而且啟動代碼也是可以改變的,從而能夠實現多系統引導

硬碟分割區表

[編輯]
硬碟分割區結構資訊
偏移 長度(位元組) 意義
00H 1 分割區狀態:00-->非活動分割區;80-->活動分割區;
其它數值沒有意義
01H 1 分割區起始磁頭號(HEAD),用到全部8位元
02H 2 分割區起始磁區號(SECTOR),占據02H的位0-5;
該分割區的起始磁柱號(CYLINDER),占據
02H的位6-7和03H的全部8位元
04H 1 檔案系統標誌位
05H 1 分割區結束磁頭號(HEAD),用到全部8位元
06H 2 分割區結束磁區號(SECTOR),占據06H的位0-5;
該分割區的結束磁柱號(CYLINDER),占據
06H的位6-7和07H的全部8位元
08H 4 分割區起始相對磁區號
0CH 4 分割區總的磁區數

硬碟分割區表占據主引導磁區的64個位元組(偏移01BEH--偏移01FDH),可以對四個分割區的資訊進行描述,其中每個分割區的資訊占據16個位元組。具體每個位元組的定義可以參見硬碟分割區結構資訊。下面是一個例子:

如果某一分割區在硬碟分割區表的資訊如下

80 01 01 00 0B FE BF FC 3F 00 00 00 7E 86 BB 00

則我們可以看到,最前面的"80"是一個分割區的啟用標誌,表示系統可引導[1];"01 01 00"表示分割區開始的磁頭號為1,開始的磁區號為1,開始的柱面號為0;"0B"表示分割區的系統類型是FAT32,其他比較常用的有04(FAT16)、07(NTFS);"FE BF FC"表示分割區結束的磁頭號為254,分割區結束的磁區號為63、分割區結束的柱面號為764;"3F 00 00 00"表示首磁區的相對磁區號為63(小端序);"7E 86 BB 00"表示總磁區數為12289662(小端序)。

對於大於8.4G的現代硬碟,CHS已經無法表示,BIOS使用LBA模式,對於超出的部分,CHS值通常設為0xFEFFFF,並加以忽略,直接使用Offset 0x08-0x0c的4位元組相對值,再進行內部轉換。

結束標誌字

[編輯]

結束標誌字55,AA(偏移1FEH-偏移1FFH)最後兩個位元組,是檢驗主開機紀錄是否有效的標誌。

主引導磁區的讀取流程

[編輯]
  • 系統開機或者重新啟動。
  1. BIOS加電(台灣用語:開機)自檢(Power On Self Test -- POST)。BIOS執行主記憶體位址為FFFF:0000H處的跳轉指令,跳轉到固化在ROM中的自檢程式處,對系統硬體(包括主記憶體)進行檢查。
  2. 讀取主開機紀錄(MBR)。當BIOS檢查到硬體正常並與CMOS中的設定相符後,按照CMOS中對啟動裝置的設定順序檢測可用的啟動裝置。BIOS將相應啟動裝置的第一個磁區(也就是MBR磁區)讀入主記憶體位址為0000:7C00H處。
  3. 檢查0000:01FEH-0000:01FFH(MBR的結束標誌位)是否等於55AAH,若不等於則轉去嘗試其他啟動裝置,如果沒有啟動裝置滿足要求則顯示"NO ROM BASIC"然後當機。
  4. 當檢測到有啟動裝置滿足要求後,BIOS將控制權交給相應啟動裝置。啟動裝置的MBR將自己複製到0000:0600H處,然後繼續執行。
  5. 根據MBR中的引導代碼啟動引導程式
  • 事實上,BIOS不僅檢查0000:01FEH-0000:01FFH(MBR的結束標誌位)是否等於55AAH,往往還對磁碟是否有防寫、主引導磁區中是否存在活動分割區等進行檢查。如果發現磁碟有防寫,則顯示磁碟防寫出錯資訊;如果發現磁碟中不存在活動分割區,則顯示類似如下的資訊「Remove disk or other media Press any key to restart」。

主開機紀錄與硬碟分割區

[編輯]

主開機紀錄的結構可以知道,它僅僅包含一個64個位元組的硬碟分割區表。由於每個分割區資訊需要16個位元組,所以對於採用MBR型分割區結構的硬碟,最多只能辨識4個主要分割區(Primary partition)。所以對於一個採用此種分割區結構的硬碟來說,想要得到4個以上的主要分割區是不可能的。這裡就需要引出擴充分割區了。擴充分割區也是主要分割區的一種,但它與主分割區的不同在於理論上可以劃分為無數個邏輯分割區。[2]

擴充分割區中邏輯驅動器的引導記錄是鏈式的。每一個邏輯分割區都有一個和MBR結構類似的擴充引導記錄(EBR),其分割區表的第一項指向該邏輯分割區本身的引導磁區,第二項指向下一個邏輯驅動器的EBR,分割區表第三、第四項沒有用到。

Windows系統預設情況下,一般都是只劃分一個主分割區給系統,剩餘的部分全部劃入擴充分割區。這裡有下面幾點需要注意:

  • 在MBR分割區表中最多4個主分割區或者3個主分割區+1個擴充分割區,也就是說擴充分割區只能有一個,然後可以再細分為多個邏輯分割區。
  • Linux系統中,硬碟分割區命名為sda1-sda4或者hda1-hda4(其中a表示硬碟編號可能是a、b、c等等)。在MBR硬碟中,分割區號1-4是主分割區(或者擴充分割區),邏輯分割區號只能從5開始。
  • 在MBR分割區表中,一個分割區最大的容量為2T,且每個分割區的起始柱面必須在這個disk的前2T內。你有一個3T的硬碟,根據要求你至少要把它劃分為2個分割區,且最後一個分割區的起始磁區要位於硬碟的前2T空間內。[3]如果硬碟太大則必須改用GPT

MBR分割區表與GPT分割區表的關係

[編輯]

與支援最大卷為2 TB(Terabytes)並且每個磁碟最多有4個主分割區(或3個主分割區,1個擴充分割區和無限制的邏輯驅動器)的MBR磁碟分割區的樣式相比,GPT磁碟分割區樣式支援最大為128個分割,一個分割最大18 EB(Exabytes),只受到作業系統限制(由於分割區表本身需要占用一定空間,最初規劃硬碟分割區時,留給分割區表的空間決定了最多可以有多少個分割區,IA-64版Windows限制最多有128個分割區,這也是EFI標準規定的分割區表的最小尺寸)。與MBR分割區的磁碟不同,至關重要的平台運算元據位於分割區,而不是位於非分割區或隱藏磁區。另外,GPT分割區磁碟有備份分割區表來提高分割區資料結構的完整性。在UEFI系統上,通常是通過ESP分割區中的EFI應用程式檔案啟動GPT硬碟上的作業系統,而不是活動主分割區上的引導程式。

注釋

[編輯]
  1. ^ 對於一個作業系統而言,系統分割區設為活動分割區並不是必須的,這主要視引導程式而定,如果使用的引導程式是Grub4Dos,MBR中的引導代碼僅僅按照分割區的順序依次探測第二階段引導器grldr的位置,並執行第一個探測到的grldr檔案。
  2. ^ 一個硬碟的分割區個數還要受到分割區大小的限制,因為硬碟是按照柱面分割區的:一個分割區至少要占一個柱面。但有一點需要注意,由於現在的硬碟結構已經和老式硬碟有了很大區別,其定址結構也不再是CHS定址,所以這裡的柱面大小不同於相關軟體顯示的柱面大小。對於物理結構上有n個面的硬碟,其分割區空間的最小值為:n ×磁區/磁軌× 512位元組。
  3. ^ 根據16位元組分割區表的結構:當前分割區的磁區數用4個位元組表示,前面各分割區磁區數的總和也是4個位元組,而232×512 = 2 199 023 255 552 Byte

外部連結

[編輯]