NAME
Tspi_TPM_DAA_JoinCreateDaaPubKey - computes the credential request for
the DAA Issuer
SYNOPSIS
#include <tss/tss_typedef.h>
#include <tss/tss_structs.h>
#include <tss/tspi.h>
TSS_RESULT Tspi_TPM_DAA_JoinCreateDaaPubKey(
TSS_HDAA hDAA,
TSS_HTPM hTPM,
UINT32 authenticationChallengeLength,
BYTE* authenticationChallenge,
UINT32 nonceIssuerLength,
BYTE* nonceIssuer,
UINT32 attributesPlatformLength,
BYTE** attributesPlatform,
TSS_DAA_JOIN_SESSION* joinSession,
TSS_DAA_CREDENTIAL_REQUEST* credentialRequest
);
DESCRIPTION
Tspi_TPM_DAA_JoinCreateDaaPubKey is the second (between
Tspi_TPM_DAA_JoinInit() and Tspi_TPM_DAA_JoinStoreCredential())
out of 3 functions to execute in order to receive a DAA Credential.
It computes the credential request for the DAA Issuer, which also
includes the Platforms’s DAA public key and the attributes that were
chosen by the Platform, and which are not visible to the DAA Issuer.
The Platform can commit to the attribute values it has chosen.
PARAMETERS
hDAA
The hDAA parameter is used to specify the handle of the DAA object.
hTPM
The hTPM parameter is the handle to the TPM object.
authenticationChallengeLength
The authenticationChallengeLength parameter is length of
authenticationChallenge (256 bytes - DAA_SIZE_NE1).
authenticationChallenge
The authenticationChallenge parameter is the second nonce of the DAA
Issuer that is encrypted by the endorsement public key. It is used as
a challenge to authenticate the underlying TPM.
nonceIssuerLength
The nonceIssuerLength parameter is the length of nonceIssuer (20
bytes).
nonceIssuer
The nonceIssuer parameter is the nonce of the DAA Issuer.
attributesPlatformLength
The attributesPlatformLength parameter is length of attributesPlatform
array, which is determined by the DAA Issuer public key (). The length
of a single attribute is ln/8. ln is defined as the size of the RSA
modulus (2048).
attributesPlatform
The attributesPlatform parameter is an array of attributes to be
encoded into the DAA Credential not visible to the DAA Issuer.
joinSession
The joinSession parameter is a structure containing the DAA Join
session information.
credentialRequest
The credentialRequest parameter is the credential request of the
Platform, it contains the blinded DAA public key of the platform on
which the DAA Issuer will issue the credential the blinded attributes
chosen by the Platform.
RETURN CODES
Tspi_TPM_DAA_JoinCreateDaaPubKey returns TSS_SUCCESS on success,
otherwise one of the following values is returned:
TSS_E_INVALID_HANDLE
Either the DAA is not valid.
TSS_E_BAD_PARAMETER
TSS_E_INTERNAL_ERROR
An internal SW error has been detected.
CONFORMING TO
Tspi_TPM_DAA_JoinCreateDaaPubKey conforms to the Trusted Computing
Group Software Specification version 1.2
SEE ALSO
Tspi_TPM_DAA_JoinInit(3) Tspi_TPM_DAA_JoinStoreCredential(3)
TSS 1.2 2006-09-0Tspi_TPM_DAA_JoinCreateDaaPubKey(3)