2008-05-27 05:24:01 +02:00
|
|
|
/** @file
|
2014-10-24 10:35:43 +02:00
|
|
|
TCG Service Protocol as defined in TCG_EFI_Protocol_1_22_Final
|
2008-05-27 05:24:01 +02:00
|
|
|
See http://trustedcomputinggroup.org for the latest specification
|
|
|
|
|
2018-06-27 15:11:33 +02:00
|
|
|
Copyright (c) 2007 - 2018, Intel Corporation. All rights reserved.<BR>
|
|
|
|
This program and the accompanying materials are licensed and made available under
|
|
|
|
the terms and conditions of the BSD License that accompanies this distribution.
|
2010-03-12 23:19:12 +01:00
|
|
|
The full text of the license may be found at
|
2018-06-27 15:11:33 +02:00
|
|
|
http://opensource.org/licenses/bsd-license.php.
|
|
|
|
|
|
|
|
THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
|
2010-03-12 23:19:12 +01:00
|
|
|
WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
2008-05-27 05:24:01 +02:00
|
|
|
|
2008-02-25 08:01:44 +01:00
|
|
|
**/
|
2008-01-02 07:43:26 +01:00
|
|
|
|
|
|
|
#ifndef _TCG_SERVICE_PROTOCOL_H_
|
|
|
|
#define _TCG_SERVICE_PROTOCOL_H_
|
|
|
|
|
2008-12-12 09:51:16 +01:00
|
|
|
#include <IndustryStandard/UefiTcgPlatform.h>
|
2008-01-02 07:43:26 +01:00
|
|
|
|
|
|
|
#define EFI_TCG_PROTOCOL_GUID \
|
2018-06-27 15:11:33 +02:00
|
|
|
{0xf541796d, 0xa62e, 0x4954, { 0xa7, 0x75, 0x95, 0x84, 0xf6, 0x1b, 0x9c, 0xdd } }
|
2008-01-02 07:43:26 +01:00
|
|
|
|
|
|
|
typedef struct _EFI_TCG_PROTOCOL EFI_TCG_PROTOCOL;
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
UINT8 Major;
|
|
|
|
UINT8 Minor;
|
|
|
|
UINT8 RevMajor;
|
|
|
|
UINT8 RevMinor;
|
|
|
|
} TCG_VERSION;
|
|
|
|
|
|
|
|
typedef struct _TCG_EFI_BOOT_SERVICE_CAPABILITY {
|
2010-03-12 23:19:12 +01:00
|
|
|
UINT8 Size; /// Size of this structure.
|
2018-06-27 15:11:33 +02:00
|
|
|
TCG_VERSION StructureVersion;
|
2008-01-02 07:43:26 +01:00
|
|
|
TCG_VERSION ProtocolSpecVersion;
|
2018-06-27 15:11:33 +02:00
|
|
|
UINT8 HashAlgorithmBitmap; /// Hash algorithms .
|
2010-03-12 23:19:12 +01:00
|
|
|
/// This protocol is capable of : 01=SHA-1.
|
|
|
|
BOOLEAN TPMPresentFlag; /// 00h = TPM not present.
|
|
|
|
BOOLEAN TPMDeactivatedFlag; /// 01h = TPM currently deactivated.
|
2008-01-02 07:43:26 +01:00
|
|
|
} TCG_EFI_BOOT_SERVICE_CAPABILITY;
|
|
|
|
|
|
|
|
typedef UINT32 TCG_ALGORITHM_ID;
|
|
|
|
|
2008-02-25 08:01:44 +01:00
|
|
|
/**
|
2018-06-27 15:11:33 +02:00
|
|
|
This service provides EFI protocol capability information, state information
|
2008-02-25 08:01:44 +01:00
|
|
|
about the TPM, and Event Log state information.
|
|
|
|
|
|
|
|
@param This Indicates the calling context
|
2018-06-27 15:11:33 +02:00
|
|
|
@param ProtocolCapability The callee allocates memory for a TCG_BOOT_SERVICE_CAPABILITY
|
|
|
|
structure and fills in the fields with the EFI protocol
|
2008-02-25 08:01:44 +01:00
|
|
|
capability information and the current TPM state information.
|
2018-06-27 15:11:33 +02:00
|
|
|
@param TCGFeatureFlags This is a pointer to the feature flags. No feature
|
|
|
|
flags are currently defined so this parameter
|
|
|
|
MUST be set to 0. However, in the future,
|
|
|
|
feature flags may be defined that, for example,
|
2008-02-25 08:01:44 +01:00
|
|
|
enable hash algorithm agility.
|
|
|
|
@param EventLogLocation This is a pointer to the address of the event log in memory.
|
2018-06-27 15:11:33 +02:00
|
|
|
@param EventLogLastEntry If the Event Log contains more than one entry,
|
|
|
|
this is a pointer to the address of the start of
|
|
|
|
the last entry in the event log in memory.
|
2008-02-25 08:01:44 +01:00
|
|
|
|
2010-03-12 23:19:12 +01:00
|
|
|
@retval EFI_SUCCESS The operation completed successfully.
|
2009-12-11 05:32:30 +01:00
|
|
|
@retval EFI_INVALID_PARAMETER ProtocolCapability does not match TCG capability.
|
2008-02-25 08:01:44 +01:00
|
|
|
**/
|
2008-01-02 07:43:26 +01:00
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_TCG_STATUS_CHECK)(
|
2008-01-02 07:43:26 +01:00
|
|
|
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
|
|
|
|
);
|
|
|
|
|
2008-02-25 08:01:44 +01:00
|
|
|
/**
|
|
|
|
This service abstracts the capability to do a hash operation on a data buffer.
|
2018-06-27 15:11:33 +02:00
|
|
|
|
2010-03-12 23:19:12 +01:00
|
|
|
@param This Indicates the calling context.
|
|
|
|
@param HashData The pointer to the data buffer to be hashed.
|
|
|
|
@param HashDataLen The length of the data buffer to be hashed.
|
|
|
|
@param AlgorithmId Identification of the Algorithm to use for the hashing operation.
|
|
|
|
@param HashedDataLen Resultant length of the hashed data.
|
|
|
|
@param HashedDataResult Resultant buffer of the hashed data.
|
2018-06-27 15:11:33 +02:00
|
|
|
|
2010-03-12 23:19:12 +01:00
|
|
|
@retval EFI_SUCCESS The operation completed successfully.
|
2009-12-11 05:32:30 +01:00
|
|
|
@retval EFI_INVALID_PARAMETER HashDataLen is NULL.
|
|
|
|
@retval EFI_INVALID_PARAMETER HashDataLenResult is NULL.
|
|
|
|
@retval EFI_OUT_OF_RESOURCES Cannot allocate buffer of size *HashedDataLen.
|
|
|
|
@retval EFI_UNSUPPORTED AlgorithmId not supported.
|
|
|
|
@retval EFI_BUFFER_TOO_SMALL *HashedDataLen < sizeof (TCG_DIGEST).
|
2008-02-25 08:01:44 +01:00
|
|
|
**/
|
2008-01-02 07:43:26 +01:00
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_TCG_HASH_ALL)(
|
2008-01-02 07:43:26 +01:00
|
|
|
IN EFI_TCG_PROTOCOL *This,
|
|
|
|
IN UINT8 *HashData,
|
|
|
|
IN UINT64 HashDataLen,
|
|
|
|
IN TCG_ALGORITHM_ID AlgorithmId,
|
|
|
|
IN OUT UINT64 *HashedDataLen,
|
|
|
|
IN OUT UINT8 **HashedDataResult
|
|
|
|
);
|
|
|
|
|
2008-02-25 08:01:44 +01:00
|
|
|
/**
|
|
|
|
This service abstracts the capability to add an entry to the Event Log.
|
|
|
|
|
|
|
|
@param This Indicates the calling context
|
2018-06-27 15:11:33 +02:00
|
|
|
@param TCGLogData The pointer to the start of the data buffer containing
|
|
|
|
the TCG_PCR_EVENT data structure. All fields in
|
2008-02-25 08:01:44 +01:00
|
|
|
this structure are properly filled by the caller.
|
2010-03-12 23:19:12 +01:00
|
|
|
@param EventNumber The event number of the event just logged.
|
2018-06-27 15:11:33 +02:00
|
|
|
@param Flags Indicates additional flags. Only one flag has been
|
|
|
|
defined at this time, which is 0x01 and means the
|
|
|
|
extend operation should not be performed. All
|
|
|
|
other bits are reserved.
|
|
|
|
|
2010-03-12 23:19:12 +01:00
|
|
|
@retval EFI_SUCCESS The operation completed successfully.
|
2009-12-11 05:32:30 +01:00
|
|
|
@retval EFI_OUT_OF_RESOURCES Insufficient memory in the event log to complete this action.
|
2008-02-25 08:01:44 +01:00
|
|
|
**/
|
2008-01-02 07:43:26 +01:00
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_TCG_LOG_EVENT)(
|
2008-01-02 07:43:26 +01:00
|
|
|
IN EFI_TCG_PROTOCOL *This,
|
|
|
|
IN TCG_PCR_EVENT *TCGLogData,
|
|
|
|
IN OUT UINT32 *EventNumber,
|
|
|
|
IN UINT32 Flags
|
|
|
|
);
|
|
|
|
|
2008-02-25 08:01:44 +01:00
|
|
|
/**
|
|
|
|
This service is a proxy for commands to the TPM.
|
|
|
|
|
2010-03-12 23:19:12 +01:00
|
|
|
@param This Indicates the calling context.
|
|
|
|
@param TpmInputParameterBlockSize Size of the TPM input parameter block.
|
|
|
|
@param TpmInputParameterBlock The pointer to the TPM input parameter block.
|
|
|
|
@param TpmOutputParameterBlockSize Size of the TPM output parameter block.
|
|
|
|
@param TpmOutputParameterBlock The pointer to the TPM output parameter block.
|
2008-02-25 08:01:44 +01:00
|
|
|
|
2010-03-12 23:19:12 +01:00
|
|
|
@retval EFI_SUCCESS The operation completed successfully.
|
2009-12-11 05:32:30 +01:00
|
|
|
@retval EFI_INVALID_PARAMETER Invalid ordinal.
|
|
|
|
@retval EFI_UNSUPPORTED Current Task Priority Level >= EFI_TPL_CALLBACK.
|
|
|
|
@retval EFI_TIMEOUT The TIS timed-out.
|
2008-02-25 08:01:44 +01:00
|
|
|
**/
|
2008-01-02 07:43:26 +01:00
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_TCG_PASS_THROUGH_TO_TPM)(
|
2008-01-02 07:43:26 +01:00
|
|
|
IN EFI_TCG_PROTOCOL *This,
|
2009-07-03 05:21:53 +02:00
|
|
|
IN UINT32 TpmInputParameterBlockSize,
|
|
|
|
IN UINT8 *TpmInputParameterBlock,
|
2008-01-02 07:43:26 +01:00
|
|
|
IN UINT32 TpmOutputParameterBlockSize,
|
|
|
|
IN UINT8 *TpmOutputParameterBlock
|
|
|
|
);
|
|
|
|
|
2008-02-25 08:01:44 +01:00
|
|
|
/**
|
|
|
|
This service abstracts the capability to do a hash operation on a data buffer, extend a specific TPM PCR with the hash result, and add an entry to the Event Log
|
|
|
|
|
|
|
|
@param This Indicates the calling context
|
2018-06-27 15:11:33 +02:00
|
|
|
@param HashData The physical address of the start of the data buffer
|
2008-02-25 08:01:44 +01:00
|
|
|
to be hashed, extended, and logged.
|
|
|
|
@param HashDataLen The length, in bytes, of the buffer referenced by HashData
|
|
|
|
@param AlgorithmId Identification of the Algorithm to use for the hashing operation
|
2018-06-27 15:11:33 +02:00
|
|
|
@param TCGLogData The physical address of the start of the data
|
2008-02-25 08:01:44 +01:00
|
|
|
buffer containing the TCG_PCR_EVENT data structure.
|
|
|
|
@param EventNumber The event number of the event just logged.
|
2018-06-27 15:11:33 +02:00
|
|
|
@param EventLogLastEntry The physical address of the first byte of the entry
|
|
|
|
just placed in the Event Log. If the Event Log was
|
|
|
|
empty when this function was called then this physical
|
|
|
|
address will be the same as the physical address of
|
2008-02-25 08:01:44 +01:00
|
|
|
the start of the Event Log.
|
|
|
|
|
2010-03-12 23:19:12 +01:00
|
|
|
@retval EFI_SUCCESS The operation completed successfully.
|
2009-12-11 05:32:30 +01:00
|
|
|
@retval EFI_UNSUPPORTED AlgorithmId != TPM_ALG_SHA.
|
|
|
|
@retval EFI_UNSUPPORTED Current TPL >= EFI_TPL_CALLBACK.
|
2008-02-25 08:01:44 +01:00
|
|
|
@retval EFI_DEVICE_ERROR The command was unsuccessful.
|
|
|
|
**/
|
2008-01-02 07:43:26 +01:00
|
|
|
typedef
|
|
|
|
EFI_STATUS
|
2008-06-24 09:14:18 +02:00
|
|
|
(EFIAPI *EFI_TCG_HASH_LOG_EXTEND_EVENT)(
|
2008-01-02 07:43:26 +01:00
|
|
|
IN EFI_TCG_PROTOCOL *This,
|
2008-03-04 10:33:30 +01:00
|
|
|
IN EFI_PHYSICAL_ADDRESS HashData,
|
2008-01-02 07:43:26 +01:00
|
|
|
IN UINT64 HashDataLen,
|
|
|
|
IN TCG_ALGORITHM_ID AlgorithmId,
|
|
|
|
IN OUT TCG_PCR_EVENT *TCGLogData,
|
|
|
|
IN OUT UINT32 *EventNumber,
|
|
|
|
OUT EFI_PHYSICAL_ADDRESS *EventLogLastEntry
|
|
|
|
);
|
|
|
|
|
2008-10-13 04:54:29 +02:00
|
|
|
///
|
|
|
|
/// The EFI_TCG Protocol abstracts TCG activity.
|
|
|
|
///
|
2008-07-28 20:42:42 +02:00
|
|
|
struct _EFI_TCG_PROTOCOL {
|
2008-01-02 07:43:26 +01: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-07-28 20:42:42 +02:00
|
|
|
};
|
2008-01-02 07:43:26 +01:00
|
|
|
|
|
|
|
extern EFI_GUID gEfiTcgProtocolGuid;
|
|
|
|
|
|
|
|
#endif
|