Skip to content
我们可以看到,一个GPT磁盘可以分为两大部分:保护MBR和EFI部分。
(1)第一部分只由0号扇区组成,在这个扇区中包含一个DOS分区表,分区表内只有一个表项,这个表项描述了一个类型值为0xEE的分区,大小为整个磁盘(如图2所示)。这个分区的存在可以使计算机认为这个磁盘是合法的,并且已被使用,从而不再试图对其进行格式化等操作,所以该扇区又被称为“保护MBR”。实际上,EFI根本不使用这个分区表。
图2GPT磁盘的0号扇区
(2)另一部分为EFI部分,EFI部分又可以分为4个区域:EFI信息区(又称为GPT头)部分、分区表部分、GPT分区部分和备份区域。
EFI信息区,也称为GPT头,起始于磁盘的1号扇区,通常只占用这一个扇区。GPT磁盘创建后,由GPT头定义分区表的位置和大小。Windows限定分区表项为128个。GPT头还包含头和分区表的校验和,这样就可以及时发现错误或者改变。
分区表区域包含分区表项。这个区域由GPT头定义,一般占用磁盘2~33号扇区。分区表中的每个表项由起始和结束地址、类型值、名字、属性标志和GUID值组成。分区表建立后,128位的GUID对系统来说是唯一的。
分区部分是最大的区域,由分配给分区的扇区组成。这个区域的起始和结束地址由GPT头定义。
备份区域位于磁盘的尾部,包含GPT头和分区表的备份。它占用GPT结束扇区和EFI结束扇区之间的33个扇区。其中最后一个扇区用来备份1号扇区的EFI信息,其余的32个扇区用来备份2~33号扇区的分区表。
数据结构
1.EFI信息扇区数据结构
EFI信息扇区位于磁盘的1号扇区,也称为GPT头。GPT磁盘创建后,由GPT头定义分区表的位置和大小,Windows限定分区表项为128个。GPT头还包含头和分区表的校验和。EFI信息扇区的结构如表2.1所示。
|
相对字节偏移
(十六进制)
|
字节数
|
说明
|
00~07
|
8
|
签名(ASCII码“EFI PART”
|
08~0B
|
4
|
版本
|
0C~0F
|
4
|
GPT头大小字节数
|
10~13
|
4
|
GPT头CRC校验和
|
14~17
|
4
|
保留
|
18~1F
|
8
|
当前GPT头的LBA扇区号,也即为EFI区域起始扇区号
|
20~27
|
8
|
GPT头备份LBA扇区号,也即为EFI区域结束扇区号
|
28~2F
|
8
|
GPT分区区域起始LBA
|
30~37
|
8
|
GPT分区区域结束LBA
|
38~47
|
12
|
磁盘GUID
|
48~4F
|
8
|
GPT分区表起始LBA
|
50~53
|
4
|
分区表项数
|
54~57
|
4
|
每分区表项占用字节数
|
58~5B
|
4
|
分区表CRC校验和
|
5C~1FF
|
366
|
保留
表2.1EFI信息扇区结构
通过这些结构中的描述值,我们可以确定GPT头、分区表、GPT分区区域、分区表的备份位置等结构布局。图2.3显示了一个GPT头的实例。

图2.3GPT头
具体分析如下:
1)0x00~0x07:8个字节,GPT头签名“4546492050415254”,ASCII码为“EFIPART”。
2)0x08~0x0B:4个字节,版本号。
3)0x0C~0x0F:4个字节,GPT头大小字节数,此处的值为0x5C,即92个字节。
4)0x10~0x13:4个字节,GPT头校验和。
5)0x14~0x17:4个字节,保留。
6)0x18~0x1F:8个字节,当前GPT头的LBA扇区号,即EFI区域起始扇区号,通常为1。
7)0x20~0x27:8个字节,GPT头备份位置的LBA扇区号,即EFI区域结束扇区号,此处的值为224909(0x086E8D)。
8)0x28~0x2F:8个字节,GPT分区区域起始LBA扇区号,此处的值为34(0x22)。
9)0x30~0x37:8个字节,GPT分区区域结束LBA扇区号,此处的值为224876(0x036E6C)。
10)0x38~0x47:16个字节,磁盘GUID。
11)0x48~0x4F:8个字节,GPT分区表起始LBA扇区号,此处的值为2(0x02),通常都是起始于2号扇区。
12)0x50~0x53:4个字节,分区表项数,限定为128(0x80)。
13)0x54~0x57:4个字节,每分区表项占用字节数,固定为128(0x80)。
14)0x58~0x5B:4个字节,分区表CRC校验和。
15)0x5C~0x1FF:420个字节,保留。
笔者在此主要侧重讲有关GPT数据恢复方面的知识,看不明白没关系,假如GPT分区模式硬盘分区丢失了,可以联系我们技王,我们有更加专业的数据恢复工程师为您服务!
Back To Top