blob: 42092241473e464f7dbb568678a704153eddec77 [file] [log] [blame]
Andreas Fuchs2968c712018-02-01 18:22:47 +01001/*!
Andreas Fuchs2968c712018-02-01 18:22:47 +01002 \defgroup esys Enhanced System API
3 \todo Description
4*/
5
6/*!
7 \defgroup esys_context Esys Context ESYS_CONTEXT
8 \ingroup esys
9 \todo Description
10 \{
11 \typedef ESYS_CONTEXT
12 Reference to the ESYS_CONTEXT that holds data for the connection to the TPM as
13 well as the metadata for TPM Resource; such as Transient key, Persistent
14 objects, NV spaces, Sessions or PCRs.
15 \fn TSS2_RC Esys_Initialize(ESYS_CONTEXT ** esys_context, TSS2_TCTI_CONTEXT * tcti, TSS2_ABI_VERSION * abiVersion)
16 \fn void Esys_Finalize(ESYS_CONTEXT * esys_context)
17 \fn TSS2_RC Esys_GetTcti(ESYS_CONTEXT * esys_context, TSS2_TCTI_CONTEXT ** tcti)
18 \fn TSS2_RC Esys_GetPollHandles(ESYS_CONTEXT * esys_context, TSS2_TCTI_POLL_HANDLE ** handles, size_t * count)
19 \fn TSS2_RC Esys_SetTimeout(ESYS_CONTEXT *esys_context, int32_t timeout)
20 \}
21*/
22
23/*!
24 \defgroup esys_tr Esys Tpm Resource ESYS_TR
25 \ingroup esys
26 Virtual objects with meta data for Tpm Resources.
27 The Esys TPM Resources are the virtual objects inside the ESYSCONTEXT that hold
28 the metadata for corresponding TPM Resources.
29
30 There are a set of global ESYS_TR objects such as ESYS_TR_NON or for the
31 various PCRs and hierarchies. ESYS_TR_MIN_OBJECT denotes the first non-global
32 ESYS_TR object.
33 \{
34 \typedef ESYS_TR
35 Reference to the virtual object inside the ESYS_CONTEXT that holds the metadata
36 for the corresponding TPM Resource. Such can be Transient key, Persistent
37 objects, NV spaces, Sessions or PCRs.
38 \fn TSS2_RC Esys_TR_SetAuth(ESYS_CONTEXT * esys_context, ESYS_TR esys_handle, TPM2B_AUTH const *authValue)
39 \fn TSS2_RC Esys_TR_GetName(ESYS_CONTEXT * esys_context, ESYS_TR esys_handle, TPM2B_NAME ** name)
40 \fn TSS2_RC Esys_TR_FromTPMPublic_Async( ESYS_CONTEXT *esysContext, TPM2_HANDLE tpm_handle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
41 \fn TSS2_RC Esys_TR_FromTPMPublic_Finish(ESYS_CONTEXT *esysContext, ESYS_TR *esys_handle)
42 \fn TSS2_RC Esys_TR_FromTPMPublic(ESYS_CONTEXT *esysContext, TPM2_HANDLE tpm_handle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, ESYS_TR *object)
43 \fn TSS2_RC Esys_TR_Serialize(ESYS_CONTEXT *esys_context, ESYS_TR esys_handle, uint8_t **buffer, size_t *buffer_size)
44 \fn TSS2_RC Esys_TR_Deserialize(ESYS_CONTEXT *esys_context, uint8_t const *buffer, size_t buffer_size, ESYS_TR *esys_handle)
45 \fn TSS2_RC Esys_TR_Close(ESYS_CONTEXT *esys_context, ESYS_TR *object)
46 \fn TSS2_RC Esys_TRSess_GetAttributes(ESYS_CONTEXT * esysContext, ESYS_TR esys_handle, TPMA_SESSION * flags)
47 \fn TSS2_RC Esys_TRSess_SetAttributes(ESYS_CONTEXT * esys_context, ESYS_TR esys_handle, TPMA_SESSION flags, TPMA_SESSION mask)
48 \}
49*/
50
51/*!
52 \defgroup esys_tr_defines Global ESYS_TR objects
53 \ingroup esys_tr
54 A set of defines for global virtual objects that are always present in every
55 ESYS_CONTEXT.
56 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +020057 \def ESYS_TR_NONE Identifier for ESYS_TR parameters if no TPM Resource is supplied.
58 \def ESYS_TR_PASSWORD Identifier for ESYS_TR sessions for password authentication.
59 \def ESYS_TR_PCR0 TPM Resource PCR 0.
60 \def ESYS_TR_PCR1 TPM Resource PCR 1.
61 \def ESYS_TR_PCR2 TPM Resource PCR 2.
62 \def ESYS_TR_PCR3 TPM Resource PCR 3.
63 \def ESYS_TR_PCR4 TPM Resource PCR 4.
64 \def ESYS_TR_PCR5 TPM Resource PCR 5.
65 \def ESYS_TR_PCR6 TPM Resource PCR 6.
66 \def ESYS_TR_PCR7 TPM Resource PCR 7.
67 \def ESYS_TR_PCR8 TPM Resource PCR 8.
68 \def ESYS_TR_PCR9 TPM Resource PCR 9.
69 \def ESYS_TR_PCR10 TPM Resource PCR 10.
70 \def ESYS_TR_PCR11 TPM Resource PCR 11.
71 \def ESYS_TR_PCR12 TPM Resource PCR 12.
72 \def ESYS_TR_PCR13 TPM Resource PCR 13.
73 \def ESYS_TR_PCR14 TPM Resource PCR 14.
74 \def ESYS_TR_PCR15 TPM Resource PCR 15.
75 \def ESYS_TR_PCR16 TPM Resource PCR 16.
76 \def ESYS_TR_PCR17 TPM Resource PCR 17.
77 \def ESYS_TR_PCR18 TPM Resource PCR 18.
78 \def ESYS_TR_PCR19 TPM Resource PCR 19.
79 \def ESYS_TR_PCR20 TPM Resource PCR 20.
80 \def ESYS_TR_PCR21 TPM Resource PCR 21.
81 \def ESYS_TR_PCR22 TPM Resource PCR 22.
82 \def ESYS_TR_PCR23 TPM Resource PCR 23.
83 \def ESYS_TR_PCR24 TPM Resource PCR 24.
84 \def ESYS_TR_PCR25 TPM Resource PCR 25.
85 \def ESYS_TR_PCR26 TPM Resource PCR 26.
86 \def ESYS_TR_PCR27 TPM Resource PCR 27.
87 \def ESYS_TR_PCR28 TPM Resource PCR 28.
88 \def ESYS_TR_PCR29 TPM Resource PCR 29.
89 \def ESYS_TR_PCR30 TPM Resource PCR 30.
90 \def ESYS_TR_PCR31 TPM Resource PCR 31.
91 \def ESYS_TR_RH_OWNER TPM Resource Owner Hierarchy
92 \def ESYS_TR_RH_NULL TPM Resource Ephemeral Hierarchy
93 \def ESYS_TR_RH_LOCKOUT TPM Resource for Lockout Authorization
94 \def ESYS_TR_RH_ENDORSEMENT TPM Resource Endorsement Hierarchy
95 \def ESYS_TR_RH_PLATFORM TPM Resource Platform Hierarchy
96 \def ESYS_TR_RH_PLATFORM_NV Identifier for ESYS_TR used for phEnableNV
97 \def ESYS_TR_RH_AUTH_00 Identifier for ESYS_TR for the start of a range of authorization values that are vendor-specific.
98 \def ESYS_TR_RH_AUTH_FF Identifier for ESYS_TR for the end of a range of authorization values that are vendor-specific.
99 \def ESYS_TR_MIN_OBJECT The first non-global ESYS_TR object identifier. These are assigned by ESAPI and beyond this value.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100100 \}
101*/
102
103/*!
104 \defgroup esys_tpm Esys TPM Commands
105 \ingroup esys
106 The following function represent interactions with the corresponding TPM
107 commands.
108 \{
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200109 \defgroup Esys_ActivateCredential The ESAPI function for the TPM2_ActivateCredential command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100110 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200111 \fn TSS2_RC Esys_ActivateCredential_Async(ESYS_CONTEXT *esysContext, ESYS_TR activateHandle, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_ID_OBJECT *credentialBlob, const TPM2B_ENCRYPTED_SECRET *secret)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100112 \fn TSS2_RC Esys_ActivateCredential(ESYS_CONTEXT *esysContext, ESYS_TR activateHandle, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_ID_OBJECT *credentialBlob, const TPM2B_ENCRYPTED_SECRET *secret, TPM2B_DIGEST **certInfo)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200113 \fn TSS2_RC Esys_ActivateCredential_Finish(ESYS_CONTEXT *esysContext, TPM2B_DIGEST **certInfo)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100114 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200115 \defgroup Esys_Certify The ESAPI function for the TPM2_Certify command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100116 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200117 \fn TSS2_RC Esys_Certify_Async(ESYS_CONTEXT *esysContext, ESYS_TR objectHandle, ESYS_TR signHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPMT_SIG_SCHEME *inScheme)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100118 \fn TSS2_RC Esys_Certify(ESYS_CONTEXT *esysContext, ESYS_TR objectHandle, ESYS_TR signHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPMT_SIG_SCHEME *inScheme, TPM2B_ATTEST **certifyInfo, TPMT_SIGNATURE **signature)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200119 \fn TSS2_RC Esys_Certify_Finish(ESYS_CONTEXT *esysContext, TPM2B_ATTEST **certifyInfo, TPMT_SIGNATURE **signature)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100120 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200121 \defgroup Esys_CertifyCreation The ESAPI function for the TPM2_CertifyCreation command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100122 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200123 \fn TSS2_RC Esys_CertifyCreation_Async(ESYS_CONTEXT *esysContext, ESYS_TR signHandle, ESYS_TR objectHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPM2B_DIGEST *creationHash, const TPMT_SIG_SCHEME *inScheme, const TPMT_TK_CREATION *creationTicket)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100124 \fn TSS2_RC Esys_CertifyCreation(ESYS_CONTEXT *esysContext, ESYS_TR signHandle, ESYS_TR objectHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPM2B_DIGEST *creationHash, const TPMT_SIG_SCHEME *inScheme, const TPMT_TK_CREATION *creationTicket, TPM2B_ATTEST **certifyInfo, TPMT_SIGNATURE **signature)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200125 \fn TSS2_RC Esys_CertifyCreation_Finish(ESYS_CONTEXT *esysContext, TPM2B_ATTEST **certifyInfo, TPMT_SIGNATURE **signature)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100126 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200127 \defgroup Esys_ChangeEPS The ESAPI function for the TPM2_ChangeEPS command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100128 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200129 \fn TSS2_RC Esys_ChangeEPS_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100130 \fn TSS2_RC Esys_ChangeEPS(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200131 \fn TSS2_RC Esys_ChangeEPS_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100132 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200133 \defgroup Esys_ChangePPS The ESAPI function for the TPM2_ChangePPS command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100134 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200135 \fn TSS2_RC Esys_ChangePPS_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100136 \fn TSS2_RC Esys_ChangePPS(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200137 \fn TSS2_RC Esys_ChangePPS_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100138 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200139 \defgroup Esys_Clear The ESAPI function for the TPM2_Clear command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100140 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200141 \fn TSS2_RC Esys_Clear_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100142 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200143 \defgroup Esys_ClearControl The ESAPI function for the TPM2_ClearControl command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100144 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200145 \fn TSS2_RC Esys_ClearControl_Async(ESYS_CONTEXT *esysContext, ESYS_TR auth, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_YES_NO disable)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100146 \fn TSS2_RC Esys_ClearControl(ESYS_CONTEXT *esysContext, ESYS_TR auth, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_YES_NO disable)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200147 \fn TSS2_RC Esys_ClearControl_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100148 \fn TSS2_RC Esys_Clear(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200149 \fn TSS2_RC Esys_Clear_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100150 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200151 \defgroup Esys_ClockRateAdjust The ESAPI function for the TPM2_ClockRateAdjust command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100152 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200153 \fn TSS2_RC Esys_ClockRateAdjust_Async(ESYS_CONTEXT *esysContext, ESYS_TR auth, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPM2_CLOCK_ADJUST rateAdjust)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100154 \fn TSS2_RC Esys_ClockRateAdjust(ESYS_CONTEXT *esysContext, ESYS_TR auth, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPM2_CLOCK_ADJUST rateAdjust)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200155 \fn TSS2_RC Esys_ClockRateAdjust_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100156 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200157 \defgroup Esys_ClockSet The ESAPI function for the TPM2_ClockSet command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100158 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200159 \fn TSS2_RC Esys_ClockSet_Async(ESYS_CONTEXT *esysContext, ESYS_TR auth, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, UINT64 newTime)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100160 \fn TSS2_RC Esys_ClockSet(ESYS_CONTEXT *esysContext, ESYS_TR auth, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, UINT64 newTime)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200161 \fn TSS2_RC Esys_ClockSet_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100162 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200163 \defgroup Esys_Commit The ESAPI function for the TPM2_Commit command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100164 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200165 \fn TSS2_RC Esys_Commit_Async(ESYS_CONTEXT *esysContext, ESYS_TR signHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_ECC_POINT *P1, const TPM2B_SENSITIVE_DATA *s2, const TPM2B_ECC_PARAMETER *y2)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100166 \fn TSS2_RC Esys_Commit(ESYS_CONTEXT *esysContext, ESYS_TR signHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_ECC_POINT *P1, const TPM2B_SENSITIVE_DATA *s2, const TPM2B_ECC_PARAMETER *y2, TPM2B_ECC_POINT **K, TPM2B_ECC_POINT **L, TPM2B_ECC_POINT **E, UINT16 *counter)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200167 \fn TSS2_RC Esys_Commit_Finish(ESYS_CONTEXT *esysContext, TPM2B_ECC_POINT **K, TPM2B_ECC_POINT **L, TPM2B_ECC_POINT **E, UINT16 *counter)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100168 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200169 \defgroup Esys_ContextLoad The ESAPI function for the TPM2_ContextLoad command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100170 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200171 \fn TSS2_RC Esys_ContextLoad_Async(ESYS_CONTEXT *esysContext, const TPMS_CONTEXT *context)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100172 \fn TSS2_RC Esys_ContextLoad(ESYS_CONTEXT *esysContext, const TPMS_CONTEXT *context, ESYS_TR *loadedHandle)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200173 \fn TSS2_RC Esys_ContextLoad_Finish(ESYS_CONTEXT *esysContext, ESYS_TR *loadedHandle)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100174 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200175 \defgroup Esys_ContextSave The ESAPI function for the TPM2_ContextSave command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100176 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200177 \fn TSS2_RC Esys_ContextSave_Async(ESYS_CONTEXT *esysContext, ESYS_TR saveHandle)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100178 \fn TSS2_RC Esys_ContextSave(ESYS_CONTEXT *esysContext, ESYS_TR saveHandle, TPMS_CONTEXT **context)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200179 \fn TSS2_RC Esys_ContextSave_Finish(ESYS_CONTEXT *esysContext, TPMS_CONTEXT **context)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100180 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200181 \defgroup Esys_Create The ESAPI function for the TPM2_Create command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100182 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200183 \fn TSS2_RC Esys_Create_Async(ESYS_CONTEXT *esysContext, ESYS_TR parentHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_SENSITIVE_CREATE *inSensitive, const TPM2B_PUBLIC *inPublic, const TPM2B_DATA *outsideInfo, const TPML_PCR_SELECTION *creationPCR)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100184 \fn TSS2_RC Esys_Create(ESYS_CONTEXT *esysContext, ESYS_TR parentHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_SENSITIVE_CREATE *inSensitive, const TPM2B_PUBLIC *inPublic, const TPM2B_DATA *outsideInfo, const TPML_PCR_SELECTION *creationPCR, TPM2B_PRIVATE **outPrivate, TPM2B_PUBLIC **outPublic, TPM2B_CREATION_DATA **creationData, TPM2B_DIGEST **creationHash, TPMT_TK_CREATION **creationTicket)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200185 \fn TSS2_RC Esys_Create_Finish(ESYS_CONTEXT *esysContext, TPM2B_PRIVATE **outPrivate, TPM2B_PUBLIC **outPublic, TPM2B_CREATION_DATA **creationData, TPM2B_DIGEST **creationHash, TPMT_TK_CREATION **creationTicket)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100186 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200187 \defgroup Esys_CreatePrimary The ESAPI function for the TPM2_CreatePrimary command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100188 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200189 \fn TSS2_RC Esys_CreatePrimary_Async(ESYS_CONTEXT *esysContext, ESYS_TR primaryHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_SENSITIVE_CREATE *inSensitive, const TPM2B_PUBLIC *inPublic, const TPM2B_DATA *outsideInfo, const TPML_PCR_SELECTION *creationPCR)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100190 \fn TSS2_RC Esys_CreatePrimary(ESYS_CONTEXT *esysContext, ESYS_TR primaryHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_SENSITIVE_CREATE *inSensitive, const TPM2B_PUBLIC *inPublic, const TPM2B_DATA *outsideInfo, const TPML_PCR_SELECTION *creationPCR, ESYS_TR *objectHandle, TPM2B_PUBLIC **outPublic, TPM2B_CREATION_DATA **creationData, TPM2B_DIGEST **creationHash, TPMT_TK_CREATION **creationTicket)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200191 \fn TSS2_RC Esys_CreatePrimary_Finish(ESYS_CONTEXT *esysContext, ESYS_TR *objectHandle, TPM2B_PUBLIC **outPublic, TPM2B_CREATION_DATA **creationData, TPM2B_DIGEST **creationHash, TPMT_TK_CREATION **creationTicket)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100192 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200193 \defgroup Esys_DictionaryAttackLockReset The ESAPI function for the TPM2_DictionaryAttackLockReset command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100194 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200195 \fn TSS2_RC Esys_DictionaryAttackLockReset_Async(ESYS_CONTEXT *esysContext, ESYS_TR lockHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100196 \fn TSS2_RC Esys_DictionaryAttackLockReset(ESYS_CONTEXT *esysContext, ESYS_TR lockHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200197 \fn TSS2_RC Esys_DictionaryAttackLockReset_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100198 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200199 \defgroup Esys_DictionaryAttackParameters The ESAPI function for the TPM2_DictionaryAttackParameters command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100200 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200201 \fn TSS2_RC Esys_DictionaryAttackParameters_Async(ESYS_CONTEXT *esysContext, ESYS_TR lockHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, UINT32 newMaxTries, UINT32 newRecoveryTime, UINT32 lockoutRecovery)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100202 \fn TSS2_RC Esys_DictionaryAttackParameters(ESYS_CONTEXT *esysContext, ESYS_TR lockHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, UINT32 newMaxTries, UINT32 newRecoveryTime, UINT32 lockoutRecovery)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200203 \fn TSS2_RC Esys_DictionaryAttackParameters_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100204 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200205 \defgroup Esys_Duplicate The ESAPI function for the TPM2_Duplicate command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100206 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200207 \fn TSS2_RC Esys_Duplicate_Async(ESYS_CONTEXT *esysContext, ESYS_TR objectHandle, ESYS_TR newParentHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *encryptionKeyIn, const TPMT_SYM_DEF_OBJECT *symmetricAlg)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100208 \fn TSS2_RC Esys_Duplicate(ESYS_CONTEXT *esysContext, ESYS_TR objectHandle, ESYS_TR newParentHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *encryptionKeyIn, const TPMT_SYM_DEF_OBJECT *symmetricAlg, TPM2B_DATA **encryptionKeyOut, TPM2B_PRIVATE **duplicate, TPM2B_ENCRYPTED_SECRET **outSymSeed)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200209 \fn TSS2_RC Esys_Duplicate_Finish(ESYS_CONTEXT *esysContext, TPM2B_DATA **encryptionKeyOut, TPM2B_PRIVATE **duplicate, TPM2B_ENCRYPTED_SECRET **outSymSeed)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100210 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200211 \defgroup Esys_ECC_Parameters The ESAPI function for the TPM2_ECC_Parameters command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100212 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200213 \fn TSS2_RC Esys_ECC_Parameters_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_ECC_CURVE curveID)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100214 \fn TSS2_RC Esys_ECC_Parameters(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_ECC_CURVE curveID, TPMS_ALGORITHM_DETAIL_ECC **parameters)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200215 \fn TSS2_RC Esys_ECC_Parameters_Finish(ESYS_CONTEXT *esysContext, TPMS_ALGORITHM_DETAIL_ECC **parameters)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100216 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200217 \defgroup Esys_ECDH_KeyGen The ESAPI function for the TPM2_ECDH_KeyGen command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100218 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200219 \fn TSS2_RC Esys_ECDH_KeyGen_Async(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100220 \fn TSS2_RC Esys_ECDH_KeyGen(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPM2B_ECC_POINT **zPoint, TPM2B_ECC_POINT **pubPoint)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200221 \fn TSS2_RC Esys_ECDH_KeyGen_Finish(ESYS_CONTEXT *esysContext, TPM2B_ECC_POINT **zPoint, TPM2B_ECC_POINT **pubPoint)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100222 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200223 \defgroup Esys_ECDH_ZGen The ESAPI function for the TPM2_ECDH_ZGen command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100224 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200225 \fn TSS2_RC Esys_ECDH_ZGen_Async(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_ECC_POINT *inPoint)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100226 \fn TSS2_RC Esys_ECDH_ZGen(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_ECC_POINT *inPoint, TPM2B_ECC_POINT **outPoint)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200227 \fn TSS2_RC Esys_ECDH_ZGen_Finish(ESYS_CONTEXT *esysContext, TPM2B_ECC_POINT **outPoint)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100228 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200229 \defgroup Esys_EC_Ephemeral The ESAPI function for the TPM2_EC_Ephemeral command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100230 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200231 \fn TSS2_RC Esys_EC_Ephemeral_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_ECC_CURVE curveID)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100232 \fn TSS2_RC Esys_EC_Ephemeral(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_ECC_CURVE curveID, TPM2B_ECC_POINT **Q, UINT16 *counter)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200233 \fn TSS2_RC Esys_EC_Ephemeral_Finish(ESYS_CONTEXT *esysContext, TPM2B_ECC_POINT **Q, UINT16 *counter)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100234 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200235 \defgroup Esys_EncryptDecrypt The ESAPI function for the TPM2_EncryptDecrypt command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100236 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200237 \fn TSS2_RC Esys_EncryptDecrypt_Async(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_YES_NO decrypt, TPMI_ALG_SYM_MODE mode, const TPM2B_IV *ivIn, const TPM2B_MAX_BUFFER *inData)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100238 \fn TSS2_RC Esys_EncryptDecrypt(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_YES_NO decrypt, TPMI_ALG_SYM_MODE mode, const TPM2B_IV *ivIn, const TPM2B_MAX_BUFFER *inData, TPM2B_MAX_BUFFER **outData, TPM2B_IV **ivOut)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200239 \fn TSS2_RC Esys_EncryptDecrypt_Finish(ESYS_CONTEXT *esysContext, TPM2B_MAX_BUFFER **outData, TPM2B_IV **ivOut)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100240 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200241 \defgroup Esys_EventSequenceComplete The ESAPI function for the TPM2_EventSequenceComplete command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100242 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200243 \fn TSS2_RC Esys_EventSequenceComplete_Async(ESYS_CONTEXT *esysContext, ESYS_TR pcrHandle, ESYS_TR sequenceHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_BUFFER *buffer)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100244 \fn TSS2_RC Esys_EventSequenceComplete(ESYS_CONTEXT *esysContext, ESYS_TR pcrHandle, ESYS_TR sequenceHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_BUFFER *buffer, TPML_DIGEST_VALUES **results)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200245 \fn TSS2_RC Esys_EventSequenceComplete_Finish(ESYS_CONTEXT *esysContext, TPML_DIGEST_VALUES **results)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100246 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200247 \defgroup Esys_EvictControl The ESAPI function for the TPM2_EvictControl command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100248 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200249 \fn TSS2_RC Esys_EvictControl_Async(ESYS_CONTEXT *esysContext, ESYS_TR auth, ESYS_TR objectHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_DH_PERSISTENT persistentHandle)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100250 \fn TSS2_RC Esys_EvictControl(ESYS_CONTEXT *esysContext, ESYS_TR auth, ESYS_TR objectHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_DH_PERSISTENT persistentHandle, ESYS_TR *newObjectHandle)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200251 \fn TSS2_RC Esys_EvictControl_Finish(ESYS_CONTEXT *esysContext, ESYS_TR *newObjectHandle)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100252 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200253 \defgroup Esys_FlushContext The ESAPI function for the TPM2_FlushContext command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100254 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200255 \fn TSS2_RC Esys_FlushContext_Async(ESYS_CONTEXT *esysContext, TPMI_DH_CONTEXT flushHandle)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100256 \fn TSS2_RC Esys_FlushContext(ESYS_CONTEXT *esysContext, TPMI_DH_CONTEXT flushHandle)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200257 \fn TSS2_RC Esys_FlushContext_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100258 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200259 \defgroup Esys_GetCapability The ESAPI function for the TPM2_GetCapability command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100260 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200261 \fn TSS2_RC Esys_GetCapability_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPM2_CAP capability, UINT32 property, UINT32 propertyCount)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100262 \fn TSS2_RC Esys_GetCapability(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPM2_CAP capability, UINT32 property, UINT32 propertyCount, TPMI_YES_NO *moreData, TPMS_CAPABILITY_DATA **capabilityData)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200263 \fn TSS2_RC Esys_GetCapability_Finish(ESYS_CONTEXT *esysContext, TPMI_YES_NO *moreData, TPMS_CAPABILITY_DATA **capabilityData)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100264 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200265 \defgroup Esys_GetCommandAuditDigest The ESAPI function for the TPM2_GetCommandAuditDigest command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100266 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200267 \fn TSS2_RC Esys_GetCommandAuditDigest_Async(ESYS_CONTEXT *esysContext, ESYS_TR privacyHandle, ESYS_TR signHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPMT_SIG_SCHEME *inScheme)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100268 \fn TSS2_RC Esys_GetCommandAuditDigest(ESYS_CONTEXT *esysContext, ESYS_TR privacyHandle, ESYS_TR signHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPMT_SIG_SCHEME *inScheme, TPM2B_ATTEST **auditInfo, TPMT_SIGNATURE **signature)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200269 \fn TSS2_RC Esys_GetCommandAuditDigest_Finish(ESYS_CONTEXT *esysContext, TPM2B_ATTEST **auditInfo, TPMT_SIGNATURE **signature)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100270 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200271 \defgroup Esys_GetRandom The ESAPI function for the TPM2_GetRandom command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100272 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200273 \fn TSS2_RC Esys_GetRandom_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, UINT16 bytesRequested)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100274 \fn TSS2_RC Esys_GetRandom(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, UINT16 bytesRequested, TPM2B_DIGEST **randomBytes)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200275 \fn TSS2_RC Esys_GetRandom_Finish(ESYS_CONTEXT *esysContext, TPM2B_DIGEST **randomBytes)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100276 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200277 \defgroup Esys_GetSessionAuditDigest The ESAPI function for the TPM2_GetSessionAuditDigest command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100278 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200279 \fn TSS2_RC Esys_GetSessionAuditDigest_Async(ESYS_CONTEXT *esysContext, ESYS_TR privacyAdminHandle, ESYS_TR signHandle, ESYS_TR sessionHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPMT_SIG_SCHEME *inScheme)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100280 \fn TSS2_RC Esys_GetSessionAuditDigest(ESYS_CONTEXT *esysContext, ESYS_TR privacyAdminHandle, ESYS_TR signHandle, ESYS_TR sessionHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPMT_SIG_SCHEME *inScheme, TPM2B_ATTEST **auditInfo, TPMT_SIGNATURE **signature)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200281 \fn TSS2_RC Esys_GetSessionAuditDigest_Finish(ESYS_CONTEXT *esysContext, TPM2B_ATTEST **auditInfo, TPMT_SIGNATURE **signature)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100282 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200283 \defgroup Esys_GetTestResult The ESAPI function for the TPM2_GetTestResult command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100284 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200285 \fn TSS2_RC Esys_GetTestResult_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100286 \fn TSS2_RC Esys_GetTestResult(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPM2B_MAX_BUFFER **outData, TPM2_RC *testResult)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200287 \fn TSS2_RC Esys_GetTestResult_Finish(ESYS_CONTEXT *esysContext, TPM2B_MAX_BUFFER **outData, TPM2_RC *testResult)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100288 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200289 \defgroup Esys_GetTime The ESAPI function for the TPM2_GetTime command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100290 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200291 \fn TSS2_RC Esys_GetTime_Async(ESYS_CONTEXT *esysContext, ESYS_TR privacyAdminHandle, ESYS_TR signHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPMT_SIG_SCHEME *inScheme)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100292 \fn TSS2_RC Esys_GetTime(ESYS_CONTEXT *esysContext, ESYS_TR privacyAdminHandle, ESYS_TR signHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPMT_SIG_SCHEME *inScheme, TPM2B_ATTEST **timeInfo, TPMT_SIGNATURE **signature)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200293 \fn TSS2_RC Esys_GetTime_Finish(ESYS_CONTEXT *esysContext, TPM2B_ATTEST **timeInfo, TPMT_SIGNATURE **signature)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100294 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200295 \defgroup Esys_Hash The ESAPI function for the TPM2_Hash command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100296 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200297 \fn TSS2_RC Esys_Hash_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_BUFFER *data, TPMI_ALG_HASH hashAlg, TPMI_RH_HIERARCHY hierarchy)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100298 \fn TSS2_RC Esys_Hash(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_BUFFER *data, TPMI_ALG_HASH hashAlg, TPMI_RH_HIERARCHY hierarchy, TPM2B_DIGEST **outHash, TPMT_TK_HASHCHECK **validation)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200299 \fn TSS2_RC Esys_Hash_Finish(ESYS_CONTEXT *esysContext, TPM2B_DIGEST **outHash, TPMT_TK_HASHCHECK **validation)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100300 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200301 \defgroup Esys_HashSequenceStart The ESAPI function for the TPM2_HashSequenceStart command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100302 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200303 \fn TSS2_RC Esys_HashSequenceStart_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_AUTH *auth, TPMI_ALG_HASH hashAlg)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100304 \fn TSS2_RC Esys_HashSequenceStart(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_AUTH *auth, TPMI_ALG_HASH hashAlg, ESYS_TR *sequenceHandle)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200305 \fn TSS2_RC Esys_HashSequenceStart_Finish(ESYS_CONTEXT *esysContext, ESYS_TR *sequenceHandle)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100306 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200307 \defgroup Esys_HierarchyChangeAuth The ESAPI function for the TPM2_HierarchyChangeAuth command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100308 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200309 \fn TSS2_RC Esys_HierarchyChangeAuth_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_AUTH *newAuth)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100310 \fn TSS2_RC Esys_HierarchyChangeAuth(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_AUTH *newAuth)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200311 \fn TSS2_RC Esys_HierarchyChangeAuth_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100312 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200313 \defgroup Esys_HierarchyControl The ESAPI function for the TPM2_HierarchyControl command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100314 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200315 \fn TSS2_RC Esys_HierarchyControl_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_RH_ENABLES enable, TPMI_YES_NO state)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100316 \fn TSS2_RC Esys_HierarchyControl(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_RH_ENABLES enable, TPMI_YES_NO state)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200317 \fn TSS2_RC Esys_HierarchyControl_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100318 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200319 \defgroup Esys_HMAC The ESAPI function for the TPM2_HMAC command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100320 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200321 \fn TSS2_RC Esys_HMAC_Async(ESYS_CONTEXT *esysContext, ESYS_TR handle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_BUFFER *buffer, TPMI_ALG_HASH hashAlg)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100322 \fn TSS2_RC Esys_HMAC(ESYS_CONTEXT *esysContext, ESYS_TR handle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_BUFFER *buffer, TPMI_ALG_HASH hashAlg, TPM2B_DIGEST **outHMAC)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200323 \fn TSS2_RC Esys_HMAC_Finish(ESYS_CONTEXT *esysContext, TPM2B_DIGEST **outHMAC)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100324 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200325 \defgroup Esys_HMAC_Start The ESAPI function for the TPM2_HMAC_Start command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100326 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200327 \fn TSS2_RC Esys_HMAC_Start_Async(ESYS_CONTEXT *esysContext, ESYS_TR handle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_AUTH *auth, TPMI_ALG_HASH hashAlg)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100328 \fn TSS2_RC Esys_HMAC_Start(ESYS_CONTEXT *esysContext, ESYS_TR handle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_AUTH *auth, TPMI_ALG_HASH hashAlg, ESYS_TR *sequenceHandle)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200329 \fn TSS2_RC Esys_HMAC_Start_Finish(ESYS_CONTEXT *esysContext, ESYS_TR *sequenceHandle)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100330 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200331 \defgroup Esys_Import The ESAPI function for the TPM2_Import command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100332 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200333 \fn TSS2_RC Esys_Import_Async(ESYS_CONTEXT *esysContext, ESYS_TR parentHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *encryptionKey, const TPM2B_PUBLIC *objectPublic, const TPM2B_PRIVATE *duplicate, const TPM2B_ENCRYPTED_SECRET *inSymSeed, const TPMT_SYM_DEF_OBJECT *symmetricAlg)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100334 \fn TSS2_RC Esys_Import(ESYS_CONTEXT *esysContext, ESYS_TR parentHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *encryptionKey, const TPM2B_PUBLIC *objectPublic, const TPM2B_PRIVATE *duplicate, const TPM2B_ENCRYPTED_SECRET *inSymSeed, const TPMT_SYM_DEF_OBJECT *symmetricAlg, TPM2B_PRIVATE **outPrivate)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200335 \fn TSS2_RC Esys_Import_Finish(ESYS_CONTEXT *esysContext, TPM2B_PRIVATE **outPrivate)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100336 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200337 \defgroup Esys_IncrementalSelfTest The ESAPI function for the TPM2_IncrementalSelfTest command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100338 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200339 \fn TSS2_RC Esys_IncrementalSelfTest_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPML_ALG *toTest)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100340 \fn TSS2_RC Esys_IncrementalSelfTest(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPML_ALG *toTest, TPML_ALG **toDoList)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200341 \fn TSS2_RC Esys_IncrementalSelfTest_Finish(ESYS_CONTEXT *esysContext, TPML_ALG **toDoList)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100342 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200343 \defgroup Esys_Load The ESAPI function for the TPM2_Load command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100344 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200345 \fn TSS2_RC Esys_Load_Async(ESYS_CONTEXT *esysContext, ESYS_TR parentHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_PRIVATE *inPrivate, const TPM2B_PUBLIC *inPublic)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100346 \fn TSS2_RC Esys_Load(ESYS_CONTEXT *esysContext, ESYS_TR parentHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_PRIVATE *inPrivate, const TPM2B_PUBLIC *inPublic, ESYS_TR *objectHandle)
347 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200348 \defgroup Esys_LoadExternal The ESAPI function for the TPM2_LoadExternal command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100349 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200350 \fn TSS2_RC Esys_LoadExternal_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_SENSITIVE *inPrivate, const TPM2B_PUBLIC *inPublic, TPMI_RH_HIERARCHY hierarchy)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100351 \fn TSS2_RC Esys_LoadExternal(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_SENSITIVE *inPrivate, const TPM2B_PUBLIC *inPublic, TPMI_RH_HIERARCHY hierarchy, ESYS_TR *objectHandle)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200352 \fn TSS2_RC Esys_LoadExternal_Finish(ESYS_CONTEXT *esysContext, ESYS_TR *objectHandle)
353 \fn TSS2_RC Esys_Load_Finish(ESYS_CONTEXT *esysContext, ESYS_TR *objectHandle)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100354 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200355 \defgroup Esys_MakeCredential The ESAPI function for the TPM2_MakeCredential command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100356 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200357 \fn TSS2_RC Esys_MakeCredential_Async(ESYS_CONTEXT *esysContext, ESYS_TR handle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *credential, const TPM2B_NAME *objectName)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100358 \fn TSS2_RC Esys_MakeCredential(ESYS_CONTEXT *esysContext, ESYS_TR handle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *credential, const TPM2B_NAME *objectName, TPM2B_ID_OBJECT **credentialBlob, TPM2B_ENCRYPTED_SECRET **secret)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200359 \fn TSS2_RC Esys_MakeCredential_Finish(ESYS_CONTEXT *esysContext, TPM2B_ID_OBJECT **credentialBlob, TPM2B_ENCRYPTED_SECRET **secret)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100360 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200361 \defgroup Esys_NV_Certify The ESAPI function for the TPM2_NV_Certify command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100362 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200363 \fn TSS2_RC Esys_NV_Certify_Async(ESYS_CONTEXT *esysContext, ESYS_TR signHandle, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPMT_SIG_SCHEME *inScheme, UINT16 size, UINT16 offset)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100364 \fn TSS2_RC Esys_NV_Certify(ESYS_CONTEXT *esysContext, ESYS_TR signHandle, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPMT_SIG_SCHEME *inScheme, UINT16 size, UINT16 offset, TPM2B_ATTEST **certifyInfo, TPMT_SIGNATURE **signature)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200365 \fn TSS2_RC Esys_NV_Certify_Finish(ESYS_CONTEXT *esysContext, TPM2B_ATTEST **certifyInfo, TPMT_SIGNATURE **signature)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100366 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200367 \defgroup Esys_NV_ChangeAuth The ESAPI function for the TPM2_NV_ChangeAuth command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100368 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200369 \fn TSS2_RC Esys_NV_ChangeAuth_Async(ESYS_CONTEXT *esysContext, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_AUTH *newAuth)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100370 \fn TSS2_RC Esys_NV_ChangeAuth(ESYS_CONTEXT *esysContext, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_AUTH *newAuth)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200371 \fn TSS2_RC Esys_NV_ChangeAuth_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100372 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200373 \defgroup Esys_NV_DefineSpace The ESAPI function for the TPM2_NV_DefineSpace command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100374 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200375 \fn TSS2_RC Esys_NV_DefineSpace_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_AUTH *auth, const TPM2B_NV_PUBLIC *publicInfo)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100376 \fn TSS2_RC Esys_NV_DefineSpace(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_AUTH *auth, const TPM2B_NV_PUBLIC *publicInfo, ESYS_TR *nvHandle)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200377 \fn TSS2_RC Esys_NV_DefineSpace_Finish(ESYS_CONTEXT *esysContext, ESYS_TR *nvHandle)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100378 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200379 \defgroup Esys_NV_Extend The ESAPI function for the TPM2_NV_Extend command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100380 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200381 \fn TSS2_RC Esys_NV_Extend_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_NV_BUFFER *data)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100382 \fn TSS2_RC Esys_NV_Extend(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_NV_BUFFER *data)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200383 \fn TSS2_RC Esys_NV_Extend_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100384 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200385 \defgroup Esys_NV_GlobalWriteLock The ESAPI function for the TPM2_NV_GlobalWriteLock command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100386 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200387 \fn TSS2_RC Esys_NV_GlobalWriteLock_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100388 \fn TSS2_RC Esys_NV_GlobalWriteLock(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200389 \fn TSS2_RC Esys_NV_GlobalWriteLock_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100390 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200391 \defgroup Esys_NV_Increment The ESAPI function for the TPM2_NV_Increment command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100392 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200393 \fn TSS2_RC Esys_NV_Increment_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100394 \fn TSS2_RC Esys_NV_Increment(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200395 \fn TSS2_RC Esys_NV_Increment_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100396 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200397 \defgroup Esys_NV_Read The ESAPI function for the TPM2_NV_Read command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100398 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200399 \fn TSS2_RC Esys_NV_Read_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, UINT16 size, UINT16 offset)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100400 \fn TSS2_RC Esys_NV_Read(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, UINT16 size, UINT16 offset, TPM2B_MAX_NV_BUFFER **data)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200401 \fn TSS2_RC Esys_NV_Read_Finish(ESYS_CONTEXT *esysContext, TPM2B_MAX_NV_BUFFER **data)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100402 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200403 \defgroup Esys_NV_ReadLock The ESAPI function for the TPM2_NV_ReadLock command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100404 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200405 \fn TSS2_RC Esys_NV_ReadLock_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100406 \fn TSS2_RC Esys_NV_ReadLock(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200407 \fn TSS2_RC Esys_NV_ReadLock_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100408 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200409 \defgroup Esys_NV_ReadPublic The ESAPI function for the TPM2_NV_ReadPublic command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100410 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200411 \fn TSS2_RC Esys_NV_ReadPublic_Async(ESYS_CONTEXT *esysContext, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100412 \fn TSS2_RC Esys_NV_ReadPublic(ESYS_CONTEXT *esysContext, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPM2B_NV_PUBLIC **nvPublic, TPM2B_NAME **nvName)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200413 \fn TSS2_RC Esys_NV_ReadPublic_Finish(ESYS_CONTEXT *esysContext, TPM2B_NV_PUBLIC **nvPublic, TPM2B_NAME **nvName)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100414 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200415 \defgroup Esys_NV_SetBits The ESAPI function for the TPM2_NV_SetBits command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100416 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200417 \fn TSS2_RC Esys_NV_SetBits_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, UINT64 bits)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100418 \fn TSS2_RC Esys_NV_SetBits(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, UINT64 bits)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200419 \fn TSS2_RC Esys_NV_SetBits_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100420 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200421 \defgroup Esys_NV_UndefineSpace The ESAPI function for the TPM2_NV_UndefineSpace command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100422 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200423 \fn TSS2_RC Esys_NV_UndefineSpace_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100424 \fn TSS2_RC Esys_NV_UndefineSpace(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200425 \fn TSS2_RC Esys_NV_UndefineSpace_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100426 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200427 \defgroup Esys_NV_UndefineSpaceSpecial The ESAPI function for the TPM2_NV_UndefineSpaceSpecial command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100428 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200429 \fn TSS2_RC Esys_NV_UndefineSpaceSpecial_Async(ESYS_CONTEXT *esysContext, ESYS_TR nvIndex, ESYS_TR platform, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100430 \fn TSS2_RC Esys_NV_UndefineSpaceSpecial(ESYS_CONTEXT *esysContext, ESYS_TR nvIndex, ESYS_TR platform, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200431 \fn TSS2_RC Esys_NV_UndefineSpaceSpecial_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100432 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200433 \defgroup Esys_NV_Write The ESAPI function for the TPM2_NV_Write command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100434 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200435 \fn TSS2_RC Esys_NV_Write_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_NV_BUFFER *data, UINT16 offset)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100436 \fn TSS2_RC Esys_NV_Write(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_NV_BUFFER *data, UINT16 offset)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200437 \fn TSS2_RC Esys_NV_Write_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100438 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200439 \defgroup Esys_NV_WriteLock The ESAPI function for the TPM2_NV_WriteLock command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100440 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200441 \fn TSS2_RC Esys_NV_WriteLock_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100442 \fn TSS2_RC Esys_NV_WriteLock(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200443 \fn TSS2_RC Esys_NV_WriteLock_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100444 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200445 \defgroup Esys_ObjectChangeAuth The ESAPI function for the TPM2_ObjectChangeAuth command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100446 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200447 \fn TSS2_RC Esys_ObjectChangeAuth_Async(ESYS_CONTEXT *esysContext, ESYS_TR objectHandle, ESYS_TR parentHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_AUTH *newAuth)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100448 \fn TSS2_RC Esys_ObjectChangeAuth(ESYS_CONTEXT *esysContext, ESYS_TR objectHandle, ESYS_TR parentHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_AUTH *newAuth, TPM2B_PRIVATE **outPrivate)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200449 \fn TSS2_RC Esys_ObjectChangeAuth_Finish(ESYS_CONTEXT *esysContext, TPM2B_PRIVATE **outPrivate)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100450 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200451 \defgroup Esys_PCR_Allocate The ESAPI function for the TPM2_PCR_Allocate command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100452 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200453 \fn TSS2_RC Esys_PCR_Allocate_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPML_PCR_SELECTION *pcrAllocation)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100454 \fn TSS2_RC Esys_PCR_Allocate(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPML_PCR_SELECTION *pcrAllocation, TPMI_YES_NO *allocationSuccess, UINT32 *maxPCR, UINT32 *sizeNeeded, UINT32 *sizeAvailable)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200455 \fn TSS2_RC Esys_PCR_Allocate_Finish(ESYS_CONTEXT *esysContext, TPMI_YES_NO *allocationSuccess, UINT32 *maxPCR, UINT32 *sizeNeeded, UINT32 *sizeAvailable)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100456 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200457 \defgroup Esys_PCR_Event The ESAPI function for the TPM2_PCR_Event command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100458 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200459 \fn TSS2_RC Esys_PCR_Event_Async(ESYS_CONTEXT *esysContext, ESYS_TR pcrHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_EVENT *eventData)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100460 \fn TSS2_RC Esys_PCR_Event(ESYS_CONTEXT *esysContext, ESYS_TR pcrHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_EVENT *eventData, TPML_DIGEST_VALUES **digests)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200461 \fn TSS2_RC Esys_PCR_Event_Finish(ESYS_CONTEXT *esysContext, TPML_DIGEST_VALUES **digests)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100462 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200463 \defgroup Esys_PCR_Extend The ESAPI function for the TPM2_PCR_Extend command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100464 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200465 \fn TSS2_RC Esys_PCR_Extend_Async(ESYS_CONTEXT *esysContext, ESYS_TR pcrHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPML_DIGEST_VALUES *digests)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100466 \fn TSS2_RC Esys_PCR_Extend(ESYS_CONTEXT *esysContext, ESYS_TR pcrHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPML_DIGEST_VALUES *digests)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200467 \fn TSS2_RC Esys_PCR_Extend_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100468 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200469 \defgroup Esys_PCR_Read The ESAPI function for the TPM2_PCR_Read command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100470 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200471 \fn TSS2_RC Esys_PCR_Read_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPML_PCR_SELECTION *pcrSelectionIn)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100472 \fn TSS2_RC Esys_PCR_Read(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPML_PCR_SELECTION *pcrSelectionIn, UINT32 *pcrUpdateCounter, TPML_PCR_SELECTION **pcrSelectionOut, TPML_DIGEST **pcrValues)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200473 \fn TSS2_RC Esys_PCR_Read_Finish(ESYS_CONTEXT *esysContext, UINT32 *pcrUpdateCounter, TPML_PCR_SELECTION **pcrSelectionOut, TPML_DIGEST **pcrValues)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100474 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200475 \defgroup Esys_PCR_Reset The ESAPI function for the TPM2_PCR_Reset command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100476 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200477 \fn TSS2_RC Esys_PCR_Reset_Async(ESYS_CONTEXT *esysContext, ESYS_TR pcrHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100478 \fn TSS2_RC Esys_PCR_Reset(ESYS_CONTEXT *esysContext, ESYS_TR pcrHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200479 \fn TSS2_RC Esys_PCR_Reset_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100480 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200481 \defgroup Esys_PCR_SetAuthPolicy The ESAPI function for the TPM2_PCR_SetAuthPolicy command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100482 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200483 \fn TSS2_RC Esys_PCR_SetAuthPolicy_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *authPolicy, TPMI_ALG_HASH hashAlg, TPMI_DH_PCR pcrNum)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100484 \fn TSS2_RC Esys_PCR_SetAuthPolicy(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *authPolicy, TPMI_ALG_HASH hashAlg, TPMI_DH_PCR pcrNum)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200485 \fn TSS2_RC Esys_PCR_SetAuthPolicy_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100486 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200487 \defgroup Esys_PCR_SetAuthValue The ESAPI function for the TPM2_PCR_SetAuthValue command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100488 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200489 \fn TSS2_RC Esys_PCR_SetAuthValue_Async(ESYS_CONTEXT *esysContext, ESYS_TR pcrHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *auth)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100490 \fn TSS2_RC Esys_PCR_SetAuthValue(ESYS_CONTEXT *esysContext, ESYS_TR pcrHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *auth)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200491 \fn TSS2_RC Esys_PCR_SetAuthValue_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100492 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200493 \defgroup Esys_PolicyAuthorize The ESAPI function for the TPM2_PolicyAuthorize command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100494 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200495 \fn TSS2_RC Esys_PolicyAuthorize_Async(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *approvedPolicy, const TPM2B_NONCE *policyRef, const TPM2B_NAME *keySign, const TPMT_TK_VERIFIED *checkTicket)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100496 \fn TSS2_RC Esys_PolicyAuthorize(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *approvedPolicy, const TPM2B_NONCE *policyRef, const TPM2B_NAME *keySign, const TPMT_TK_VERIFIED *checkTicket)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200497 \fn TSS2_RC Esys_PolicyAuthorize_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100498 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200499 \defgroup Esys_PolicyAuthValue The ESAPI function for the TPM2_PolicyAuthValue command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100500 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200501 \fn TSS2_RC Esys_PolicyAuthValue_Async(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100502 \fn TSS2_RC Esys_PolicyAuthValue(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200503 \fn TSS2_RC Esys_PolicyAuthValue_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100504 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200505 \defgroup Esys_PolicyCommandCode The ESAPI function for the TPM2_PolicyCommandCode command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100506 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200507 \fn TSS2_RC Esys_PolicyCommandCode_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_SH_POLICY policySession, TPM2_CC code)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100508 \fn TSS2_RC Esys_PolicyCommandCode(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_SH_POLICY policySession, TPM2_CC code)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200509 \fn TSS2_RC Esys_PolicyCommandCode_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100510 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200511 \defgroup Esys_PolicyCounterTimer The ESAPI function for the TPM2_PolicyCounterTimer command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100512 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200513 \fn TSS2_RC Esys_PolicyCounterTimer_Async(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_OPERAND *operandB, UINT16 offset, TPM2_EO operation)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100514 \fn TSS2_RC Esys_PolicyCounterTimer(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_OPERAND *operandB, UINT16 offset, TPM2_EO operation)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200515 \fn TSS2_RC Esys_PolicyCounterTimer_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100516 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200517 \defgroup Esys_PolicyCpHash The ESAPI function for the TPM2_PolicyCpHash command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100518 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200519 \fn TSS2_RC Esys_PolicyCpHash_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_SH_POLICY policySession, const TPM2B_DIGEST *cpHashA)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100520 \fn TSS2_RC Esys_PolicyCpHash(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_SH_POLICY policySession, const TPM2B_DIGEST *cpHashA)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200521 \fn TSS2_RC Esys_PolicyCpHash_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100522 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200523 \defgroup Esys_PolicyDuplicationSelect The ESAPI function for the TPM2_PolicyDuplicationSelect command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100524 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200525 \fn TSS2_RC Esys_PolicyDuplicationSelect_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_SH_POLICY policySession, const TPM2B_NAME *objectName, const TPM2B_NAME *newParentName, TPMI_YES_NO includeObject)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100526 \fn TSS2_RC Esys_PolicyDuplicationSelect(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_SH_POLICY policySession, const TPM2B_NAME *objectName, const TPM2B_NAME *newParentName, TPMI_YES_NO includeObject)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200527 \fn TSS2_RC Esys_PolicyDuplicationSelect_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100528 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200529 \defgroup Esys_PolicyGetDigest The ESAPI function for the TPM2_PolicyGetDigest command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100530 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200531 \fn TSS2_RC Esys_PolicyGetDigest_Async(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100532 \fn TSS2_RC Esys_PolicyGetDigest(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPM2B_DIGEST **policyDigest)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200533 \fn TSS2_RC Esys_PolicyGetDigest_Finish(ESYS_CONTEXT *esysContext, TPM2B_DIGEST **policyDigest)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100534 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200535 \defgroup Esys_PolicyLocality The ESAPI function for the TPM2_PolicyLocality command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100536 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200537 \fn TSS2_RC Esys_PolicyLocality_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_SH_POLICY policySession, TPMA_LOCALITY locality)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100538 \fn TSS2_RC Esys_PolicyLocality(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_SH_POLICY policySession, TPMA_LOCALITY locality)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200539 \fn TSS2_RC Esys_PolicyLocality_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100540 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200541 \defgroup Esys_PolicyNameHash The ESAPI function for the TPM2_PolicyNameHash command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100542 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200543 \fn TSS2_RC Esys_PolicyNameHash_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_SH_POLICY policySession, const TPM2B_DIGEST *nameHash)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100544 \fn TSS2_RC Esys_PolicyNameHash(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_SH_POLICY policySession, const TPM2B_DIGEST *nameHash)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200545 \fn TSS2_RC Esys_PolicyNameHash_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100546 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200547 \defgroup Esys_PolicyNV The ESAPI function for the TPM2_PolicyNV command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100548 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200549 \fn TSS2_RC Esys_PolicyNV_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_OPERAND *operandB, UINT16 offset, TPM2_EO operation)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100550 \fn TSS2_RC Esys_PolicyNV(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR nvIndex, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_OPERAND *operandB, UINT16 offset, TPM2_EO operation)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200551 \fn TSS2_RC Esys_PolicyNV_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100552 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200553 \defgroup Esys_PolicyNvWritten The ESAPI function for the TPM2_PolicyNvWritten command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100554 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200555 \fn TSS2_RC Esys_PolicyNvWritten_Async(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_YES_NO writtenSet)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100556 \fn TSS2_RC Esys_PolicyNvWritten(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_YES_NO writtenSet)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200557 \fn TSS2_RC Esys_PolicyNvWritten_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100558 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200559 \defgroup Esys_PolicyOR The ESAPI function for the TPM2_PolicyOR command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100560 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200561 \fn TSS2_RC Esys_PolicyOR_Async(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPML_DIGEST *pHashList)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100562 \fn TSS2_RC Esys_PolicyOR(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPML_DIGEST *pHashList)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200563 \fn TSS2_RC Esys_PolicyOR_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100564 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200565 \defgroup Esys_PolicyPassword The ESAPI function for the TPM2_PolicyPassword command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100566 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200567 \fn TSS2_RC Esys_PolicyPassword_Async(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100568 \fn TSS2_RC Esys_PolicyPassword(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200569 \fn TSS2_RC Esys_PolicyPassword_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100570 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200571 \defgroup Esys_PolicyPCR The ESAPI function for the TPM2_PolicyPCR command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100572 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200573 \fn TSS2_RC Esys_PolicyPCR_Async(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *pcrDigest, const TPML_PCR_SELECTION *pcrs)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100574 \fn TSS2_RC Esys_PolicyPCR(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *pcrDigest, const TPML_PCR_SELECTION *pcrs)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200575 \fn TSS2_RC Esys_PolicyPCR_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100576 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200577 \defgroup Esys_PolicyPhysicalPresence The ESAPI function for the TPM2_PolicyPhysicalPresence command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100578 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200579 \fn TSS2_RC Esys_PolicyPhysicalPresence_Async(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100580 \fn TSS2_RC Esys_PolicyPhysicalPresence(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200581 \fn TSS2_RC Esys_PolicyPhysicalPresence_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100582 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200583 \defgroup Esys_PolicyRestart The ESAPI function for the TPM2_PolicyRestart command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100584 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200585 \fn TSS2_RC Esys_PolicyRestart_Async(ESYS_CONTEXT *esysContext, ESYS_TR sessionHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100586 \fn TSS2_RC Esys_PolicyRestart(ESYS_CONTEXT *esysContext, ESYS_TR sessionHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200587 \fn TSS2_RC Esys_PolicyRestart_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100588 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200589 \defgroup Esys_PolicySecret The ESAPI function for the TPM2_PolicySecret command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100590 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200591 \fn TSS2_RC Esys_PolicySecret_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_NONCE *nonceTPM, const TPM2B_DIGEST *cpHashA, const TPM2B_NONCE *policyRef, INT32 expiration)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100592 \fn TSS2_RC Esys_PolicySecret(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_NONCE *nonceTPM, const TPM2B_DIGEST *cpHashA, const TPM2B_NONCE *policyRef, INT32 expiration, TPM2B_TIMEOUT **timeout, TPMT_TK_AUTH **policyTicket)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200593 \fn TSS2_RC Esys_PolicySecret_Finish(ESYS_CONTEXT *esysContext, TPM2B_TIMEOUT **timeout, TPMT_TK_AUTH **policyTicket)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100594 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200595 \defgroup Esys_PolicySigned The ESAPI function for the TPM2_PolicySigned command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100596 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200597 \fn TSS2_RC Esys_PolicySigned_Async(ESYS_CONTEXT *esysContext, ESYS_TR authObject, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_NONCE *nonceTPM, const TPM2B_DIGEST *cpHashA, const TPM2B_NONCE *policyRef, INT32 expiration, const TPMT_SIGNATURE *auth)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100598 \fn TSS2_RC Esys_PolicySigned(ESYS_CONTEXT *esysContext, ESYS_TR authObject, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_NONCE *nonceTPM, const TPM2B_DIGEST *cpHashA, const TPM2B_NONCE *policyRef, INT32 expiration, const TPMT_SIGNATURE *auth, TPM2B_TIMEOUT **timeout, TPMT_TK_AUTH **policyTicket)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200599 \fn TSS2_RC Esys_PolicySigned_Finish(ESYS_CONTEXT *esysContext, TPM2B_TIMEOUT **timeout, TPMT_TK_AUTH **policyTicket)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100600 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200601 \defgroup Esys_PolicyTicket The ESAPI function for the TPM2_PolicyTicket command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100602 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200603 \fn TSS2_RC Esys_PolicyTicket_Async(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_TIMEOUT *timeout, const TPM2B_DIGEST *cpHashA, const TPM2B_NONCE *policyRef, const TPM2B_NAME *authName, const TPMT_TK_AUTH *ticket)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100604 \fn TSS2_RC Esys_PolicyTicket(ESYS_CONTEXT *esysContext, ESYS_TR policySession, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_TIMEOUT *timeout, const TPM2B_DIGEST *cpHashA, const TPM2B_NONCE *policyRef, const TPM2B_NAME *authName, const TPMT_TK_AUTH *ticket)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200605 \fn TSS2_RC Esys_PolicyTicket_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100606 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200607 \defgroup Esys_PP_Commands The ESAPI function for the TPM2_PP_Commands command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100608 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200609 \fn TSS2_RC Esys_PP_Commands_Async(ESYS_CONTEXT *esysContext, ESYS_TR auth, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPML_CC *setList, const TPML_CC *clearList)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100610 \fn TSS2_RC Esys_PP_Commands(ESYS_CONTEXT *esysContext, ESYS_TR auth, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPML_CC *setList, const TPML_CC *clearList)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200611 \fn TSS2_RC Esys_PP_Commands_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100612 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200613 \defgroup Esys_Quote The ESAPI function for the TPM2_Quote command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100614 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200615 \fn TSS2_RC Esys_Quote_Async(ESYS_CONTEXT *esysContext, ESYS_TR signHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPMT_SIG_SCHEME *inScheme, const TPML_PCR_SELECTION *PCRselect)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100616 \fn TSS2_RC Esys_Quote(ESYS_CONTEXT *esysContext, ESYS_TR signHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *qualifyingData, const TPMT_SIG_SCHEME *inScheme, const TPML_PCR_SELECTION *PCRselect, TPM2B_ATTEST **quoted, TPMT_SIGNATURE **signature)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200617 \fn TSS2_RC Esys_Quote_Finish(ESYS_CONTEXT *esysContext, TPM2B_ATTEST **quoted, TPMT_SIGNATURE **signature)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100618 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200619 \defgroup Esys_ReadClock The ESAPI function for the TPM2_ReadClock command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100620 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200621 \fn TSS2_RC Esys_ReadClock_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100622 \fn TSS2_RC Esys_ReadClock(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMS_TIME_INFO **currentTime)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200623 \fn TSS2_RC Esys_ReadClock_Finish(ESYS_CONTEXT *esysContext, TPMS_TIME_INFO **currentTime)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100624 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200625 \defgroup Esys_ReadPublic The ESAPI function for the TPM2_ReadPublic command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100626 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200627 \fn TSS2_RC Esys_ReadPublic_Async(ESYS_CONTEXT *esysContext, ESYS_TR objectHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100628 \fn TSS2_RC Esys_ReadPublic(ESYS_CONTEXT *esysContext, ESYS_TR objectHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPM2B_PUBLIC **outPublic, TPM2B_NAME **name, TPM2B_NAME **qualifiedName)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200629 \fn TSS2_RC Esys_ReadPublic_Finish(ESYS_CONTEXT *esysContext, TPM2B_PUBLIC **outPublic, TPM2B_NAME **name, TPM2B_NAME **qualifiedName)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100630 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200631 \defgroup Esys_Rewrap The ESAPI function for the TPM2_Rewrap command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100632 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200633 \fn TSS2_RC Esys_Rewrap_Async(ESYS_CONTEXT *esysContext, ESYS_TR oldParent, ESYS_TR newParent, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_PRIVATE *inDuplicate, const TPM2B_NAME *name, const TPM2B_ENCRYPTED_SECRET *inSymSeed)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100634 \fn TSS2_RC Esys_Rewrap(ESYS_CONTEXT *esysContext, ESYS_TR oldParent, ESYS_TR newParent, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_PRIVATE *inDuplicate, const TPM2B_NAME *name, const TPM2B_ENCRYPTED_SECRET *inSymSeed, TPM2B_PRIVATE **outDuplicate, TPM2B_ENCRYPTED_SECRET **outSymSeed)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200635 \fn TSS2_RC Esys_Rewrap_Finish(ESYS_CONTEXT *esysContext, TPM2B_PRIVATE **outDuplicate, TPM2B_ENCRYPTED_SECRET **outSymSeed)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100636 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200637 \defgroup Esys_RSA_Decrypt The ESAPI function for the TPM2_RSA_Decrypt command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100638 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200639 \fn TSS2_RC Esys_RSA_Decrypt_Async(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_PUBLIC_KEY_RSA *cipherText, const TPMT_RSA_DECRYPT *inScheme, const TPM2B_DATA *label)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100640 \fn TSS2_RC Esys_RSA_Decrypt(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_PUBLIC_KEY_RSA *cipherText, const TPMT_RSA_DECRYPT *inScheme, const TPM2B_DATA *label, TPM2B_PUBLIC_KEY_RSA **message)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200641 \fn TSS2_RC Esys_RSA_Decrypt_Finish(ESYS_CONTEXT *esysContext, TPM2B_PUBLIC_KEY_RSA **message)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100642 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200643 \defgroup Esys_RSA_Encrypt The ESAPI function for the TPM2_RSA_Encrypt command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100644 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200645 \fn TSS2_RC Esys_RSA_Encrypt_Async(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_PUBLIC_KEY_RSA *message, const TPMT_RSA_DECRYPT *inScheme, const TPM2B_DATA *label)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100646 \fn TSS2_RC Esys_RSA_Encrypt(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_PUBLIC_KEY_RSA *message, const TPMT_RSA_DECRYPT *inScheme, const TPM2B_DATA *label, TPM2B_PUBLIC_KEY_RSA **outData)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200647 \fn TSS2_RC Esys_RSA_Encrypt_Finish(ESYS_CONTEXT *esysContext, TPM2B_PUBLIC_KEY_RSA **outData)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100648 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200649 \defgroup Esys_SelfTest The ESAPI function for the TPM2_SelfTest command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100650 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200651 \fn TSS2_RC Esys_SelfTest_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_YES_NO fullTest)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100652 \fn TSS2_RC Esys_SelfTest(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_YES_NO fullTest)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200653 \fn TSS2_RC Esys_SelfTest_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100654 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200655 \defgroup Esys_SequenceComplete The ESAPI function for the TPM2_SequenceComplete command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100656 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200657 \fn TSS2_RC Esys_SequenceComplete_Async(ESYS_CONTEXT *esysContext, ESYS_TR sequenceHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_BUFFER *buffer, TPMI_RH_HIERARCHY hierarchy)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100658 \fn TSS2_RC Esys_SequenceComplete(ESYS_CONTEXT *esysContext, ESYS_TR sequenceHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_BUFFER *buffer, TPMI_RH_HIERARCHY hierarchy, TPM2B_DIGEST **result, TPMT_TK_HASHCHECK **validation)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200659 \fn TSS2_RC Esys_SequenceComplete_Finish(ESYS_CONTEXT *esysContext, TPM2B_DIGEST **result, TPMT_TK_HASHCHECK **validation)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100660 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200661 \defgroup Esys_SequenceUpdate The ESAPI function for the TPM2_SequenceUpdate command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100662 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200663 \fn TSS2_RC Esys_SequenceUpdate_Async(ESYS_CONTEXT *esysContext, ESYS_TR sequenceHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_BUFFER *buffer)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100664 \fn TSS2_RC Esys_SequenceUpdate(ESYS_CONTEXT *esysContext, ESYS_TR sequenceHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_MAX_BUFFER *buffer)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200665 \fn TSS2_RC Esys_SequenceUpdate_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100666 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200667 \defgroup Esys_SetAlgorithmSet The ESAPI function for the TPM2_SetAlgorithmSet command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100668 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200669 \fn TSS2_RC Esys_SetAlgorithmSet_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, UINT32 algorithmSet)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100670 \fn TSS2_RC Esys_SetAlgorithmSet(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, UINT32 algorithmSet)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200671 \fn TSS2_RC Esys_SetAlgorithmSet_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100672 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200673 \defgroup Esys_SetCommandCodeAuditStatus The ESAPI function for the TPM2_SetCommandCodeAuditStatus command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100674 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200675 \fn TSS2_RC Esys_SetCommandCodeAuditStatus_Async(ESYS_CONTEXT *esysContext, ESYS_TR auth, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_ALG_HASH auditAlg, const TPML_CC *setList, const TPML_CC *clearList)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100676 \fn TSS2_RC Esys_SetCommandCodeAuditStatus(ESYS_CONTEXT *esysContext, ESYS_TR auth, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPMI_ALG_HASH auditAlg, const TPML_CC *setList, const TPML_CC *clearList)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200677 \fn TSS2_RC Esys_SetCommandCodeAuditStatus_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100678 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200679 \defgroup Esys_SetPrimaryPolicy The ESAPI function for the TPM2_SetPrimaryPolicy command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100680 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200681 \fn TSS2_RC Esys_SetPrimaryPolicy_Async(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *authPolicy, TPMI_ALG_HASH hashAlg)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100682 \fn TSS2_RC Esys_SetPrimaryPolicy(ESYS_CONTEXT *esysContext, ESYS_TR authHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *authPolicy, TPMI_ALG_HASH hashAlg)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200683 \fn TSS2_RC Esys_SetPrimaryPolicy_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100684 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200685 \defgroup Esys_Shutdown The ESAPI function for the TPM2_Shutdown command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100686 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200687 \fn TSS2_RC Esys_Shutdown_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPM2_SU shutdownType)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100688 \fn TSS2_RC Esys_Shutdown(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPM2_SU shutdownType)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200689 \fn TSS2_RC Esys_Shutdown_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100690 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200691 \defgroup Esys_Sign The ESAPI function for the TPM2_Sign command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100692 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200693 \fn TSS2_RC Esys_Sign_Async(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *digest, const TPMT_SIG_SCHEME *inScheme, const TPMT_TK_HASHCHECK *validation)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100694 \fn TSS2_RC Esys_Sign(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *digest, const TPMT_SIG_SCHEME *inScheme, const TPMT_TK_HASHCHECK *validation, TPMT_SIGNATURE **signature)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200695 \fn TSS2_RC Esys_Sign_Finish(ESYS_CONTEXT *esysContext, TPMT_SIGNATURE **signature)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100696 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200697 \defgroup Esys_StartAuthSession The ESAPI function for the TPM2_StartAuthSession command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100698 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200699 \fn TSS2_RC Esys_StartAuthSession_Async(ESYS_CONTEXT *esysContext, ESYS_TR tpmKey, ESYS_TR bind, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_NONCE *nonceCaller, const TPM2B_ENCRYPTED_SECRET *encryptedSalt, TPM2_SE sessionType, const TPMT_SYM_DEF *symmetric, TPMI_ALG_HASH authHash)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100700 \fn TSS2_RC Esys_StartAuthSession(ESYS_CONTEXT *esysContext, ESYS_TR tpmKey, ESYS_TR bind, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_NONCE *nonceCaller, const TPM2B_ENCRYPTED_SECRET *encryptedSalt, TPM2_SE sessionType, const TPMT_SYM_DEF *symmetric, TPMI_ALG_HASH authHash, ESYS_TR *sessionHandle, TPM2B_NONCE **nonceTPM)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200701 \fn TSS2_RC Esys_StartAuthSession_Finish(ESYS_CONTEXT *esysContext, ESYS_TR *sessionHandle, TPM2B_NONCE **nonceTPM)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100702 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200703 \defgroup Esys_Startup The ESAPI function for the TPM2_Startup command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100704 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200705 \fn TSS2_RC Esys_Startup_Async(ESYS_CONTEXT *esysContext, TPM2_SU startupType)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100706 \fn TSS2_RC Esys_Startup(ESYS_CONTEXT *esysContext, TPM2_SU startupType)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200707 \fn TSS2_RC Esys_Startup_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100708 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200709 \defgroup Esys_StirRandom The ESAPI function for the TPM2_StirRandom command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100710 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200711 \fn TSS2_RC Esys_StirRandom_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_SENSITIVE_DATA *inData)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100712 \fn TSS2_RC Esys_StirRandom(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_SENSITIVE_DATA *inData)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200713 \fn TSS2_RC Esys_StirRandom_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100714 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200715 \defgroup Esys_TestParms The ESAPI function for the TPM2_TestParms command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100716 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200717 \fn TSS2_RC Esys_TestParms_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPMT_PUBLIC_PARMS *parameters)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100718 \fn TSS2_RC Esys_TestParms(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPMT_PUBLIC_PARMS *parameters)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200719 \fn TSS2_RC Esys_TestParms_Finish(ESYS_CONTEXT *esysContext)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100720 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200721 \defgroup Esys_Unseal The ESAPI function for the TPM2_Unseal command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100722 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200723 \fn TSS2_RC Esys_Unseal_Async(ESYS_CONTEXT *esysContext, ESYS_TR itemHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100724 \fn TSS2_RC Esys_Unseal(ESYS_CONTEXT *esysContext, ESYS_TR itemHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, TPM2B_SENSITIVE_DATA **outData)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200725 \fn TSS2_RC Esys_Unseal_Finish(ESYS_CONTEXT *esysContext, TPM2B_SENSITIVE_DATA **outData)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100726 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200727 \defgroup Esys_Vendor_TCG_Test The ESAPI function for the TPM2_Vendor_TCG_Test command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100728 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200729 \fn TSS2_RC Esys_Vendor_TCG_Test_Async(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *inputData)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100730 \fn TSS2_RC Esys_Vendor_TCG_Test(ESYS_CONTEXT *esysContext, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DATA *inputData, TPM2B_DATA **outputData)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200731 \fn TSS2_RC Esys_Vendor_TCG_Test_Finish(ESYS_CONTEXT *esysContext, TPM2B_DATA **outputData)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100732 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200733 \defgroup Esys_VerifySignature The ESAPI function for the TPM2_VerifySignature command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100734 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200735 \fn TSS2_RC Esys_VerifySignature_Async(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *digest, const TPMT_SIGNATURE *signature)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100736 \fn TSS2_RC Esys_VerifySignature(ESYS_CONTEXT *esysContext, ESYS_TR keyHandle, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_DIGEST *digest, const TPMT_SIGNATURE *signature, TPMT_TK_VERIFIED **validation)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200737 \fn TSS2_RC Esys_VerifySignature_Finish(ESYS_CONTEXT *esysContext, TPMT_TK_VERIFIED **validation)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100738 \}
Andreas Fuchsbc169cb2018-04-10 12:02:10 +0200739 \defgroup Esys_ZGen_2Phase The ESAPI function for the TPM2_ZGen_2Phase command.
Andreas Fuchs2968c712018-02-01 18:22:47 +0100740 \{
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200741 \fn TSS2_RC Esys_ZGen_2Phase_Async(ESYS_CONTEXT *esysContext, ESYS_TR keyA, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_ECC_POINT *inQsB, const TPM2B_ECC_POINT *inQeB, TPMI_ECC_KEY_EXCHANGE inScheme, UINT16 counter)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100742 \fn TSS2_RC Esys_ZGen_2Phase(ESYS_CONTEXT *esysContext, ESYS_TR keyA, ESYS_TR shandle1, ESYS_TR shandle2, ESYS_TR shandle3, const TPM2B_ECC_POINT *inQsB, const TPM2B_ECC_POINT *inQeB, TPMI_ECC_KEY_EXCHANGE inScheme, UINT16 counter, TPM2B_ECC_POINT **outZ1, TPM2B_ECC_POINT **outZ2)
Andreas Fuchsf0973c02018-04-26 12:02:59 +0200743 \fn TSS2_RC Esys_ZGen_2Phase_Finish(ESYS_CONTEXT *esysContext, TPM2B_ECC_POINT **outZ1, TPM2B_ECC_POINT **outZ2)
Andreas Fuchs2968c712018-02-01 18:22:47 +0100744 \}
745 \}
746*/
747
748/*!
749 \defgroup iesys Internals of Enhanced System API
750 \ingroup esys
751 This module holds internal APIs of the ESAPI implementation.
752 \{
753 \}
754*/
755
756
Juergen Repp506c4732018-04-26 11:15:50 +0200757/*!
758 \defgroup Internal Cryptographic Backend
759 \ingroup iesys
760 \todo Description
761 \{
762 \def IESYS_CRYPTO_CONTEXT_BLOB
763 \fn TSS2_RC iesys_crypto_hash_get_digest_size(TPM2_ALG_ID hashAlg, size_t *size)
764 \fn TSS2_RC iesys_cryptogcry_hash_start( IESYS_CRYPTO_CONTEXT_BLOB **context, TPM2_ALG_ID hashAlg)
765 \fn TSS2_RC iesys_cryptogcry_hash_update( IESYS_CRYPTO_CONTEXT_BLOB *context, const uint8_t *buffer, size_t size)
766 \fn TSS2_RC iesys_cryptogcry_hash_update2b( IESYS_CRYPTO_CONTEXT_BLOB *context, TPM2B *b)
767 \fn TSS2_RC iesys_cryptogcry_hash_finish( IESYS_CRYPTO_CONTEXT_BLOB **context, uint8_t *buffer, size_t *size)
768 \fn TSS2_RC iesys_cryptogcry_hash_finish2b( IESYS_CRYPTO_CONTEXT_BLOB **context, TPM2B *b)
769 void iesys_cryptogcry_hash_abort(IESYS_CRYPTO_CONTEXT_BLOB **context)
770 \fn TSS2_RC iesys_cryptogcry_hmac_start( IESYS_CRYPTO_CONTEXT_BLOB **context, TPM2_ALG_ID hmacAlg, const uint8_t *key, size_t size)
771 \fn TSS2_RC iesys_cryptogcry_hmac_start2b( IESYS_CRYPTO_CONTEXT_BLOB **context, TPM2_ALG_ID hmacAlg, TPM2B *b)
772 \fn TSS2_RC iesys_cryptogcry_hmac_update( IESYS_CRYPTO_CONTEXT_BLOB *context, const uint8_t *buffer, size_t size)
773 \fn TSS2_RC iesys_cryptogcry_hmac_update2b( IESYS_CRYPTO_CONTEXT_BLOB *context, TPM2B *b)
774 \fn TSS2_RC iesys_cryptogcry_hmac_finish( IESYS_CRYPTO_CONTEXT_BLOB **context, uint8_t *buffer, size_t *size)
775 \fn TSS2_RC iesys_cryptogcry_hmac_finish2b( IESYS_CRYPTO_CONTEXT_BLOB **context, TPM2B *b)
776 \fn void iesys_cryptogcry_hmac_abort(IESYS_CRYPTO_CONTEXT_BLOB **context)
777 \fn TSS2_RC iesys_crypto_pHash( TPM2_ALG_ID alg, const uint8_t rcBuffer[4], const uint8_t ccBuffer[4], const TPM2B_NAME *name1, const TPM2B_NAME *name2, const TPM2B_NAME *name3, const uint8_t *pBuffer, size_t pBuffer_size, uint8_t *pHash, size_t *pHash_size)
778 \fn TSS2_RC iesys_crypto_authHmac( TPM2_ALG_ID alg, uint8_t *hmacKey, size_t hmacKeySize, const uint8_t *pHash, size_t pHash_size, const TPM2B_NONCE *nonceNewer, const TPM2B_NONCE *nonceOlder, const TPM2B_NONCE *nonceDecrypt, const TPM2B_NONCE *nonceEncrypt, TPMA_SESSION sessionAttributes, TPM2B_AUTH *hmac)
779 \fn TSS2_RC iesys_cryptogcry_random2b(TPM2B_NONCE *nonce, size_t num_bytes)
780 \fn TSS2_RC iesys_cryptogcry_pk_encrypt( TPM2B_PUBLIC *key, size_t in_size, BYTE *in_buffer, size_t max_out_size, BYTE *out_buffer, size_t *out_size, const char *label)
781 \fn TSS2_RC iesys_crypto_KDFaHmac( TPM2_ALG_ID alg, uint8_t *hmacKey, size_t hmacKeySize, uint32_t counter, const char *label, TPM2B_NONCE *contextU, TPM2B_NONCE *contextV, uint32_t bitlength, uint8_t *hmac, size_t *hmacSize)
782 \fn TSS2_RC iesys_crypto_KDFa( TPM2_ALG_ID hashAlg, uint8_t *hmacKey, size_t hmacKeySize, const char *label, TPM2B_NONCE *contextU, TPM2B_NONCE *contextV, uint32_t bitLength, uint32_t *counterInOut, BYTE *outKey, BOOL use_digest_size)
783 \fn TSS2_RC iesys_cryptogcry_KDFe( TPM2_ALG_ID hashAlg, TPM2B_ECC_PARAMETER *Z, const char *label, TPM2B_ECC_PARAMETER *partyUInfo, TPM2B_ECC_PARAMETER *partyVInfo, UINT32 bit_size, BYTE *key)
784 \fn TSS2_RC iesys_cryptogcry_sym_aes_encrypt( uint8_t *key, TPM2_ALG_ID tpm_sym_alg, TPMI_AES_KEY_BITS key_bits, TPM2_ALG_ID tpm_mode, size_t blk_len, uint8_t *dst, size_t dst_size, uint8_t *iv)
785 \fn TSS2_RC iesys_cryptogcry_sym_aes_decrypt( uint8_t *key, TPM2_ALG_ID tpm_sym_alg, TPMI_AES_KEY_BITS key_bits, TPM2_ALG_ID tpm_mode, size_t blk_len, uint8_t *dst, size_t dst_size, uint8_t *iv)
786 \fn TSS2_RC iesys_xor_parameter_obfuscation( TPM2_ALG_ID hash_alg, uint8_t *key, size_t key_size, TPM2B_NONCE * contextU, TPM2B_NONCE * contextV, BYTE *data, size_t data_size)
787 \fn TSS2_RC iesys_cryptogcry_get_ecdh_point( TPM2B_PUBLIC * key, size_t max_out_size, TPM2B_ECC_PARAMETER *Z, TPMS_ECC_POINT *Q, BYTE * out_buffer, size_t * out_size)
788 \}
789*/
Andreas Fuchs2968c712018-02-01 18:22:47 +0100790
791/*!
792 \defgroup Testgroup Testing
793 \todo description
794 \{
795
796 \}
797*/
798