xref: /aosp_15_r20/external/vboot_reference/firmware/include/gpt.h (revision 8617a60d3594060b7ecbd21bc622a7c14f3cf2bc)
1*8617a60dSAndroid Build Coastguard Worker /* Copyright 2013 The ChromiumOS Authors
2*8617a60dSAndroid Build Coastguard Worker  * Use of this source code is governed by a BSD-style license that can be
3*8617a60dSAndroid Build Coastguard Worker  * found in the LICENSE file.
4*8617a60dSAndroid Build Coastguard Worker  *
5*8617a60dSAndroid Build Coastguard Worker  * Defines UEFI related structure. See more details in the UEFI spec.
6*8617a60dSAndroid Build Coastguard Worker  *
7*8617a60dSAndroid Build Coastguard Worker  * To download UEFI standard, please visit UEFI homepage:
8*8617a60dSAndroid Build Coastguard Worker  *    http://www.uefi.org/
9*8617a60dSAndroid Build Coastguard Worker  */
10*8617a60dSAndroid Build Coastguard Worker 
11*8617a60dSAndroid Build Coastguard Worker #ifndef VBOOT_REFERENCE_CGPTLIB_GPT_H_
12*8617a60dSAndroid Build Coastguard Worker #define VBOOT_REFERENCE_CGPTLIB_GPT_H_
13*8617a60dSAndroid Build Coastguard Worker 
14*8617a60dSAndroid Build Coastguard Worker #include <stdint.h>
15*8617a60dSAndroid Build Coastguard Worker 
16*8617a60dSAndroid Build Coastguard Worker #ifdef __cplusplus
17*8617a60dSAndroid Build Coastguard Worker extern "C" {
18*8617a60dSAndroid Build Coastguard Worker #endif  /* __cplusplus */
19*8617a60dSAndroid Build Coastguard Worker 
20*8617a60dSAndroid Build Coastguard Worker /* From the specification */
21*8617a60dSAndroid Build Coastguard Worker #define GPT_HEADER_SIGNATURE_SIZE 8
22*8617a60dSAndroid Build Coastguard Worker #define GPT_HEADER_REVISION 0x00010000
23*8617a60dSAndroid Build Coastguard Worker #define GPT_HEADER_SIGNATURE  "EFI PART"
24*8617a60dSAndroid Build Coastguard Worker 
25*8617a60dSAndroid Build Coastguard Worker /* From https://chromium-review.googlesource.com/31264 */
26*8617a60dSAndroid Build Coastguard Worker #define GPT_HEADER_SIGNATURE2 "CHROMEOS"
27*8617a60dSAndroid Build Coastguard Worker 
28*8617a60dSAndroid Build Coastguard Worker /* From http://crosbug.com/p/52595 */
29*8617a60dSAndroid Build Coastguard Worker #define GPT_HEADER_SIGNATURE_IGNORED "IGNOREME"
30*8617a60dSAndroid Build Coastguard Worker 
31*8617a60dSAndroid Build Coastguard Worker /*
32*8617a60dSAndroid Build Coastguard Worker  * The first 3 numbers should be stored in network-endian format according to
33*8617a60dSAndroid Build Coastguard Worker  * the GUID RFC.  The UEFI spec appendix A claims they should be stored in
34*8617a60dSAndroid Build Coastguard Worker  * little-endian format.  But they need to be _displayed_ in network-endian
35*8617a60dSAndroid Build Coastguard Worker  * format, which is also how they're documented in the specs.
36*8617a60dSAndroid Build Coastguard Worker  *
37*8617a60dSAndroid Build Coastguard Worker  * Since what we have here are little-endian constants, they're byte-swapped
38*8617a60dSAndroid Build Coastguard Worker  * from the normal display order.
39*8617a60dSAndroid Build Coastguard Worker  */
40*8617a60dSAndroid Build Coastguard Worker #define GPT_ENT_TYPE_UNUSED \
41*8617a60dSAndroid Build Coastguard Worker 	{{{0x00000000,0x0000,0x0000,0x00,0x00,{0x00,0x00,0x00,0x00,0x00,0x00}}}}
42*8617a60dSAndroid Build Coastguard Worker #define GPT_ENT_TYPE_EFI \
43*8617a60dSAndroid Build Coastguard Worker 	{{{0xc12a7328,0xf81f,0x11d2,0xba,0x4b,{0x00,0xa0,0xc9,0x3e,0xc9,0x3b}}}}
44*8617a60dSAndroid Build Coastguard Worker #define GPT_ENT_TYPE_CHROMEOS_FIRMWARE \
45*8617a60dSAndroid Build Coastguard Worker 	{{{0xcab6e88e,0xabf3,0x4102,0xa0,0x7a,{0xd4,0xbb,0x9b,0xe3,0xc1,0xd3}}}}
46*8617a60dSAndroid Build Coastguard Worker #define GPT_ENT_TYPE_CHROMEOS_KERNEL \
47*8617a60dSAndroid Build Coastguard Worker 	{{{0xfe3a2a5d,0x4f32,0x41a7,0xb7,0x25,{0xac,0xcc,0x32,0x85,0xa3,0x09}}}}
48*8617a60dSAndroid Build Coastguard Worker #define GPT_ENT_TYPE_CHROMEOS_ROOTFS \
49*8617a60dSAndroid Build Coastguard Worker 	{{{0x3cb8e202,0x3b7e,0x47dd,0x8a,0x3c,{0x7f,0xf2,0xa1,0x3c,0xfc,0xec}}}}
50*8617a60dSAndroid Build Coastguard Worker #define GPT_ENT_TYPE_CHROMEOS_RESERVED \
51*8617a60dSAndroid Build Coastguard Worker 	{{{0x2e0a753d,0x9e48,0x43b0,0x83,0x37,{0xb1,0x51,0x92,0xcb,0x1b,0x5e}}}}
52*8617a60dSAndroid Build Coastguard Worker #define GPT_ENT_TYPE_BASIC_DATA \
53*8617a60dSAndroid Build Coastguard Worker 	{{{0xebd0a0a2,0xb9e5,0x4433,0x87,0xc0,{0x68,0xb6,0xb7,0x26,0x99,0xc7}}}}
54*8617a60dSAndroid Build Coastguard Worker #define GPT_ENT_TYPE_LINUX_FS \
55*8617a60dSAndroid Build Coastguard Worker 	{{{0x0fc63daf,0x8483,0x4772,0x8e,0x79,{0x3d,0x69,0xd8,0x47,0x7d,0xe4}}}}
56*8617a60dSAndroid Build Coastguard Worker #define GPT_ENT_TYPE_CHROMEOS_MINIOS \
57*8617a60dSAndroid Build Coastguard Worker 	{{{0x09845860,0x705f,0x4bb5,0xb1,0x6c,{0x8a,0x8a,0x09,0x9c,0xaf,0x52}}}}
58*8617a60dSAndroid Build Coastguard Worker #define GPT_ENT_TYPE_CHROMEOS_HIBERNATE \
59*8617a60dSAndroid Build Coastguard Worker 	{{{0x3f0f8318,0xf146,0x4e6b,0x82,0x22,{0xc2,0x8c,0x8f,0x02,0xe0,0xd5}}}}
60*8617a60dSAndroid Build Coastguard Worker 
61*8617a60dSAndroid Build Coastguard Worker #define UUID_NODE_LEN 6
62*8617a60dSAndroid Build Coastguard Worker #define GUID_SIZE 16
63*8617a60dSAndroid Build Coastguard Worker 
64*8617a60dSAndroid Build Coastguard Worker /* GUID definition. Defined in appendix A of UEFI standard. */
65*8617a60dSAndroid Build Coastguard Worker typedef struct {
66*8617a60dSAndroid Build Coastguard Worker 	union {
67*8617a60dSAndroid Build Coastguard Worker 		struct {
68*8617a60dSAndroid Build Coastguard Worker 			uint32_t time_low;
69*8617a60dSAndroid Build Coastguard Worker 			uint16_t time_mid;
70*8617a60dSAndroid Build Coastguard Worker 			uint16_t time_high_and_version;
71*8617a60dSAndroid Build Coastguard Worker 			uint8_t clock_seq_high_and_reserved;
72*8617a60dSAndroid Build Coastguard Worker 			uint8_t clock_seq_low;
73*8617a60dSAndroid Build Coastguard Worker 			uint8_t node[UUID_NODE_LEN];
74*8617a60dSAndroid Build Coastguard Worker 		} Uuid;
75*8617a60dSAndroid Build Coastguard Worker 		uint8_t raw[GUID_SIZE];
76*8617a60dSAndroid Build Coastguard Worker 	} u;
77*8617a60dSAndroid Build Coastguard Worker } __attribute__((packed)) Guid;
78*8617a60dSAndroid Build Coastguard Worker 
79*8617a60dSAndroid Build Coastguard Worker #define GUID_EXPECTED_SIZE GUID_SIZE
80*8617a60dSAndroid Build Coastguard Worker 
81*8617a60dSAndroid Build Coastguard Worker /*
82*8617a60dSAndroid Build Coastguard Worker  * GPT header defines how many partitions exist on a drive and sectors managed.
83*8617a60dSAndroid Build Coastguard Worker  * For every drive device, there are 2 headers, primary and secondary.  Most of
84*8617a60dSAndroid Build Coastguard Worker  * the fields are duplicates except my_lba and entries_lba.
85*8617a60dSAndroid Build Coastguard Worker  *
86*8617a60dSAndroid Build Coastguard Worker  * You may find more details in chapter 5 of the UEFI standard.
87*8617a60dSAndroid Build Coastguard Worker  */
88*8617a60dSAndroid Build Coastguard Worker typedef struct {
89*8617a60dSAndroid Build Coastguard Worker 	char signature[GPT_HEADER_SIGNATURE_SIZE];
90*8617a60dSAndroid Build Coastguard Worker 	uint32_t revision;
91*8617a60dSAndroid Build Coastguard Worker 	uint32_t size;
92*8617a60dSAndroid Build Coastguard Worker 	uint32_t header_crc32;
93*8617a60dSAndroid Build Coastguard Worker 	uint32_t reserved_zero;
94*8617a60dSAndroid Build Coastguard Worker 	uint64_t my_lba;
95*8617a60dSAndroid Build Coastguard Worker 	uint64_t alternate_lba;
96*8617a60dSAndroid Build Coastguard Worker 	uint64_t first_usable_lba;
97*8617a60dSAndroid Build Coastguard Worker 	uint64_t last_usable_lba;
98*8617a60dSAndroid Build Coastguard Worker 	Guid disk_uuid;
99*8617a60dSAndroid Build Coastguard Worker 	uint64_t entries_lba;
100*8617a60dSAndroid Build Coastguard Worker 	uint32_t number_of_entries;
101*8617a60dSAndroid Build Coastguard Worker 	uint32_t size_of_entry;
102*8617a60dSAndroid Build Coastguard Worker 	uint32_t entries_crc32;
103*8617a60dSAndroid Build Coastguard Worker 	/* Remainder of sector is reserved and should be 0 */
104*8617a60dSAndroid Build Coastguard Worker } __attribute__((packed)) GptHeader;
105*8617a60dSAndroid Build Coastguard Worker 
106*8617a60dSAndroid Build Coastguard Worker #define GPTHEADER_EXPECTED_SIZE 92
107*8617a60dSAndroid Build Coastguard Worker 
108*8617a60dSAndroid Build Coastguard Worker /*
109*8617a60dSAndroid Build Coastguard Worker  * GPT partition entry defines the starting and ending LBAs of a partition.  It
110*8617a60dSAndroid Build Coastguard Worker  * also contains the unique GUID, type, and attribute bits.
111*8617a60dSAndroid Build Coastguard Worker  *
112*8617a60dSAndroid Build Coastguard Worker  * You may find more details in chapter 5 of the UEFI standard.
113*8617a60dSAndroid Build Coastguard Worker  */
114*8617a60dSAndroid Build Coastguard Worker typedef struct {
115*8617a60dSAndroid Build Coastguard Worker 	Guid type;
116*8617a60dSAndroid Build Coastguard Worker 	Guid unique;
117*8617a60dSAndroid Build Coastguard Worker 	uint64_t starting_lba;
118*8617a60dSAndroid Build Coastguard Worker 	uint64_t ending_lba;
119*8617a60dSAndroid Build Coastguard Worker 	union {
120*8617a60dSAndroid Build Coastguard Worker 		struct {
121*8617a60dSAndroid Build Coastguard Worker 			uint8_t required:1;
122*8617a60dSAndroid Build Coastguard Worker 			uint8_t efi_ignore:1;
123*8617a60dSAndroid Build Coastguard Worker 			uint8_t legacy_boot:1;
124*8617a60dSAndroid Build Coastguard Worker 			uint8_t reserved1:5;
125*8617a60dSAndroid Build Coastguard Worker 			uint8_t reserved2;
126*8617a60dSAndroid Build Coastguard Worker 			uint16_t reserved[2];
127*8617a60dSAndroid Build Coastguard Worker 			uint16_t gpt_att;
128*8617a60dSAndroid Build Coastguard Worker 		} __attribute__((packed)) fields;
129*8617a60dSAndroid Build Coastguard Worker 		uint64_t whole;
130*8617a60dSAndroid Build Coastguard Worker 	} attrs;
131*8617a60dSAndroid Build Coastguard Worker 	uint16_t name[36];  /* UTF-16 encoded partition name */
132*8617a60dSAndroid Build Coastguard Worker 	/* Remainder of entry is reserved and should be 0 */
133*8617a60dSAndroid Build Coastguard Worker } __attribute__((packed)) GptEntry;
134*8617a60dSAndroid Build Coastguard Worker 
135*8617a60dSAndroid Build Coastguard Worker #define GPTENTRY_EXPECTED_SIZE 128
136*8617a60dSAndroid Build Coastguard Worker 
137*8617a60dSAndroid Build Coastguard Worker #ifdef __cplusplus
138*8617a60dSAndroid Build Coastguard Worker }
139*8617a60dSAndroid Build Coastguard Worker #endif  /* __cplusplus */
140*8617a60dSAndroid Build Coastguard Worker 
141*8617a60dSAndroid Build Coastguard Worker #endif  /* VBOOT_REFERENCE_CGPTLIB_GPT_H_ */
142