2007-06-28 09:00:39 +02:00
|
|
|
/*++
|
|
|
|
|
|
|
|
Copyright (c) 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:
|
|
|
|
|
|
|
|
TcgService.h
|
|
|
|
|
|
|
|
Abstract:
|
|
|
|
|
|
|
|
TCG Service Protocol as defined in TCG_EFI_Protocol_1_20_Final
|
|
|
|
|
|
|
|
See http://trustedcomputinggroup.org for the latest specification
|
|
|
|
|
|
|
|
--*/
|
|
|
|
|
|
|
|
#ifndef _TCG_SERVICE_PROTOCOL_H_
|
|
|
|
#define _TCG_SERVICE_PROTOCOL_H_
|
|
|
|
|
1) Sync EdkCompatibilityPkg with EDK 1.04. The changes includes:
1.1) Bug fixes. (For details, please check Documents & files: Snapshot/Release Notes at https://edk.tianocore.org/servlets/ProjectDocumentList?folderID=43&expandFolder=43&folderID=6)
1.2) Add new UEFI protocol definitions for AbsolutePointer, FormBrowser2, HiiConfigAccess, HiiConfigRouting, HiiDatabase, HiiFont, HiiImage, HiiString, SimpleTextInputEx, DPC protocol.
1.3) Add Smbios 2.5, 2.6 supports.
Incompatible changes hilighted:
1) EFI_MANAGED_NETWORK_PROTOCOL_GUID changed.
2) EFI_IP4_IPCONFIG_DATA changed.
2) Add in EdkCompatibilityPkg/EdkCompatibilityPkg.dsc to build all libraries in this package.
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@4623 6f19259b-4bc3-4df7-8a09-765794883524
2008-01-24 08:10:05 +01:00
|
|
|
#include "EfiTpm.h"
|
2007-06-28 09:00:39 +02:00
|
|
|
|
|
|
|
#define EFI_TCG_PROTOCOL_GUID \
|
|
|
|
{0xf541796d, 0xa62e, 0x4954, 0xa7, 0x75, 0x95, 0x84, 0xf6, 0x1b, 0x9c, 0xdd}
|
|
|
|
|
1) Sync EdkCompatibilityPkg with EDK 1.04. The changes includes:
1.1) Bug fixes. (For details, please check Documents & files: Snapshot/Release Notes at https://edk.tianocore.org/servlets/ProjectDocumentList?folderID=43&expandFolder=43&folderID=6)
1.2) Add new UEFI protocol definitions for AbsolutePointer, FormBrowser2, HiiConfigAccess, HiiConfigRouting, HiiDatabase, HiiFont, HiiImage, HiiString, SimpleTextInputEx, DPC protocol.
1.3) Add Smbios 2.5, 2.6 supports.
Incompatible changes hilighted:
1) EFI_MANAGED_NETWORK_PROTOCOL_GUID changed.
2) EFI_IP4_IPCONFIG_DATA changed.
2) Add in EdkCompatibilityPkg/EdkCompatibilityPkg.dsc to build all libraries in this package.
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@4623 6f19259b-4bc3-4df7-8a09-765794883524
2008-01-24 08:10:05 +01:00
|
|
|
#define EFI_TCG_PLATFORM_PROTOCOL_GUID \
|
|
|
|
{ 0x8c4c9a41, 0xbf56, 0x4627, 0x9e, 0xa, 0xc8, 0x38, 0x6d, 0x66, 0x11, 0x5c }
|
|
|
|
|
2007-06-28 09:00:39 +02:00
|
|
|
#define TSS_EVENT_DATA_MAX_SIZE 256
|
|
|
|
|
1) Sync EdkCompatibilityPkg with EDK 1.04. The changes includes:
1.1) Bug fixes. (For details, please check Documents & files: Snapshot/Release Notes at https://edk.tianocore.org/servlets/ProjectDocumentList?folderID=43&expandFolder=43&folderID=6)
1.2) Add new UEFI protocol definitions for AbsolutePointer, FormBrowser2, HiiConfigAccess, HiiConfigRouting, HiiDatabase, HiiFont, HiiImage, HiiString, SimpleTextInputEx, DPC protocol.
1.3) Add Smbios 2.5, 2.6 supports.
Incompatible changes hilighted:
1) EFI_MANAGED_NETWORK_PROTOCOL_GUID changed.
2) EFI_IP4_IPCONFIG_DATA changed.
2) Add in EdkCompatibilityPkg/EdkCompatibilityPkg.dsc to build all libraries in this package.
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@4623 6f19259b-4bc3-4df7-8a09-765794883524
2008-01-24 08:10:05 +01:00
|
|
|
#define EFI_CALLING_EFI_APPLICATION \
|
|
|
|
"Calling EFI Application from Boot Option"
|
|
|
|
#define EFI_RETURNING_FROM_EFI_APPLICATOIN \
|
|
|
|
"Returning from EFI Application from Boot Option"
|
|
|
|
#define EFI_EXIT_BOOT_SERVICES_INVOCATION \
|
|
|
|
"Exit Boot Services Invocation"
|
|
|
|
#define EFI_EXIT_BOOT_SERVICES_FAILED \
|
|
|
|
"Exit Boot Services Returned with Failure"
|
|
|
|
#define EFI_EXIT_BOOT_SERVICES_SUCCEEDED \
|
|
|
|
"Exit Boot Services Returned with Success"
|
|
|
|
|
2007-06-28 09:00:39 +02:00
|
|
|
EFI_FORWARD_DECLARATION (EFI_TCG_PROTOCOL);
|
|
|
|
|
|
|
|
//
|
|
|
|
// Set structure alignment to 1-byte
|
|
|
|
//
|
|
|
|
#pragma pack (push, 1)
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
UINT8 Major;
|
|
|
|
UINT8 Minor;
|
|
|
|
UINT8 RevMajor;
|
|
|
|
UINT8 RevMinor;
|
|
|
|
} TCG_VERSION;
|
|
|
|
|
|
|
|
typedef struct _TCG_EFI_BOOT_SERVICE_CAPABILITY {
|
|
|
|
UINT8 Size; // Size of this structure
|
|
|
|
TCG_VERSION StructureVersion;
|
|
|
|
TCG_VERSION ProtocolSpecVersion;
|
|
|
|
UINT8 HashAlgorithmBitmap; // Hash algorithms
|
|
|
|
// this protocol is capable of : 01=SHA-1
|
|
|
|
BOOLEAN TPMPresentFlag; // 00h = TPM not present
|
|
|
|
BOOLEAN TPMDeactivatedFlag; // 01h = TPM currently deactivated
|
|
|
|
} TCG_EFI_BOOT_SERVICE_CAPABILITY;
|
|
|
|
|
|
|
|
typedef UINT32 TCG_ALGORITHM_ID;
|
|
|
|
|
|
|
|
//
|
|
|
|
// Restore original structure alignment
|
|
|
|
//
|
|
|
|
#pragma pack (pop)
|
|
|
|
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *EFI_TCG_STATUS_CHECK) (
|
|
|
|
IN EFI_TCG_PROTOCOL *This,
|
|
|
|
OUT TCG_EFI_BOOT_SERVICE_CAPABILITY
|
|
|
|
*ProtocolCapability,
|
|
|
|
OUT UINT32 *TCGFeatureFlags,
|
|
|
|
OUT EFI_PHYSICAL_ADDRESS *EventLogLocation,
|
|
|
|
OUT EFI_PHYSICAL_ADDRESS *EventLogLastEntry
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *EFI_TCG_HASH_ALL) (
|
|
|
|
IN EFI_TCG_PROTOCOL *This,
|
|
|
|
IN UINT8 *HashData,
|
|
|
|
IN UINT64 HashDataLen,
|
|
|
|
IN TCG_ALGORITHM_ID AlgorithmId,
|
|
|
|
IN OUT UINT64 *HashedDataLen,
|
|
|
|
IN OUT UINT8 **HashedDataResult
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *EFI_TCG_LOG_EVENT) (
|
|
|
|
IN EFI_TCG_PROTOCOL *This,
|
|
|
|
IN TCG_PCR_EVENT *TCGLogData,
|
|
|
|
IN OUT UINT32 *EventNumber,
|
|
|
|
IN UINT32 Flags
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *EFI_TCG_PASS_THROUGH_TO_TPM) (
|
|
|
|
IN EFI_TCG_PROTOCOL *This,
|
|
|
|
IN UINT32 TpmInputParamterBlockSize,
|
|
|
|
IN UINT8 *TpmInputParamterBlock,
|
|
|
|
IN UINT32 TpmOutputParameterBlockSize,
|
|
|
|
IN UINT8 *TpmOutputParameterBlock
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *EFI_TCG_HASH_LOG_EXTEND_EVENT) (
|
|
|
|
IN EFI_TCG_PROTOCOL *This,
|
|
|
|
IN UINT8 *HashData,
|
|
|
|
IN UINT64 HashDataLen,
|
|
|
|
IN TCG_ALGORITHM_ID AlgorithmId,
|
|
|
|
IN OUT TCG_PCR_EVENT *TCGLogData,
|
|
|
|
IN OUT UINT32 *EventNumber,
|
|
|
|
OUT EFI_PHYSICAL_ADDRESS *EventLogLastEntry
|
|
|
|
);
|
|
|
|
|
2008-03-20 21:45:58 +01:00
|
|
|
struct _EFI_TCG_PROTOCOL {
|
2007-06-28 09:00:39 +02:00
|
|
|
EFI_TCG_STATUS_CHECK StatusCheck;
|
|
|
|
EFI_TCG_HASH_ALL HashAll;
|
|
|
|
EFI_TCG_LOG_EVENT LogEvent;
|
|
|
|
EFI_TCG_PASS_THROUGH_TO_TPM PassThroughToTpm;
|
|
|
|
EFI_TCG_HASH_LOG_EXTEND_EVENT HashLogExtendEvent;
|
2008-03-20 21:45:58 +01:00
|
|
|
};
|
2007-06-28 09:00:39 +02:00
|
|
|
|
|
|
|
extern EFI_GUID gEfiTcgProtocolGuid;
|
|
|
|
|
1) Sync EdkCompatibilityPkg with EDK 1.04. The changes includes:
1.1) Bug fixes. (For details, please check Documents & files: Snapshot/Release Notes at https://edk.tianocore.org/servlets/ProjectDocumentList?folderID=43&expandFolder=43&folderID=6)
1.2) Add new UEFI protocol definitions for AbsolutePointer, FormBrowser2, HiiConfigAccess, HiiConfigRouting, HiiDatabase, HiiFont, HiiImage, HiiString, SimpleTextInputEx, DPC protocol.
1.3) Add Smbios 2.5, 2.6 supports.
Incompatible changes hilighted:
1) EFI_MANAGED_NETWORK_PROTOCOL_GUID changed.
2) EFI_IP4_IPCONFIG_DATA changed.
2) Add in EdkCompatibilityPkg/EdkCompatibilityPkg.dsc to build all libraries in this package.
git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@4623 6f19259b-4bc3-4df7-8a09-765794883524
2008-01-24 08:10:05 +01:00
|
|
|
//
|
|
|
|
// EFI TCG Platform Protocol
|
|
|
|
//
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *EFI_TCG_MEASURE_PE_IMAGE) (
|
|
|
|
IN BOOLEAN BootPolicy,
|
|
|
|
IN EFI_PHYSICAL_ADDRESS ImageAddress,
|
|
|
|
IN UINTN ImageSize,
|
|
|
|
IN UINTN LinkTimeBase,
|
|
|
|
IN UINT16 ImageType,
|
|
|
|
IN EFI_HANDLE DeviceHandle,
|
|
|
|
IN EFI_DEVICE_PATH_PROTOCOL *FilePath
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
|
|
|
(EFIAPI *EFI_TCG_MEASURE_ACTION) (
|
|
|
|
IN CHAR8 *ActionString
|
|
|
|
);
|
|
|
|
|
|
|
|
typedef struct tdEFI_TCG_PLATFORM_PROTOCOL {
|
|
|
|
EFI_TCG_MEASURE_PE_IMAGE MeasurePeImage;
|
|
|
|
EFI_TCG_MEASURE_ACTION MeasureAction;
|
|
|
|
} EFI_TCG_PLATFORM_PROTOCOL;
|
|
|
|
|
|
|
|
extern EFI_GUID gEfiTcgPlatformProtocolGuid;
|
|
|
|
|
2007-06-28 09:00:39 +02:00
|
|
|
#endif
|