TianoCore EDK2 master
|
#include <IndustryStandard/Tpm12.h>
Go to the source code of this file.
Data Structures | |
struct | TIS_PC_REGISTERS |
Macros | |
#define | TPM_BASE_ADDRESS 0xfed40000 |
#define | TCG_PLATFORM_TYPE_CLIENT 0 |
#define | TCG_PLATFORM_TYPE_SERVER 1 |
#define | TIS_PC_VALID BIT7 |
#define | TIS_PC_ACC_ACTIVE BIT5 |
#define | TIS_PC_ACC_SEIZED BIT4 |
#define | TIS_PC_ACC_SEIZE BIT3 |
#define | TIS_PC_ACC_PENDIND BIT2 |
#define | TIS_PC_ACC_RQUUSE BIT1 |
#define | TIS_PC_ACC_ESTABLISH BIT0 |
#define | TIS_PC_STS_READY BIT6 |
#define | TIS_PC_STS_GO BIT5 |
#define | TIS_PC_STS_DATA BIT4 |
#define | TIS_PC_STS_EXPECT BIT3 |
#define | TIS_PC_STS_RETRY BIT1 |
#define | TIS_TIMEOUT_A 750 * 1000 |
#define | TIS_TIMEOUT_B 2000 * 1000 |
#define | TIS_TIMEOUT_C 750 * 1000 |
#define | TIS_TIMEOUT_D 750 * 1000 |
#define | TPMCMDBUFLENGTH 1024 |
Typedefs | |
typedef EFI_HANDLE | TIS_TPM_HANDLE |
typedef TIS_PC_REGISTERS * | TIS_PC_REGISTERS_PTR |
Functions | |
EFI_STATUS EFIAPI | TisPcWaitRegisterBits (IN UINT8 *Register, IN UINT8 BitSet, IN UINT8 BitClear, IN UINT32 TimeOut) |
EFI_STATUS EFIAPI | TisPcReadBurstCount (IN TIS_PC_REGISTERS_PTR TisReg, OUT UINT16 *BurstCount) |
EFI_STATUS EFIAPI | TisPcPrepareCommand (IN TIS_PC_REGISTERS_PTR TisReg) |
EFI_STATUS EFIAPI | TisPcRequestUseTpm (IN TIS_PC_REGISTERS_PTR TisReg) |
EFI_STATUS EFIAPI | TpmCommHashAll (IN CONST UINT8 *Data, IN UINTN DataLen, OUT TPM_DIGEST *Digest) |
This library is only intended to be used by TPM modules. It provides basic TPM Interface Specification (TIS) and Command functions.
Copyright (c) 2005 - 2018, Intel Corporation. All rights reserved.
SPDX-License-Identifier: BSD-2-Clause-Patent
Definition in file TpmCommLib.h.
#define TCG_PLATFORM_TYPE_CLIENT 0 |
Definition at line 118 of file TpmCommLib.h.
#define TCG_PLATFORM_TYPE_SERVER 1 |
Definition at line 119 of file TpmCommLib.h.
#define TIS_PC_ACC_ACTIVE BIT5 |
Indicate that this locality is active.
Definition at line 132 of file TpmCommLib.h.
#define TIS_PC_ACC_ESTABLISH BIT0 |
A value of 1 indicates that a T/OS has not been established on the platform
Definition at line 155 of file TpmCommLib.h.
#define TIS_PC_ACC_PENDIND BIT2 |
When this bit is 1, another locality is requesting usage of the TPM.
Definition at line 147 of file TpmCommLib.h.
#define TIS_PC_ACC_RQUUSE BIT1 |
Set to 1 to indicate that this locality is requesting to use TPM.
Definition at line 151 of file TpmCommLib.h.
#define TIS_PC_ACC_SEIZE BIT3 |
Set to 1 to indicate that TPM MUST reset the TIS_PC_ACC_ACTIVE bit and remove ownership for localities less than the locality that is writing this bit.
Definition at line 143 of file TpmCommLib.h.
#define TIS_PC_ACC_SEIZED BIT4 |
Set to 1 to indicate that this locality had the TPM taken away while this locality had the TIS_PC_ACC_ACTIVE bit set.
Definition at line 137 of file TpmCommLib.h.
#define TIS_PC_STS_DATA BIT4 |
This bit indicates that the TPM has data available as a response.
Definition at line 169 of file TpmCommLib.h.
#define TIS_PC_STS_EXPECT BIT3 |
The TPM sets this bit to a value of 1 when it expects another byte of data for a command.
Definition at line 173 of file TpmCommLib.h.
#define TIS_PC_STS_GO BIT5 |
Write a 1 to this bit to cause the TPM to execute that command.
Definition at line 165 of file TpmCommLib.h.
#define TIS_PC_STS_READY BIT6 |
When this bit is 1, TPM is in the Ready state, indicating it is ready to receive a new command.
Definition at line 161 of file TpmCommLib.h.
#define TIS_PC_STS_RETRY BIT1 |
Writes a 1 to this bit to force the TPM to re-send the response.
Definition at line 177 of file TpmCommLib.h.
#define TIS_PC_VALID BIT7 |
This bit is a 1 to indicate that the other bits in this register are valid.
Definition at line 128 of file TpmCommLib.h.
#define TIS_TIMEOUT_A 750 * 1000 |
Definition at line 182 of file TpmCommLib.h.
#define TIS_TIMEOUT_B 2000 * 1000 |
Definition at line 183 of file TpmCommLib.h.
#define TIS_TIMEOUT_C 750 * 1000 |
Definition at line 184 of file TpmCommLib.h.
#define TIS_TIMEOUT_D 750 * 1000 |
Definition at line 185 of file TpmCommLib.h.
#define TPM_BASE_ADDRESS 0xfed40000 |
TPM register base address.
Definition at line 20 of file TpmCommLib.h.
#define TPMCMDBUFLENGTH 1024 |
Definition at line 190 of file TpmCommLib.h.
typedef TIS_PC_REGISTERS* TIS_PC_REGISTERS_PTR |
Definition at line 113 of file TpmCommLib.h.
typedef EFI_HANDLE TIS_TPM_HANDLE |
Definition at line 15 of file TpmCommLib.h.
EFI_STATUS EFIAPI TisPcPrepareCommand | ( | IN TIS_PC_REGISTERS_PTR | TisReg | ) |
Set TPM chip to ready state by sending ready command TIS_PC_STS_READY to Status Register in time.
[in] | TisReg | Pointer to TIS register. |
EFI_SUCCESS | TPM chip enters into ready state. |
EFI_INVALID_PARAMETER | TisReg is NULL. |
EFI_TIMEOUT | TPM chip can't be set to ready state in time. |
EFI_STATUS EFIAPI TisPcReadBurstCount | ( | IN TIS_PC_REGISTERS_PTR | TisReg, |
OUT UINT16 * | BurstCount | ||
) |
Get BurstCount by reading the burstCount field of a TIS register in the time of default TIS_TIMEOUT_D.
[in] | TisReg | Pointer to TIS register. |
[out] | BurstCount | Pointer to a buffer to store the got BurstCount. |
EFI_SUCCESS | Get BurstCount. |
EFI_INVALID_PARAMETER | TisReg is NULL or BurstCount is NULL. |
EFI_TIMEOUT | BurstCount can't be got in time. |
EFI_STATUS EFIAPI TisPcRequestUseTpm | ( | IN TIS_PC_REGISTERS_PTR | TisReg | ) |
Get the control of TPM chip by sending requestUse command TIS_PC_ACC_RQUUSE to ACCESS Register in the time of default TIS_TIMEOUT_D.
[in] | TisReg | Pointer to TIS register. |
EFI_SUCCESS | Get the control of TPM chip. |
EFI_INVALID_PARAMETER | TisReg is NULL. |
EFI_NOT_FOUND | TPM chip doesn't exit. |
EFI_TIMEOUT | Can't get the TPM control in time. |
Get the control of TPM chip by sending requestUse command TIS_PC_ACC_RQUUSE to ACCESS Register in the time of default TIS_TIMEOUT_A.
[in] | TisReg | Pointer to TIS register. |
EFI_SUCCESS | Get the control of TPM chip. |
EFI_INVALID_PARAMETER | TisReg is NULL. |
EFI_NOT_FOUND | TPM chip doesn't exit. |
EFI_TIMEOUT | Can't get the TPM control in time. |
EFI_STATUS EFIAPI TisPcWaitRegisterBits | ( | IN UINT8 * | Register, |
IN UINT8 | BitSet, | ||
IN UINT8 | BitClear, | ||
IN UINT32 | TimeOut | ||
) |
Check whether the value of a TPM chip register satisfies the input BIT setting.
[in] | Register | Address port of register to be checked. |
[in] | BitSet | Check these data bits are set. |
[in] | BitClear | Check these data bits are clear. |
[in] | TimeOut | The max wait time (unit MicroSecond) when checking register. |
EFI_SUCCESS | The register satisfies the check bit. |
EFI_TIMEOUT | The register can't run into the expected status in time. |
EFI_STATUS EFIAPI TpmCommHashAll | ( | IN CONST UINT8 * | Data, |
IN UINTN | DataLen, | ||
OUT TPM_DIGEST * | Digest | ||
) |
Single function calculates SHA1 digest value for all raw data. It combines Sha1Init(), Sha1Update() and Sha1Final().
[in] | Data | Raw data to be digested. |
[in] | DataLen | Size of the raw data. |
[out] | Digest | Pointer to a buffer that stores the final digest. |
EFI_SUCCESS | Always successfully calculate the final digest. |