Changes for V4 ============== 1) Move delete of QuarkSocPkg\QuarkNorthCluster\Binary\QuarkMicrocode from QuarkPlatformPkg commit to QuarkSocPkg commit 2) Fix incorrect license header in PlatformSecLibModStrs.uni Changes for V3 ============== 1) Set PcdResetOnMemoryTypeInformationChange FALSE in QuarkMin.dsc This is required because QuarkMin.dsc uses the emulated variable driver that does not preserve any non-volatile UEFI variables across reset. If the condition is met where the memory type information variable needs to be updated, then the system will reset every time the UEFI Shell is run. By setting this PCD to FALSE, then reset action is disabled. 2) Move one binary file to QuarkSocBinPkg 3) Change RMU.bin FILE statements to INF statement in DSC FD region to be compatible with PACKAGES_PATH search for QuarkSocBinPkg Changes for V2 ============== 1) Use new generic PCI serial driver PciSioSerialDxe in MdeModulePkg 2) Configure PcdPciSerialParameters for PCI serial driver for Quark 3) Use new MtrrLib API to reduce time to set MTRRs for all DRAM 4) Convert all UNI files to utf-8 5) Replace tabs with spaces and remove trailing spaces 6) Add License.txt Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Michael Kinney <michael.d.kinney@intel.com> Acked-by: Jordan Justen <jordan.l.justen@intel.com> git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@19287 6f19259b-4bc3-4df7-8a09-765794883524
144 lines
3.5 KiB
C
144 lines
3.5 KiB
C
/** @file
|
|
Header file for the SmbiosMisc Driver.
|
|
|
|
Copyright (c) 2013-2015 Intel Corporation.
|
|
|
|
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.
|
|
|
|
|
|
**/
|
|
|
|
#ifndef _SMBIOS_MISC_H
|
|
#define _SMBIOS_MISC_H
|
|
|
|
#include "MiscDevicePath.h"
|
|
#include <Library/UefiBootServicesTableLib.h>
|
|
#include <Library/PrintLib.h>
|
|
|
|
///
|
|
/// Reference SMBIOS 2.6, chapter 3.1.3.
|
|
/// Each text string is limited to 64 significant characters due to system MIF limitations.
|
|
///
|
|
#define SMBIOS_STRING_MAX_LENGTH 64
|
|
#define SMBIOS_PORT_CONNECTOR_MAX_NUM 14
|
|
|
|
typedef struct {
|
|
CHAR16 PortInternalConnectorDesignator[SMBIOS_STRING_MAX_LENGTH];
|
|
CHAR16 PortExternalConnectorDesignator[SMBIOS_STRING_MAX_LENGTH];
|
|
UINT8 PortInternalConnectorType;
|
|
UINT8 PortExternalConnectorType;
|
|
UINT8 PortType;
|
|
} SMBIOS_PORT_CONNECTOR_DESIGNATOR;
|
|
|
|
typedef struct {
|
|
UINT8 SMBIOSConnectorNumber;
|
|
SMBIOS_PORT_CONNECTOR_DESIGNATOR SMBIOSPortConnector[SMBIOS_PORT_CONNECTOR_MAX_NUM];
|
|
} SMBIOS_PORT_CONNECTOR_DESIGNATOR_COFNIG;
|
|
|
|
#define SMBIOS_SYSTEM_SLOT_MAX_NUM 14
|
|
|
|
typedef struct {
|
|
CHAR16 SlotDesignation[SMBIOS_STRING_MAX_LENGTH];
|
|
UINT8 SlotType;
|
|
UINT8 SlotDataBusWidth;
|
|
UINT8 SlotUsage;
|
|
UINT8 SlotLength;
|
|
UINT16 SlotId;
|
|
UINT32 SlotCharacteristics;
|
|
} SMBIOS_SLOT_DESIGNATION;
|
|
|
|
typedef struct {
|
|
UINT8 SMBIOSSystemSlotNumber;
|
|
SMBIOS_SLOT_DESIGNATION SMBIOSSystemSlot[SMBIOS_SYSTEM_SLOT_MAX_NUM];
|
|
} SMBIOS_SLOT_COFNIG;
|
|
|
|
//
|
|
// Data table entry update function.
|
|
//
|
|
typedef EFI_STATUS (EFIAPI EFI_MISC_SMBIOS_DATA_FUNCTION) (
|
|
IN VOID *RecordData,
|
|
IN EFI_SMBIOS_PROTOCOL *Smbios
|
|
);
|
|
|
|
|
|
//
|
|
// Data table entry definition.
|
|
//
|
|
typedef struct {
|
|
//
|
|
// intermediat input data for SMBIOS record
|
|
//
|
|
VOID *RecordData;
|
|
EFI_MISC_SMBIOS_DATA_FUNCTION *Function;
|
|
} EFI_MISC_SMBIOS_DATA_TABLE;
|
|
|
|
//
|
|
// Data Table extern definitions.
|
|
//
|
|
#define MISC_SMBIOS_DATA_TABLE_POINTER(NAME1) \
|
|
& NAME1 ## Data
|
|
|
|
//
|
|
// Data Table extern definitions.
|
|
//
|
|
#define MISC_SMBIOS_DATA_TABLE_EXTERNS(NAME1, NAME2) \
|
|
extern NAME1 NAME2 ## Data
|
|
|
|
//
|
|
// Data and function Table extern definitions.
|
|
//
|
|
#define MISC_SMBIOS_TABLE_EXTERNS(NAME1, NAME2, NAME3) \
|
|
extern NAME1 NAME2 ## Data; \
|
|
extern EFI_MISC_SMBIOS_DATA_FUNCTION NAME3 ## Function
|
|
|
|
|
|
//
|
|
// Data Table entries
|
|
//
|
|
|
|
#define MISC_SMBIOS_TABLE_ENTRY_DATA_AND_FUNCTION(NAME1, NAME2) \
|
|
{ \
|
|
& NAME1 ## Data, \
|
|
& NAME2 ## Function \
|
|
}
|
|
|
|
|
|
//
|
|
// Global definition macros.
|
|
//
|
|
#define MISC_SMBIOS_TABLE_DATA(NAME1, NAME2) \
|
|
NAME1 NAME2 ## Data
|
|
|
|
#define MISC_SMBIOS_TABLE_FUNCTION(NAME2) \
|
|
EFI_STATUS EFIAPI NAME2 ## Function( \
|
|
IN VOID *RecordData, \
|
|
IN EFI_SMBIOS_PROTOCOL *Smbios \
|
|
)
|
|
|
|
|
|
// Data Table Array
|
|
//
|
|
extern EFI_MISC_SMBIOS_DATA_TABLE mSmbiosMiscDataTable[];
|
|
|
|
//
|
|
// Data Table Array Entries
|
|
//
|
|
extern UINTN mSmbiosMiscDataTableEntries;
|
|
extern EFI_HII_HANDLE mHiiHandle;
|
|
//
|
|
// Prototypes
|
|
//
|
|
EFI_STATUS
|
|
PiSmbiosMiscEntryPoint (
|
|
IN EFI_HANDLE ImageHandle,
|
|
IN EFI_SYSTEM_TABLE *SystemTable
|
|
);
|
|
|
|
#endif
|