/** @file This library is only intended to be used by TPM modules. It provides basic TPM Interface Specification (TIS) functions. ;****************************************************************************** ;* Copyright (c) 2013 - 2015, Insyde Software Corp. All Rights Reserved. ;* ;* You may not reproduce, distribute, publish, display, perform, modify, adapt, ;* transmit, broadcast, present, recite, release, license or otherwise exploit ;* any part of this publication in any form, by any means, without the prior ;* written permission of Insyde Software Corporation. ;* ;****************************************************************************** */ #ifndef _TPM2_TIS_COMM_LIB_H_ #define _TPM2_TIS_COMM_LIB_H_ // // TPM register base address. // #define TPM_BASE_ADDRESS 0xfed40000 // // Set structure alignment to 1-byte // #pragma pack (1) // // Register set map as specified in TIS specification Chapter 10 // typedef struct { // // Used to gain ownership for this particular port. // UINT8 Access; // 0 UINT8 Reserved1[7]; // 1 // // Controls interrupts. // UINT32 IntEnable; // 8 // // SIRQ vector to be used by the TPM. // UINT8 IntVector; // 0ch UINT8 Reserved2[3]; // 0dh // // What caused interrupt. // UINT32 IntSts; // 10h // // Shows which interrupts are supported by that particular TPM. // UINT32 IntfCapability; // 14h // // Status Register. Provides status of the TPM. // UINT8 Status; // 18h // // Number of consecutive writes that can be done to the TPM. // UINT16 BurstCount; // 19h // // TPM2 support CANCEL at BIT[24] of STATUS register (WO) // UINT8 StatusEx; // 1Bh UINT8 Reserved3[8]; // // Read or write FIFO, depending on transaction. // UINT32 DataFifo; // 24h UINT8 Reserved4[0xed8]; // 28h // // Vendor ID // UINT16 Vid; // 0f00h // // Device ID // UINT16 Did; // 0f02h // // Revision ID // UINT8 Rid; // 0f04h // // TCG defined configuration registers. // UINT8 TcgDefined[0x7b]; // 0f05h // // Alias to I/O legacy space. // UINT32 LegacyAddress1; // 0f80h // // Additional 8 bits for I/O legacy space extension. // UINT32 LegacyAddress1Ex; // 0f84h // // Alias to second I/O legacy space. // UINT32 LegacyAddress2; // 0f88h // // Additional 8 bits for second I/O legacy space extension. // UINT32 LegacyAddress2Ex; // 0f8ch // // Vendor-defined configuration registers. // UINT8 VendorDefined[0x70];// 0f90h } TIS_PC_REGISTERS; // // Restore original structure alignment // #pragma pack () // // Define pointer types used to access TIS registers on PC // typedef TIS_PC_REGISTERS *TIS_PC_REGISTERS_PTR; // // Define bits of ACCESS and STATUS registers // // // This bit is a 1 to indicate that the other bits in this register are valid. // #define TIS_PC_VALID BIT7 // // Indicate that this locality is active. // #define TIS_PC_ACC_ACTIVE BIT5 // // Set to 1 to indicate that this locality had the TPM taken away while // this locality had the TIS_PC_ACC_ACTIVE bit set. // #define TIS_PC_ACC_SEIZED BIT4 // // 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. // #define TIS_PC_ACC_SEIZE BIT3 // // When this bit is 1, another locality is requesting usage of the TPM. // #define TIS_PC_ACC_PENDIND BIT2 // // Set to 1 to indicate that this locality is requesting to use TPM. // #define TIS_PC_ACC_RQUUSE BIT1 // // A value of 1 indicates that a T/OS has not been established on the platform // #define TIS_PC_ACC_ESTABLISH BIT0 // // When this bit is 1, TPM is in the Ready state, // indicating it is ready to receive a new command. // #define TIS_PC_STS_READY BIT6 // // Write a 1 to this bit to cause the TPM to execute that command. // #define TIS_PC_STS_GO BIT5 // // This bit indicates that the TPM has data available as a response. // #define TIS_PC_STS_DATA BIT4 // // The TPM sets this bit to a value of 1 when it expects another byte of data for a command. // #define TIS_PC_STS_EXPECT BIT3 // // Writes a 1 to this bit to force the TPM to re-send the response. // #define TIS_PC_STS_RETRY BIT1 // // Default TimeOut value // #define TIS_TIMEOUT_A (1000 * 1000) // 1s #define TIS_TIMEOUT_B (2000 * 1000) // 2s #define TIS_TIMEOUT_C (1000 * 1000) // 1s #define TIS_TIMEOUT_D (1000 * 1000) // 1s #define TIS_TIMEOUT_MAX (90000 * 1000) // 90s #define TIS_SMM_TIMEOUT ( 50 * 1000) // 0.05s /** Check whether TPM chip exist. @param[in] TisReg Pointer to TIS register. @retval TRUE TPM chip exists. @retval FALSE TPM chip is not found. **/ BOOLEAN TisPcPresenceCheck ( IN TIS_PC_REGISTERS_PTR TisReg ); /** Check whether the value of a TPM chip register satisfies the input BIT setting. @param[in] Register Address port of register to be checked. @param[in] BitSet Check these data bits are set. @param[in] BitClear Check these data bits are clear. @param[in] TimeOut The max wait time (unit MicroSecond) when checking register. @retval EFI_SUCCESS The register satisfies the check bit. @retval EFI_TIMEOUT The register can't run into the expected status in time. **/ EFI_STATUS EFIAPI TisPcWaitRegisterBits ( IN UINT8 *Register, IN UINT8 BitSet, IN UINT8 BitClear, IN UINT32 TimeOut ); /** Get BurstCount by reading the burstCount field of a TIS regiger in the time of default TIS_TIMEOUT_D. @param[in] TisReg Pointer to TIS register. @param[out] BurstCount Pointer to a buffer to store the got BurstConut. @retval EFI_SUCCESS Get BurstCount. @retval EFI_INVALID_PARAMETER TisReg is NULL or BurstCount is NULL. @retval EFI_TIMEOUT BurstCount can't be got in time. **/ EFI_STATUS EFIAPI TisPcReadBurstCount ( IN TIS_PC_REGISTERS_PTR TisReg, OUT UINT16 *BurstCount ); /** Set TPM chip to ready state by sending ready command TIS_PC_STS_READY to Status Register in time. @param[in] TisReg Pointer to TIS register. @retval EFI_SUCCESS TPM chip enters into ready state. @retval EFI_INVALID_PARAMETER TisReg is NULL. @retval EFI_TIMEOUT TPM chip can't be set to ready state in time. **/ EFI_STATUS EFIAPI TisPcPrepareCommand ( 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. @param[in] TisReg Pointer to TIS register. @retval EFI_SUCCESS Get the control of TPM chip. @retval EFI_INVALID_PARAMETER TisReg is NULL. @retval EFI_NOT_FOUND TPM chip doesn't exit. @retval EFI_TIMEOUT Can't get the TPM control in time. **/ EFI_STATUS EFIAPI TisPcRequestUseTpm ( IN TIS_PC_REGISTERS_PTR TisReg ); /** Send a command to TPM for execution. @param[in] TisReg Pointer to TIS register. @param[in] BufferIn Buffer for command data. @param[in] SizeIn Size of command data. @retval EFI_SUCCESS Operation completed successfully. @retval EFI_INVALID_PARAMETER TisReg is NULL. @retval EFI_BUFFER_TOO_SMALL Response data buffer is too small. @retval EFI_TIMEOUT The register can't run into the expected status in time. **/ EFI_STATUS TisSend ( IN TIS_PC_REGISTERS_PTR TisReg, IN UINT8 *BufferIn, IN UINT32 SizeIn ); /** Get return response data. @param[in] TisReg Pointer to TIS register. @param[out] BufferOut Buffer for response data. @param[out] SizeOut Size of response data. @retval EFI_SUCCESS Operation completed successfully. @retval EFI_INVALID_PARAMETER TisReg is NULL. @retval EFI_BUFFER_TOO_SMALL Response data buffer is too small. @retval EFI_TIMEOUT The register can't run into the expected status in time. **/ EFI_STATUS TisReceive ( IN TIS_PC_REGISTERS_PTR TisReg, IN UINT32 Timeout, IN OUT UINT8 *BufferOut, IN OUT UINT32 *SizeOut ); /** Send a command to TPM for execution and return response data. @param[in] TisReg Pointer to TIS register. @param[in] Timeout Timeout duration. @param[in] BufferIn Buffer for command data. @param[in] SizeIn Size of command data. @param[in, out] BufferOut Buffer for response data. @param[in, out] SizeOut Size of response data. @retval EFI_SUCCESS Operation completed successfully. @retval EFI_INVALID_PARAMETER TisReg is NULL. @retval EFI_BUFFER_TOO_SMALL Response data buffer is too small. @retval EFI_TIMEOUT The register can't run into the expected status in time. **/ EFI_STATUS TisTpmCommand ( IN TIS_PC_REGISTERS_PTR TisReg, IN UINT32 Timeout, IN UINT8 *BufferIn, IN UINT32 SizeIn, IN OUT UINT8 *BufferOut, IN OUT UINT32 *SizeOut ); #endif //_TPM2_TIS_COMM_LIB_H_