Provided by: libtspi-dev_0.3.15-0.3_amd64 bug

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).