2009-11-20 05:01:32 +01:00
|
|
|
/** @file
|
|
|
|
This code supports the implementation of the Smbios protocol
|
|
|
|
|
2015-03-16 03:41:48 +01:00
|
|
|
Copyright (c) 2009 - 2015, Intel Corporation. All rights reserved.<BR>
|
2010-04-24 11:33:45 +02:00
|
|
|
This program and the accompanying materials
|
2009-11-20 05:01:32 +01:00
|
|
|
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_DXE_H_
|
|
|
|
#define _SMBIOS_DXE_H_
|
|
|
|
|
|
|
|
|
|
|
|
#include <PiDxe.h>
|
|
|
|
|
|
|
|
#include <Protocol/Smbios.h>
|
|
|
|
#include <IndustryStandard/SmBios.h>
|
|
|
|
#include <Guid/EventGroup.h>
|
|
|
|
#include <Guid/SmBios.h>
|
|
|
|
#include <Library/DebugLib.h>
|
|
|
|
#include <Library/UefiDriverEntryPoint.h>
|
|
|
|
#include <Library/UefiLib.h>
|
|
|
|
#include <Library/BaseLib.h>
|
|
|
|
#include <Library/BaseMemoryLib.h>
|
|
|
|
#include <Library/MemoryAllocationLib.h>
|
|
|
|
#include <Library/UefiBootServicesTableLib.h>
|
2010-02-01 03:54:22 +01:00
|
|
|
#include <Library/PcdLib.h>
|
2009-11-20 05:01:32 +01:00
|
|
|
|
2012-05-08 03:33:23 +02:00
|
|
|
//
|
|
|
|
// The length of the entire structure table (including all strings) must be reported
|
|
|
|
// in the Structure Table Length field of the SMBIOS Structure Table Entry Point,
|
|
|
|
// which is a WORD field limited to 65,535 bytes.
|
|
|
|
//
|
|
|
|
#define SMBIOS_TABLE_MAX_LENGTH 0xFFFF
|
|
|
|
|
2015-03-16 03:41:48 +01:00
|
|
|
//
|
|
|
|
// For SMBIOS 3.0, Structure table maximum size in Entry Point structure is DWORD field limited to 0xFFFFFFFF bytes.
|
|
|
|
//
|
|
|
|
#define SMBIOS_3_0_TABLE_MAX_LENGTH 0xFFFFFFFF
|
|
|
|
|
2009-11-20 05:01:32 +01:00
|
|
|
#define SMBIOS_INSTANCE_SIGNATURE SIGNATURE_32 ('S', 'B', 'i', 's')
|
|
|
|
typedef struct {
|
|
|
|
UINT32 Signature;
|
|
|
|
EFI_HANDLE Handle;
|
|
|
|
//
|
|
|
|
// Produced protocol
|
|
|
|
//
|
|
|
|
EFI_SMBIOS_PROTOCOL Smbios;
|
|
|
|
//
|
|
|
|
// Updates to record list must be locked.
|
|
|
|
//
|
|
|
|
EFI_LOCK DataLock;
|
|
|
|
//
|
|
|
|
// List of EFI_SMBIOS_ENTRY structures.
|
|
|
|
//
|
|
|
|
LIST_ENTRY DataListHead;
|
|
|
|
//
|
|
|
|
// List of allocated SMBIOS handle.
|
|
|
|
//
|
|
|
|
LIST_ENTRY AllocatedHandleListHead;
|
|
|
|
} SMBIOS_INSTANCE;
|
|
|
|
|
|
|
|
#define SMBIOS_INSTANCE_FROM_THIS(this) CR (this, SMBIOS_INSTANCE, Smbios, SMBIOS_INSTANCE_SIGNATURE)
|
|
|
|
|
|
|
|
//
|
|
|
|
// SMBIOS record Header
|
|
|
|
//
|
|
|
|
// An SMBIOS internal Record is an EFI_SMBIOS_RECORD_HEADER followed by (RecordSize - HeaderSize) bytes of
|
|
|
|
// data. The format of the data is defined by the SMBIOS spec.
|
|
|
|
//
|
|
|
|
//
|
|
|
|
#define EFI_SMBIOS_RECORD_HEADER_VERSION 0x0100
|
|
|
|
typedef struct {
|
|
|
|
UINT16 Version;
|
|
|
|
UINT16 HeaderSize;
|
|
|
|
UINTN RecordSize;
|
|
|
|
EFI_HANDLE ProducerHandle;
|
|
|
|
UINTN NumberOfStrings;
|
|
|
|
} EFI_SMBIOS_RECORD_HEADER;
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
// Private data structure to contain the SMBIOS record. One record per
|
|
|
|
// structure. SmbiosRecord is a copy of the data passed in and follows RecordHeader .
|
|
|
|
//
|
|
|
|
#define EFI_SMBIOS_ENTRY_SIGNATURE SIGNATURE_32 ('S', 'r', 'e', 'c')
|
|
|
|
typedef struct {
|
|
|
|
UINT32 Signature;
|
|
|
|
LIST_ENTRY Link;
|
|
|
|
EFI_SMBIOS_RECORD_HEADER *RecordHeader;
|
|
|
|
UINTN RecordSize;
|
2015-03-16 03:41:48 +01:00
|
|
|
//
|
|
|
|
// Indicate which table this record is added to.
|
|
|
|
//
|
|
|
|
BOOLEAN Smbios32BitTable;
|
|
|
|
BOOLEAN Smbios64BitTable;
|
2009-11-20 05:01:32 +01:00
|
|
|
} EFI_SMBIOS_ENTRY;
|
|
|
|
|
|
|
|
#define SMBIOS_ENTRY_FROM_LINK(link) CR (link, EFI_SMBIOS_ENTRY, Link, EFI_SMBIOS_ENTRY_SIGNATURE)
|
|
|
|
|
|
|
|
//
|
|
|
|
// Private data to contain the Smbios handle that already allocated.
|
|
|
|
//
|
|
|
|
#define SMBIOS_HANDLE_ENTRY_SIGNATURE SIGNATURE_32 ('S', 'h', 'r', 'd')
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
UINT32 Signature;
|
|
|
|
LIST_ENTRY Link;
|
|
|
|
//
|
|
|
|
// Filter driver will register what record guid filter should be used.
|
|
|
|
//
|
|
|
|
EFI_SMBIOS_HANDLE SmbiosHandle;
|
|
|
|
|
|
|
|
} SMBIOS_HANDLE_ENTRY;
|
|
|
|
|
|
|
|
#define SMBIOS_HANDLE_ENTRY_FROM_LINK(link) CR (link, SMBIOS_HANDLE_ENTRY, Link, SMBIOS_HANDLE_ENTRY_SIGNATURE)
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
EFI_SMBIOS_TABLE_HEADER Header;
|
|
|
|
UINT8 Tailing[2];
|
|
|
|
} EFI_SMBIOS_TABLE_END_STRUCTURE;
|
|
|
|
|
2011-08-01 09:30:02 +02:00
|
|
|
/**
|
|
|
|
Create Smbios Table and installs the Smbios Table to the System Table.
|
2015-03-16 03:41:48 +01:00
|
|
|
|
|
|
|
@param Smbios32BitTable The flag to update 32-bit table.
|
|
|
|
@param Smbios64BitTable The flag to update 64-bit table.
|
|
|
|
|
2011-08-01 09:30:02 +02:00
|
|
|
**/
|
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
SmbiosTableConstruction (
|
2015-03-16 03:41:48 +01:00
|
|
|
BOOLEAN Smbios32BitTable,
|
|
|
|
BOOLEAN Smbios64BitTable
|
2011-08-01 09:30:02 +02:00
|
|
|
);
|
|
|
|
|
2009-11-20 05:01:32 +01:00
|
|
|
#endif
|