2011-07-19 22:47:28 +02:00
|
|
|
/** @file
|
|
|
|
|
|
|
|
Copyright (c) 2010, Intel Corporation. All rights reserved.<BR>
|
|
|
|
|
2019-04-04 01:05:13 +02:00
|
|
|
SPDX-License-Identifier: BSD-2-Clause-Patent
|
2011-07-19 22:47:28 +02:00
|
|
|
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef _SMM_LOCK_BOX_LIB_PRIVATE_H_
|
|
|
|
#define _SMM_LOCK_BOX_LIB_PRIVATE_H_
|
|
|
|
|
|
|
|
#include <Uefi.h>
|
|
|
|
|
2011-07-28 19:47:22 +02:00
|
|
|
#pragma pack(1)
|
2011-07-19 22:47:28 +02:00
|
|
|
|
|
|
|
//
|
|
|
|
// Below data structure is used for lockbox registration in SMST
|
|
|
|
//
|
|
|
|
|
2021-12-05 23:54:02 +01:00
|
|
|
#define SMM_LOCK_BOX_SIGNATURE_32 SIGNATURE_64 ('L','O','C','K','B','_','3','2')
|
|
|
|
#define SMM_LOCK_BOX_SIGNATURE_64 SIGNATURE_64 ('L','O','C','K','B','_','6','4')
|
2011-07-19 22:47:28 +02:00
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:54:02 +01:00
|
|
|
UINT64 Signature;
|
|
|
|
EFI_PHYSICAL_ADDRESS LockBoxDataAddress;
|
2011-07-19 22:47:28 +02:00
|
|
|
} SMM_LOCK_BOX_CONTEXT;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Below data structure is used for lockbox management
|
|
|
|
//
|
|
|
|
|
2021-12-05 23:54:02 +01:00
|
|
|
#define SMM_LOCK_BOX_DATA_SIGNATURE SIGNATURE_64 ('L','O','C','K','B','O','X','D')
|
2011-07-19 22:47:28 +02:00
|
|
|
|
|
|
|
typedef struct {
|
2021-12-05 23:54:02 +01:00
|
|
|
UINT64 Signature;
|
|
|
|
EFI_GUID Guid;
|
|
|
|
EFI_PHYSICAL_ADDRESS Buffer;
|
|
|
|
UINT64 Length;
|
|
|
|
UINT64 Attributes;
|
|
|
|
EFI_PHYSICAL_ADDRESS SmramBuffer;
|
|
|
|
LIST_ENTRY Link;
|
2011-07-19 22:47:28 +02:00
|
|
|
} SMM_LOCK_BOX_DATA;
|
|
|
|
|
2011-07-28 19:47:22 +02:00
|
|
|
#pragma pack()
|
2011-07-19 22:47:28 +02:00
|
|
|
|
2020-12-17 22:18:51 +01:00
|
|
|
/**
|
|
|
|
Constructor for SmmLockBox library.
|
|
|
|
This is used to set SmmLockBox context, which will be used in PEI phase in S3 boot path later.
|
|
|
|
|
|
|
|
@retval EFI_SUCEESS
|
|
|
|
@return Others Some error occurs.
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
SmmLockBoxMmConstructor (
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor for SmmLockBox library.
|
|
|
|
This is used to uninstall SmmLockBoxCommunication configuration table
|
|
|
|
if it has been installed in Constructor.
|
|
|
|
|
|
|
|
@retval EFI_SUCEESS The destructor always returns EFI_SUCCESS.
|
|
|
|
|
|
|
|
**/
|
|
|
|
EFI_STATUS
|
|
|
|
SmmLockBoxMmDestructor (
|
|
|
|
VOID
|
|
|
|
);
|
|
|
|
|
2011-07-19 22:47:28 +02:00
|
|
|
#endif
|