Tspi_TPM_GetPubEndorsementKey
Section: C Library Functions (3)
Updated: 2004-05-25
Index
Return to Main Contents
TCG Software Stack Developer's Reference
NAME
Tspi_TPM_GetPubEndorsementKey - create a TSS key object from the TPM's public endorsement key
SYNOPSIS
#include <tss/platform.h>
#include <tss/tcpa_defines.h>
#include <tss/tcpa_typedef.h>
#include <tss/tcpa_struct.h>
#include <tss/tss_typedef.h>
#include <tss/tss_structs.h>
#include <tss/tspi.h>
TSS_RESULT Tspi_TPM_GetPubEndorsementKey(TSS_HTPM hTPM, TSS_BOOL fOwnerAuthorized,
TSS_VALIDATION* pValidationData, TSS_HKEY* phEndorsementPubKey);
DESCRIPTION
Tspi_TPM_GetPubEndorsementKey
This function retrieves the public endorsement key (PubEK) from the TPM and creates a TSS
key object for it, whose handle is returned in phEndorsementPubKey. Due to
the fact that different TPM chips validate the PubEK in different ways, application
verification of the PubEK (using a non-NULL pValidationData is broken.
Tspi_TPM_GetPubEndorsementKey should be called with a NULL pValidationData parameter
to allow the TSS to verify the PubEK itself.
PARAMETERS
hTPM
The hTPM parameter is used to specify the handle of the TPM object.
fOwnerAuthorized
If TRUE, the TPM owner secret must be provided to get the public endorsement key.
If FALSE, no TPM owner secret must be provided to get the public endorsement key.
pValidationData
If non-NULL, the application should set the pValidationData->rgbExternalData parameter
to 20 bytes of random data before calling Tspi_TPM_GetPubEndorsementKey. On successful
completion of the command, the structure will provide buffers containing the validation
data and the buffer the validation data was computed from.
phEndorsementPubKey
Receives a handle to a key object representing the TPM's public endorsement key.
RETURN CODES
Tspi_TPM_GetPubEndorsementKey returns TSS_SUCCESS on success,
otherwise one of the following values is returned:
- TSS_E_INVALID_HANDLE
-
hTPM is not a valid handle.
- TSS_E_INTERNAL_ERROR
-
An internal SW error has been detected.
- TSS_E_BAD_PARAMETER
-
One or more parameters is bad.
- TPM_E_DISABLED_CMD
-
Reading of PubEK from TPM has been disabled.
CONFORMING TO
Tspi_TPM_GetPubEndorsementKey conforms to the Trusted Computing
Group Software Specification version 1.1 Golden
SEE ALSO
Tspi_Key_GetPubKey(3).