CloverBootloader/Include/IndustryStandard/AppleSmBios.h

361 lines
14 KiB
C

/** @file
Apple-Specific Definitions of SMBIOS Table Specification v3.0.0.
Copyright (c) 2006 - 2015, Intel Corporation. All rights reserved.<BR>
(C) Copyright 2015 Hewlett Packard Enterprise Development LP<BR>
This program and the accompanying materials are licensed and made available under
the terms and conditions of the BSD License that accompanies this distribution.
The full text of the license may be found at
http://opensource.org/licenses/bsd-license.php.
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
**/
#ifndef __APPLE_SMBIOS_STANDARD_H__
#define __APPLE_SMBIOS_STANDARD_H__
#include <IndustryStandard/SmBios.h>
#pragma pack (1)
#define APPLE_SMBIOS_TYPE_FIRMWARE_INFORMATION 128
#define APPLE_SMBIOS_TYPE_MEMORY_SPD_DATA 130
#define APPLE_SMBIOS_TYPE_PROCESSOR_TYPE 131
#define APPLE_SMBIOS_TYPE_PROCESSOR_BUS_SPEED 132
#define APPLE_SMBIOS_TYPE_PLATFORM_FEATURE 133
#define APPLE_SMBIOS_TYPE_SMC_INFORMATION 134
#define APPLE_NUMBER_OF_FLASHMAP_ENTRIES 8
#define APPLE_SMBIOS_SMC_VERSION_SIZE 16
// APPLE_REGION_TYPE
enum {
FW_REGION_RESERVED = 0,
FW_REGION_RECOVERY = 1,
FW_REGION_MAIN = 2,
FW_REGION_NVRAM = 3,
FW_REGION_CONFIG = 4,
FW_REGION_DIAGVAULT = 5,
NUM_FLASHMAP_ENTRIES = 8
};
enum {
AppleRegionTypeReserved = 0,
AppleRegionTypeRecovery = 1,
AppleRegionTypeMain = 2,
AppleRegionTypeNvram = 3,
AppleRegionTypeConfig = 4,
AppleRegionTypeDiagvault = 5
};
typedef UINT8 APPLE_REGION_TYPE;
///
/// Apple Firmware Volume - Region Info Type.
///
typedef struct {
UINT32 StartAddress;
UINT32 EndAddress;
} FW_REGION_INFO;
///
/// Apple Firmware Volume (Type 128).
///
typedef struct {
SMBIOS_STRUCTURE Hdr;
UINT8 RegionCount;
UINT8 Reserved[3];
UINT32 FirmwareFeatures;
UINT32 FirmwareFeaturesMask;
UINT8 RegionType[NUM_FLASHMAP_ENTRIES];
FW_REGION_INFO FlashMap[NUM_FLASHMAP_ENTRIES];
UINT32 ExtendedFirmwareFeatures;
UINT32 ExtendedFirmwareFeaturesMask;
} SMBIOS_TABLE_TYPE128;
///
/// Apple Memory SPD Data (Type 130).
///
typedef struct {
SMBIOS_STRUCTURE Hdr;
UINT16 Type17Handle;
UINT16 Offset;
UINT16 Size;
UINT16 Data[];
} APPLE_SMBIOS_TABLE_TYPE130, SMBIOS_TABLE_TYPE130;
//
// It might be that 0x01 was intended for Pentium, and 0x08 for Atom.
// Reference binaries: AppleSmBios.efi and AppleSystemInfo.framework
//
// typedef struct {
// UINT32 MajorType;
// UINT32 MinorType;
// UINT32 NumberOfCores;
// CONST CHAR8 *MarketingName;
// CONST CHAR8 *TechnicalName;
// } PROCESSOR_INFO;
//
// The cpu types listed here originate from AppleSystemInfo.framework and are not
// complete per se. The match of a certain CPU is firstly done by MajorType and
// NumberOfCores, and MinorType does not need to match. For a more complete
// table refer to AppleProcessorType enum, which is built based on Mac dumps.
//
// <0201> 01 cores Intel Core Solo Intel Core Solo
// <0201> 02 cores Intel Core Duo Intel Core Duo
// <0301> 01 cores Intel Core 2 Solo Intel Core 2 Solo
// <0301> 02 cores Intel Core 2 Duo Intel Core 2 Duo
// <0401> 01 cores Single-Core Intel Xeon Single-Core Intel Xeon
// <0401> 02 cores Dual-Core Intel Xeon Dual-Core Intel Xeon
// <0402> 01 cores Single-Core Intel Xeon Single-Core Intel Xeon
// <0402> 02 cores Dual-Core Intel Xeon Dual-Core Intel Xeon
// <0402> 03 cores Unknown Intel Xeon Unknown Intel Xeon
// <0402> 04 cores Quad-Core Intel Xeon Quad-Core Intel Xeon
// <0501> 01 cores Single-Core Intel Xeon Single-Core Intel Xeon
// <0501> 02 cores Dual-Core Intel Xeon Dual-Core Intel Xeon
// <0501> 03 cores Unknown Intel Xeon Unknown Intel Xeon
// <0501> 04 cores Quad-Core Intel Xeon Quad-Core Intel Xeon
// <0501> 06 cores 6-Core Intel Xeon 6-Core Intel Xeon
// <0601> 01 cores Intel Core i5 Intel Core i5
// <0601> 02 cores Intel Core i5 Intel Core i5
// <0601> 03 cores Intel Core i5 Intel Core i5
// <0601> 04 cores Intel Core i5 Intel Core i5
// <0601> 06 cores Intel Core i5 Intel Core i5
// <0701> 01 cores Intel Core i7 Intel Core i7
// <0701> 02 cores Intel Core i7 Intel Core i7
// <0701> 03 cores Intel Core i7 Intel Core i7
// <0701> 04 cores Intel Core i7 Intel Core i7
// <0701> 06 cores Intel Core i7 Intel Core i7
// <0901> 01 cores Intel Core i3 Intel Core i3
// <0901> 02 cores Intel Core i3 Intel Core i3
// <0901> 03 cores Intel Core i3 Intel Core i3
// <0901> 04 cores Intel Core i3 Intel Core i3
// <0A01> 04 cores Quad-Core Intel Xeon E5 Quad-Core Intel Xeon E5
// <0A01> 06 cores 6-Core Intel Xeon E5 6-Core Intel Xeon E5
// <0A01> 08 cores 8-Core Intel Xeon E5 8-Core Intel Xeon E5
// <0A01> 10 cores 10-Core Intel Xeon E5 10-Core Intel Xeon E5
// <0A01> 12 cores 12-Core Intel Xeon E5 12-Core Intel Xeon E5
// <0B01> 01 cores Intel Core M Intel Core M
// <0B01> 02 cores Intel Core M Intel Core M
// <0B01> 03 cores Intel Core M Intel Core M
// <0B01> 04 cores Intel Core M Intel Core M
// <0C01> 01 cores Intel Core m3 Intel Core m3
// <0C01> 02 cores Intel Core m3 Intel Core m3
// <0C01> 03 cores Intel Core m3 Intel Core m3
// <0C01> 04 cores Intel Core m3 Intel Core m3
// <0D01> 01 cores Intel Core m5 Intel Core m5
// <0D01> 02 cores Intel Core m5 Intel Core m5
// <0D01> 03 cores Intel Core m5 Intel Core m5
// <0D01> 04 cores Intel Core m5 Intel Core m5
// <0E01> 01 cores Intel Core m7 Intel Core m7
// <0E01> 02 cores Intel Core m7 Intel Core m7
// <0E01> 03 cores Intel Core m7 Intel Core m7
// <0E01> 04 cores Intel Core m7 Intel Core m7
// <0F01> 08 cores Intel Xeon W Intel Xeon W
// <0F01> 10 cores Intel Xeon W Intel Xeon W
// <0F01> 14 cores Intel Xeon W Intel Xeon W
// <0F01> 18 cores Intel Xeon W Intel Xeon W
// <1001> 06 cores Intel Core i9 Intel Core i9
//
// Also see here for a list of CPUs used on Mac models:
// https://docs.google.com/spreadsheets/d/1x09b5-DGh8ozNwN5ZjAi7TMnOp4TDm6DbmrKu86i_bQ
//
//
// Apple Processor Type Information - Processor Types.
//
enum {
AppleProcessorTypeUnknown = 0x0000,
AppleProcessorTypeCoreSolo = 0x0201,
AppleProcessorTypeCore2DuoType1 = 0x0301,
AppleProcessorTypeCore2DuoType2 = 0x0302,
AppleProcessorTypeXeonPenrynType1 = 0x0401, // may not be used
AppleProcessorTypeXeonPenrynType2 = 0x0402,
AppleProcessorTypeXeon = 0x0501,
AppleProcessorTypeXeonE5 = 0x0A01,
AppleProcessorTypeCorei5Type1 = 0x0601,
AppleProcessorTypeCorei7Type1 = 0x0701,
AppleProcessorTypeCorei3Type1 = 0x0901,
AppleProcessorTypeCorei5Type2 = 0x0602,
AppleProcessorTypeCorei7Type2 = 0x0702,
AppleProcessorTypeCorei3Type2 = 0x0902,
AppleProcessorTypeCorei5Type3 = 0x0603,
AppleProcessorTypeCorei7Type3 = 0x0703,
AppleProcessorTypeCorei3Type3 = 0x0903,
AppleProcessorTypeCorei5Type4 = 0x0604,
AppleProcessorTypeCorei7Type4 = 0x0704,
AppleProcessorTypeCorei3Type4 = 0x0904,
AppleProcessorTypeCorei5Type5 = 0x0605, // NOTE: we are putting 0x0609 on IM191 (i5-8600), although it should be 0x0605.
AppleProcessorTypeCorei7Type5 = 0x0705,
AppleProcessorTypeCorei3Type5 = 0x0905,
AppleProcessorTypeCorei5Type6 = 0x0606, // i5 5250U (iMac16,1, MacBookAir7,1 and 7,2), i5 5675R (iMac16,2), i5 5257U (MacBookPro12,1)
AppleProcessorTypeCorei7Type6 = 0x0706, // ideal value for Broadwell i7, need confirmation
AppleProcessorTypeCorei3Type6 = 0x0906, // ideal value for Broadwell i3, need confirmation
// placeholder for i5Type7 (maybe 0x0607 ???)
AppleProcessorTypeCorei7Type7 = 0x0707, // i7 6700HQ (MacBookPro13,3)
// placeholder for i3Type7 (maybe 0x0907 ???)
AppleProcessorTypeCorei5Type8 = 0x0608, // i5 8210Y (MacBookAir8,1)
// placeholder for i7Type8 (maybe 0x0708 ???)
// placeholder for i3Type8 (maybe 0x0908 ???)
AppleProcessorTypeCorei5Type9 = 0x0609, // i5 8259U (MacBookPro15,2), i5 8500B (Macmini8,1)
AppleProcessorTypeCorei7Type9 = 0x0709, // i7 8850H (MacBookPro15,1), i7 8700B (Macmini8,1)
// placeholder for i3Type9 (maybe 0x0909 ???)
AppleProcessorTypeCoreMType1 = 0x0B01, // may not be used
AppleProcessorTypeCoreMType6 = 0x0B06, // M 5Y51 (MacBook8,1)
AppleProcessorTypeCoreM3Type1 = 0x0C01, // may not be used
AppleProcessorTypeCoreM3Type7 = 0x0C07, // m3-7Y32 (MacBook10,1)
AppleProcessorTypeCoreM5Type1 = 0x0D01, // may not be used
AppleProcessorTypeCoreM5Type7 = 0x0D07, // m5-6Y54 (MacBook9,1)
AppleProcessorTypeCoreM7Type1 = 0x0E01, // may not be used
AppleProcessorTypeCoreM7Type7 = 0x0E07, // might be used on Core m7 (SKL), need confirmation
AppleProcessorTypeXeonW = 0x0F01, // iMacPro1,1
AppleProcessorTypeCorei9Type1 = 0x1001, // may not be used
AppleProcessorTypeCorei9Type5 = 0x1005, // SKL-X i9, most likely to be invalid!
AppleProcessorTypeCorei9Type9 = 0x1009 // ideal value for Coffee Lake i9, need confirmation
};
// APPLE_PROCESSOR_TYPE_CLASS
enum {
AppleProcessorMajorUnknown = 0x00,
AppleProcessorMajorCore = 0x02,
AppleProcessorMajorCore2 = 0x03,
AppleProcessorMajorXeonPenryn = 0x04,
AppleProcessorMajorXeonNehalem = 0x05,
AppleProcessorMajorI5 = 0x06,
AppleProcessorMajorI7 = 0x07,
AppleProcessorMajorI3 = 0x09,
AppleProcessorMajorI9 = 0x10,
AppleProcessorMajorXeonE5 = 0x0A,
AppleProcessorMajorM = 0x0B,
AppleProcessorMajorM3 = 0x0C,
AppleProcessorMajorM5 = 0x0D,
AppleProcessorMajorM7 = 0x0E,
AppleProcessorMajorXeonW = 0x0F
};
///
/// Apple Processor Type (Type 131). Not used in Monterey
///
typedef struct {
UINT8 MinorType;
UINT8 MajorType;
} APPLE_PROCESSOR_TYPE_INFO;
typedef union {
APPLE_PROCESSOR_TYPE_INFO Detail;
UINT16 Type;
} APPLE_PROCESSOR_TYPE;
// APPLE_SMBIOS_TABLE_TYPE131
typedef struct {
SMBIOS_STRUCTURE Hdr;
APPLE_PROCESSOR_TYPE ProcessorType;
UINT8 Reserved[2];
} APPLE_SMBIOS_TABLE_TYPE131, SMBIOS_TABLE_TYPE131;
///
/// Apple Processor Bus Speed (Type 132). Not used in Monterey
///
typedef struct {
SMBIOS_STRUCTURE Hdr;
UINT16 ProcessorBusSpeed; // MT/s unit
} SMBIOS_TABLE_TYPE132;
///
/// Apple Platform Feature (Type 133).
///
typedef struct {
SMBIOS_STRUCTURE Hdr;
UINT64 PlatformFeature;
} SMBIOS_TABLE_TYPE133;
///
/// Apple SMC Version (Type 134). Not used in Monterey
///
typedef struct {
SMBIOS_STRUCTURE Hdr;
UINT8 SmcVersion[APPLE_SMBIOS_SMC_VERSION_SIZE];
} APPLE_SMBIOS_TABLE_TYPE134, SMBIOS_TABLE_TYPE134;
///
/// Union of all the possible SMBIOS record types.
///
typedef union {
SMBIOS_STRUCTURE *Hdr;
SMBIOS_TABLE_TYPE0 *Type0;
SMBIOS_TABLE_TYPE1 *Type1;
SMBIOS_TABLE_TYPE2 *Type2;
SMBIOS_TABLE_TYPE3 *Type3;
SMBIOS_TABLE_TYPE4 *Type4;
SMBIOS_TABLE_TYPE5 *Type5;
SMBIOS_TABLE_TYPE6 *Type6;
SMBIOS_TABLE_TYPE7 *Type7;
SMBIOS_TABLE_TYPE8 *Type8;
SMBIOS_TABLE_TYPE9 *Type9;
SMBIOS_TABLE_TYPE10 *Type10;
SMBIOS_TABLE_TYPE11 *Type11;
SMBIOS_TABLE_TYPE12 *Type12;
SMBIOS_TABLE_TYPE13 *Type13;
SMBIOS_TABLE_TYPE14 *Type14;
SMBIOS_TABLE_TYPE15 *Type15;
SMBIOS_TABLE_TYPE16 *Type16;
SMBIOS_TABLE_TYPE17 *Type17;
SMBIOS_TABLE_TYPE18 *Type18;
SMBIOS_TABLE_TYPE19 *Type19;
SMBIOS_TABLE_TYPE20 *Type20;
SMBIOS_TABLE_TYPE21 *Type21;
SMBIOS_TABLE_TYPE22 *Type22;
SMBIOS_TABLE_TYPE23 *Type23;
SMBIOS_TABLE_TYPE24 *Type24;
SMBIOS_TABLE_TYPE25 *Type25;
SMBIOS_TABLE_TYPE26 *Type26;
SMBIOS_TABLE_TYPE27 *Type27;
SMBIOS_TABLE_TYPE28 *Type28;
SMBIOS_TABLE_TYPE29 *Type29;
SMBIOS_TABLE_TYPE30 *Type30;
SMBIOS_TABLE_TYPE31 *Type31;
SMBIOS_TABLE_TYPE32 *Type32;
SMBIOS_TABLE_TYPE33 *Type33;
SMBIOS_TABLE_TYPE34 *Type34;
SMBIOS_TABLE_TYPE35 *Type35;
SMBIOS_TABLE_TYPE36 *Type36;
SMBIOS_TABLE_TYPE37 *Type37;
SMBIOS_TABLE_TYPE38 *Type38;
SMBIOS_TABLE_TYPE39 *Type39;
SMBIOS_TABLE_TYPE40 *Type40;
SMBIOS_TABLE_TYPE41 *Type41;
SMBIOS_TABLE_TYPE42 *Type42;
SMBIOS_TABLE_TYPE126 *Type126;
SMBIOS_TABLE_TYPE127 *Type127;
SMBIOS_TABLE_TYPE128 *Type128;
SMBIOS_TABLE_TYPE130 *Type130;
SMBIOS_TABLE_TYPE131 *Type131;
SMBIOS_TABLE_TYPE132 *Type132;
SMBIOS_TABLE_TYPE133 *Type133;
SMBIOS_TABLE_TYPE134 *Type134;
UINT8 *Raw;
} APPLE_SMBIOS_STRUCTURE_POINTER;
#pragma pack()
#endif