2007-06-15 12:02:42 +02:00
|
|
|
/** @file
|
|
|
|
GUID for use in reserving SMRAM regions.
|
|
|
|
|
2009-07-02 09:40:24 +02:00
|
|
|
Copyright (c) 2007 - 2009, Intel Corporation
|
2007-06-15 12:02:42 +02:00
|
|
|
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: SmramMemoryReserve.h
|
|
|
|
|
|
|
|
@par Revision Reference:
|
|
|
|
GUIDs defined in SmmCis spec version 0.9
|
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef _EFI_SMM_PEI_SMRAM_MEMORY_RESERVE_H_
|
|
|
|
#define _EFI_SMM_PEI_SMRAM_MEMORY_RESERVE_H_
|
|
|
|
|
2007-06-28 14:23:11 +02:00
|
|
|
#include <PiPei.h>
|
|
|
|
|
2007-06-15 12:02:42 +02:00
|
|
|
#define EFI_SMM_PEI_SMRAM_MEMORY_RESERVE \
|
|
|
|
{ \
|
|
|
|
0x6dadf1d1, 0xd4cc, 0x4910, {0xbb, 0x6e, 0x82, 0xb1, 0xfd, 0x80, 0xff, 0x3d } \
|
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// *******************************************************
|
|
|
|
// EFI_SMRAM_DESCRIPTOR
|
|
|
|
// *******************************************************
|
|
|
|
//
|
|
|
|
typedef struct {
|
2009-07-02 09:40:24 +02:00
|
|
|
EFI_PHYSICAL_ADDRESS PhysicalStart; ///< Phsyical location in DRAM
|
|
|
|
EFI_PHYSICAL_ADDRESS CpuStart; ///< Address CPU uses to access the SMI handler
|
2007-06-15 12:02:42 +02:00
|
|
|
// May or may not match PhysicalStart
|
|
|
|
//
|
|
|
|
UINT64 PhysicalSize;
|
|
|
|
UINT64 RegionState;
|
|
|
|
} EFI_SMRAM_DESCRIPTOR;
|
|
|
|
|
|
|
|
//
|
|
|
|
// *******************************************************
|
|
|
|
// EFI_SMRAM_STATE
|
|
|
|
// *******************************************************
|
|
|
|
//
|
|
|
|
#define EFI_SMRAM_OPEN 0x00000001
|
|
|
|
#define EFI_SMRAM_CLOSED 0x00000002
|
|
|
|
#define EFI_SMRAM_LOCKED 0x00000004
|
|
|
|
#define EFI_CACHEABLE 0x00000008
|
|
|
|
#define EFI_ALLOCATED 0x00000010
|
|
|
|
#define EFI_NEEDS_TESTING 0x00000020
|
|
|
|
#define EFI_NEEDS_ECC_INITIALIZATION 0x00000040
|
|
|
|
|
|
|
|
//
|
|
|
|
// *******************************************************
|
|
|
|
// EFI_SMRAM_HOB_DESCRIPTOR_BLOCK
|
|
|
|
// *******************************************************
|
|
|
|
//
|
|
|
|
typedef struct {
|
|
|
|
UINTN NumberOfSmmReservedRegions;
|
|
|
|
EFI_SMRAM_DESCRIPTOR Descriptor[1];
|
|
|
|
} EFI_SMRAM_HOB_DESCRIPTOR_BLOCK;
|
|
|
|
|
|
|
|
extern EFI_GUID gEfiSmmPeiSmramMemoryReserveGuid;
|
|
|
|
|
|
|
|
#endif
|