datahubsubclassmemory.h
来自「EFI BIOS是Intel提出的下一代的BIOS标准。这里上传的Edk源代码是」· C头文件 代码 · 共 264 行
H
264 行
/*++
Copyright (c) 2004 - 2006, Intel Corporation
All rights reserved. This program and the accompanying materials
are licensed and made available under the terms and conditions of the BSD License
which 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.
Module Name:
DataHubSubClassMemory.h
Abstract:
Definitions for memory sub class data records
Revision History
--*/
#ifndef _DATAHUB_SUBCLASS_MEMORY_H_
#define _DATAHUB_SUBCLASS_MEMORY_H_
#include EFI_GUID_DEFINITION (DataHubRecords)
#define EFI_MEMORY_SUBCLASS_GUID \
{0x4E8F4EBB, 0x64B9, 0x4e05, 0x9B, 0x18, 0x4C, 0xFE, 0x49, 0x23, 0x50, 0x97}
#define EFI_MEMORY_SUBCLASS_VERSION 0x0100
#define EFI_MEMORY_SIZE_RECORD_NUMBER 0x00000001
typedef enum _EFI_MEMORY_REGION_TYPE {
EfiMemoryRegionMemory = 0x01,
EfiMemoryRegionReserved = 0x02,
EfiMemoryRegionAcpi = 0x03,
EfiMemoryRegionNvs = 0x04
} EFI_MEMORY_REGION_TYPE;
typedef struct {
UINT32 ProcessorNumber;
UINT16 StartBusNumber;
UINT16 EndBusNumber;
EFI_MEMORY_REGION_TYPE MemoryRegionType;
EFI_EXP_BASE2_DATA MemorySize;
EFI_PHYSICAL_ADDRESS MemoryStartAddress;
} EFI_MEMORY_SIZE_DATA;
#define EFI_MEMORY_ARRAY_LOCATION_RECORD_NUMBER 0x00000002
typedef enum _EFI_MEMORY_ARRAY_LOCATION {
EfiMemoryArrayLocationOther = 0x01,
EfiMemoryArrayLocationUnknown = 0x02,
EfiMemoryArrayLocationSystemBoard = 0x03,
EfiMemoryArrayLocationIsaAddonCard = 0x04,
EfiMemoryArrayLocationEisaAddonCard = 0x05,
EfiMemoryArrayLocationPciAddonCard = 0x06,
EfiMemoryArrayLocationMcaAddonCard = 0x07,
EfiMemoryArrayLocationPcmciaAddonCard = 0x08,
EfiMemoryArrayLocationProprietaryAddonCard = 0x09,
EfiMemoryArrayLocationNuBus = 0x0A,
EfiMemoryArrayLocationPc98C20AddonCard = 0xA0,
EfiMemoryArrayLocationPc98C24AddonCard = 0xA1,
EfiMemoryArrayLocationPc98EAddonCard = 0xA2,
EfiMemoryArrayLocationPc98LocalBusAddonCard = 0xA3
} EFI_MEMORY_ARRAY_LOCATION;
typedef enum _EFI_MEMORY_ARRAY_USE {
EfiMemoryArrayUseOther = 0x01,
EfiMemoryArrayUseUnknown = 0x02,
EfiMemoryArrayUseSystemMemory = 0x03,
EfiMemoryArrayUseVideoMemory = 0x04,
EfiMemoryArrayUseFlashMemory = 0x05,
EfiMemoryArrayUseNonVolatileRam = 0x06,
EfiMemoryArrayUseCacheMemory = 0x07,
} EFI_MEMORY_ARRAY_USE;
typedef enum _EFI_MEMORY_ERROR_CORRECTION {
EfiMemoryErrorCorrectionOther = 0x01,
EfiMemoryErrorCorrectionUnknown = 0x02,
EfiMemoryErrorCorrectionNone = 0x03,
EfiMemoryErrorCorrectionParity = 0x04,
EfiMemoryErrorCorrectionSingleBitEcc = 0x05,
EfiMemoryErrorCorrectionMultiBitEcc = 0x06,
EfiMemoryErrorCorrectionCrc = 0x07,
} EFI_MEMORY_ERROR_CORRECTION;
typedef struct {
EFI_MEMORY_ARRAY_LOCATION MemoryArrayLocation;
EFI_MEMORY_ARRAY_USE MemoryArrayUse;
EFI_MEMORY_ERROR_CORRECTION MemoryErrorCorrection;
UINT32 MaximumMemoryCapacity;
UINT16 NumberMemoryDevices;
} EFI_MEMORY_ARRAY_LOCATION_DATA;
#define EFI_MEMORY_ARRAY_LINK_RECORD_NUMBER 0x00000003
typedef enum _EFI_MEMORY_FORM_FACTOR {
EfiMemoryFormFactorOther = 0x01,
EfiMemoryFormFactorUnknown = 0x02,
EfiMemoryFormFactorSimm = 0x03,
EfiMemoryFormFactorSip = 0x04,
EfiMemoryFormFactorChip = 0x05,
EfiMemoryFormFactorDip = 0x06,
EfiMemoryFormFactorZip = 0x07,
EfiMemoryFormFactorProprietaryCard = 0x08,
EfiMemoryFormFactorDimm = 0x09,
EfiMemoryFormFactorTsop = 0x0A,
EfiMemoryFormFactorRowOfChips = 0x0B,
EfiMemoryFormFactorRimm = 0x0C,
EfiMemoryFormFactorSodimm = 0x0D,
EfiMemoryFormFactorSrimm = 0x0E,
EfiMemoryFormFactorFbDimm = 0x0F
} EFI_MEMORY_FORM_FACTOR;
typedef enum _EFI_MEMORY_ARRAY_TYPE {
EfiMemoryTypeOther = 0x01,
EfiMemoryTypeUnknown = 0x02,
EfiMemoryTypeDram = 0x03,
EfiMemoryTypeEdram = 0x04,
EfiMemoryTypeVram = 0x05,
EfiMemoryTypeSram = 0x06,
EfiMemoryTypeRam = 0x07,
EfiMemoryTypeRom = 0x08,
EfiMemoryTypeFlash = 0x09,
EfiMemoryTypeEeprom = 0x0A,
EfiMemoryTypeFeprom = 0x0B,
EfiMemoryTypeEprom = 0x0C,
EfiMemoryTypeCdram = 0x0D,
EfiMemoryType3Dram = 0x0E,
EfiMemoryTypeSdram = 0x0F,
EfiMemoryTypeSgram = 0x10,
EfiMemoryTypeRdram = 0x11,
EfiMemoryTypeDdr = 0x12,
EfiMemoryTypeDdr2 = 0x13,
EfiMemoryTypeDdr2FbDimm = 0x14
} EFI_MEMORY_ARRAY_TYPE;
typedef struct {
UINT32 Reserved :1;
UINT32 Other :1;
UINT32 Unknown :1;
UINT32 FastPaged :1;
UINT32 StaticColumn :1;
UINT32 PseudoStatic :1;
UINT32 Rambus :1;
UINT32 Synchronous :1;
UINT32 Cmos :1;
UINT32 Edo :1;
UINT32 WindowDram :1;
UINT32 CacheDram :1;
UINT32 Nonvolatile :1;
UINT32 Reserved1 :19;
} EFI_MEMORY_TYPE_DETAIL;
typedef enum {
EfiMemoryStateEnabled =0,
EfiMemoryStateUnknown,
EfiMemoryStateUnsupported,
EfiMemoryStateError,
EfiMemoryStateAbsent,
EfiMemoryStateDisabled,
EfiMemoryStatePartial
} EFI_MEMORY_STATE;
typedef struct {
EFI_STRING_TOKEN MemoryDeviceLocator;
EFI_STRING_TOKEN MemoryBankLocator;
EFI_STRING_TOKEN MemoryManufacturer;
EFI_STRING_TOKEN MemorySerialNumber;
EFI_STRING_TOKEN MemoryAssetTag;
EFI_STRING_TOKEN MemoryPartNumber;
EFI_INTER_LINK_DATA MemoryArrayLink;
EFI_INTER_LINK_DATA MemorySubArrayLink;
UINT16 MemoryTotalWidth;
UINT16 MemoryDataWidth;
UINT64 MemoryDeviceSize;
EFI_MEMORY_FORM_FACTOR MemoryFormFactor;
UINT8 MemoryDeviceSet;
EFI_MEMORY_ARRAY_TYPE MemoryType;
EFI_MEMORY_TYPE_DETAIL MemoryTypeDetail;
UINT16 MemorySpeed;
EFI_MEMORY_STATE MemoryState;
} EFI_MEMORY_ARRAY_LINK;
#define EFI_MEMORY_ARRAY_START_ADDRESS_RECORD_NUMBER 0x00000004
typedef struct {
EFI_PHYSICAL_ADDRESS MemoryArrayStartAddress;
EFI_PHYSICAL_ADDRESS MemoryArrayEndAddress;
EFI_INTER_LINK_DATA PhysicalMemoryArrayLink;
UINT16 MemoryArrayPartitionWidth;
} EFI_MEMORY_ARRAY_START_ADDRESS;
#define EFI_MEMORY_DEVICE_START_ADDRESS_RECORD_NUMBER 0x00000005
typedef struct {
EFI_PHYSICAL_ADDRESS MemoryDeviceStartAddress;
EFI_PHYSICAL_ADDRESS MemoryDeviceEndAddress;
EFI_INTER_LINK_DATA PhysicalMemoryDeviceLink;
EFI_INTER_LINK_DATA PhysicalMemoryArrayLink;
UINT8 MemoryDevicePartitionRowPosition;
UINT8 MemoryDeviceInterleavePosition;
UINT8 MemoryDeviceInterleaveDataDepth;
} EFI_MEMORY_DEVICE_START_ADDRESS;
//
// Memory. Channel Device Type - SMBIOS Type 37
//
#define EFI_MEMORY_CHANNEL_TYPE_RECORD_NUMBER 0x00000006
typedef enum _EFI_MEMORY_CHANNEL_TYPE {
EfiMemoryChannelTypeOther = 1,
EfiMemoryChannelTypeUnknown = 2,
EfiMemoryChannelTypeRambus = 3,
EfiMemoryChannelTypeSyncLink = 4
} EFI_MEMORY_CHANNEL_TYPE;
typedef struct {
EFI_MEMORY_CHANNEL_TYPE MemoryChannelType;
UINT8 MemoryChannelMaximumLoad;
UINT8 MemoryChannelDeviceCount;
} EFI_MEMORY_CHANNEL_TYPE_DATA;
#define EFI_MEMORY_CHANNEL_DEVICE_RECORD_NUMBER 0x00000007
typedef struct {
UINT8 DeviceId;
EFI_INTER_LINK_DATA DeviceLink;
UINT8 MemoryChannelDeviceLoad;
} EFI_MEMORY_CHANNEL_DEVICE_DATA;
typedef union _EFI_MEMORY_SUBCLASS_RECORDS {
EFI_MEMORY_SIZE_DATA SizeData;
EFI_MEMORY_ARRAY_LOCATION_DATA ArrayLocationData;
EFI_MEMORY_ARRAY_LINK ArrayLink;
EFI_MEMORY_ARRAY_START_ADDRESS ArrayStartAddress;
EFI_MEMORY_DEVICE_START_ADDRESS DeviceStartAddress;
EFI_MEMORY_CHANNEL_TYPE_DATA ChannelTypeData;
EFI_MEMORY_CHANNEL_DEVICE_DATA ChannelDeviceData;
} EFI_MEMORY_SUBCLASS_RECORDS;
typedef struct {
EFI_SUBCLASS_TYPE1_HEADER Header;
EFI_MEMORY_SUBCLASS_RECORDS Record;
} EFI_MEMORY_SUBCLASS_DRIVER_DATA;
#endif
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?