1cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler/* Copyright (c) 2013 The Chromium OS Authors. All rights reserved.
237f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo * Use of this source code is governed by a BSD-style license that can be
337f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo * found in the LICENSE file.
437f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo *
5864fae2d78f88a1ec3865c6eeffa9eb605cc6b38Bill Richardson * Defines UEFI related structure. See more details in the UEFI spec.
637f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo *
7864fae2d78f88a1ec3865c6eeffa9eb605cc6b38Bill Richardson * To download UEFI standard, please visit UEFI homepage:
837f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo *    http://www.uefi.org/
937f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo */
1037f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo#ifndef VBOOT_REFERENCE_CGPTLIB_GPT_H_
1137f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo#define VBOOT_REFERENCE_CGPTLIB_GPT_H_
120c3ba249abb1dc60f5ebabccf84ff13206440b83Bill Richardson#include <stdint.h>
1337f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo
14864fae2d78f88a1ec3865c6eeffa9eb605cc6b38Bill Richardson/* From the specification */
15864fae2d78f88a1ec3865c6eeffa9eb605cc6b38Bill Richardson#define GPT_HEADER_SIGNATURE_SIZE 8
16864fae2d78f88a1ec3865c6eeffa9eb605cc6b38Bill Richardson#define GPT_HEADER_REVISION 0x00010000
17b7b865cfee68190babd971ab9a897bdabbab075fStefan Reinauer#define GPT_HEADER_SIGNATURE  "EFI PART"
18864fae2d78f88a1ec3865c6eeffa9eb605cc6b38Bill Richardson
19864fae2d78f88a1ec3865c6eeffa9eb605cc6b38Bill Richardson/* From https://chromium-review.googlesource.com/31264 */
20b7b865cfee68190babd971ab9a897bdabbab075fStefan Reinauer#define GPT_HEADER_SIGNATURE2 "CHROMEOS"
2137f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo
22cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler/*
23cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler * The first 3 numbers should be stored in network-endian format according to
24cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler * the GUID RFC.  The UEFI spec appendix A claims they should be stored in
25cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler * little-endian format.  But they need to be _displayed_ in network-endian
26cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler * format, which is also how they're documented in the specs.
273dcf9dce04301d6d735f265652625fffb6758430Randall Spangler *
28cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler * Since what we have here are little-endian constants, they're byte-swapped
29cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler * from the normal display order.
30cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler */
3137f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo#define GPT_ENT_TYPE_UNUSED \
32cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	{{{0x00000000,0x0000,0x0000,0x00,0x00,{0x00,0x00,0x00,0x00,0x00,0x00}}}}
333dcf9dce04301d6d735f265652625fffb6758430Randall Spangler#define GPT_ENT_TYPE_EFI \
34cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	{{{0xc12a7328,0xf81f,0x11d2,0xba,0x4b,{0x00,0xa0,0xc9,0x3e,0xc9,0x3b}}}}
3593cf15e9a1c29962d6f08be6102d2ea7876d969fGabe Black#define GPT_ENT_TYPE_CHROMEOS_FIRMWARE \
36cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	{{{0xcab6e88e,0xabf3,0x4102,0xa0,0x7a,{0xd4,0xbb,0x9b,0xe3,0xc1,0xd3}}}}
3737f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo#define GPT_ENT_TYPE_CHROMEOS_KERNEL \
38cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	{{{0xfe3a2a5d,0x4f32,0x41a7,0xb7,0x25,{0xac,0xcc,0x32,0x85,0xa3,0x09}}}}
3937f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo#define GPT_ENT_TYPE_CHROMEOS_ROOTFS \
40cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	{{{0x3cb8e202,0x3b7e,0x47dd,0x8a,0x3c,{0x7f,0xf2,0xa1,0x3c,0xfc,0xec}}}}
4137f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo#define GPT_ENT_TYPE_CHROMEOS_RESERVED \
42cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	{{{0x2e0a753d,0x9e48,0x43b0,0x83,0x37,{0xb1,0x51,0x92,0xcb,0x1b,0x5e}}}}
4377d26e51909b4f8bc4d3641577b42ee537ccdf18Bill Richardson#define GPT_ENT_TYPE_LINUX_DATA \
44cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	{{{0xebd0a0a2,0xb9e5,0x4433,0x87,0xc0,{0x68,0xb6,0xb7,0x26,0x99,0xc7}}}}
452b0dc167451b151452b834f88dafd83d912a55cdFurquan Shaikh#define GPT_ENT_TYPE_LINUX_FS \
462b0dc167451b151452b834f88dafd83d912a55cdFurquan Shaikh	{{{0x0fc63daf,0x8483,0x4772,0x8e,0x79,{0x3d,0x69,0xd8,0x47,0x7d,0xe4}}}}
4737f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo
4837f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo#define UUID_NODE_LEN 6
4937f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo#define GUID_SIZE 16
5037f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo
51864fae2d78f88a1ec3865c6eeffa9eb605cc6b38Bill Richardson/* GUID definition. Defined in appendix A of UEFI standard. */
5237f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lotypedef struct {
53cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	union {
54cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler		struct {
55cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler			uint32_t time_low;
56cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler			uint16_t time_mid;
57cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler			uint16_t time_high_and_version;
58cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler			uint8_t clock_seq_high_and_reserved;
59cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler			uint8_t clock_seq_low;
60cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler			uint8_t node[UUID_NODE_LEN];
61cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler		} Uuid;
62cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler		uint8_t raw[GUID_SIZE];
63cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	} u;
6437f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo} __attribute__((packed)) Guid;
6537f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo
6681d0996901387619cc782ca258fcb4a9f3f591e7Randall Spangler#define GUID_EXPECTED_SIZE GUID_SIZE
6781d0996901387619cc782ca258fcb4a9f3f591e7Randall Spangler
68cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler/*
69cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler * GPT header defines how many partitions exist on a drive and sectors managed.
70cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler * For every drive device, there are 2 headers, primary and secondary.  Most of
71864fae2d78f88a1ec3865c6eeffa9eb605cc6b38Bill Richardson * the fields are duplicates except my_lba and entries_lba.
7237f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo *
73864fae2d78f88a1ec3865c6eeffa9eb605cc6b38Bill Richardson * You may find more details in chapter 5 of the UEFI standard.
7437f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo */
7537f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lotypedef struct {
76864fae2d78f88a1ec3865c6eeffa9eb605cc6b38Bill Richardson	char signature[GPT_HEADER_SIGNATURE_SIZE];
77cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint32_t revision;
78cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint32_t size;
79cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint32_t header_crc32;
80cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint32_t reserved_zero;
81cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint64_t my_lba;
82cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint64_t alternate_lba;
83cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint64_t first_usable_lba;
84cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint64_t last_usable_lba;
85cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	Guid disk_uuid;
86cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint64_t entries_lba;
87cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint32_t number_of_entries;
88cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint32_t size_of_entry;
89cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint32_t entries_crc32;
90cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	/* Remainder of sector is reserved and should be 0 */
91962483c1e27627aad843a2c394f11b830dd1ce02Bill Richardson} __attribute__((packed)) GptHeader;
9237f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo
9381d0996901387619cc782ca258fcb4a9f3f591e7Randall Spangler#define GPTHEADER_EXPECTED_SIZE 92
9481d0996901387619cc782ca258fcb4a9f3f591e7Randall Spangler
95cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler/*
96cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler * GPT partition entry defines the starting and ending LBAs of a partition.  It
97cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler * also contains the unique GUID, type, and attribute bits.
9837f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo *
99864fae2d78f88a1ec3865c6eeffa9eb605cc6b38Bill Richardson * You may find more details in chapter 5 of the UEFI standard.
10037f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo */
10137f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lotypedef struct {
102cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	Guid type;
103cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	Guid unique;
104cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint64_t starting_lba;
105cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint64_t ending_lba;
106cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	union {
107cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler		struct {
108cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler			uint16_t reserved[3];
109cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler			uint16_t gpt_att;
110cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler		} __attribute__((packed)) fields;
111cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler		uint64_t whole;
112cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	} attrs;
113cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	uint16_t name[36];  /* UTF-16 encoded partition name */
114cefe12c105a91e6ee9f44bca218bd6e4f89bcb71Randall Spangler	/* Remainder of entry is reserved and should be 0 */
115962483c1e27627aad843a2c394f11b830dd1ce02Bill Richardson} __attribute__((packed)) GptEntry;
11637f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo
11781d0996901387619cc782ca258fcb4a9f3f591e7Randall Spangler#define GPTENTRY_EXPECTED_SIZE 128
11881d0996901387619cc782ca258fcb4a9f3f591e7Randall Spangler
11937f6b55a25f337f555da1dfbe585d32cd004103dLouis Yung-Chieh Lo#endif  /* VBOOT_REFERENCE_CGPTLIB_GPT_H_ */
120