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