/** @file Legacy Master Boot Record Format Definition. Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent **/ #ifndef _MBR_H_ #define _MBR_H_ #define MBR_SIGNATURE 0xaa55 #define EXTENDED_DOS_PARTITION 0x05 #define EXTENDED_WINDOWS_PARTITION 0x0F #define MAX_MBR_PARTITIONS 4 #define PMBR_GPT_PARTITION 0xEE #define EFI_PARTITION 0xEF #define MBR_SIZE 512 #pragma pack(1) /// /// MBR Partition Entry /// typedef struct { UINT8 BootIndicator; UINT8 StartHead; UINT8 StartSector; UINT8 StartTrack; UINT8 OSIndicator; UINT8 EndHead; UINT8 EndSector; UINT8 EndTrack; UINT8 StartingLBA[4]; UINT8 SizeInLBA[4]; } MBR_PARTITION_RECORD; /// /// MBR Partition Table /// typedef struct { UINT8 BootStrapCode[440]; UINT8 UniqueMbrSignature[4]; UINT8 Unknown[2]; MBR_PARTITION_RECORD Partition[MAX_MBR_PARTITIONS]; UINT16 Signature; } MASTER_BOOT_RECORD; #pragma pack() #endif