1*758e9fbaSOystein Eftevaag /* SPDX-License-Identifier: BSD-2-Clause */
2*758e9fbaSOystein Eftevaag #ifdef HAVE_CONFIG_H
3*758e9fbaSOystein Eftevaag #include <config.h>
4*758e9fbaSOystein Eftevaag #endif
5*758e9fbaSOystein Eftevaag
6*758e9fbaSOystein Eftevaag #include <stdlib.h>
7*758e9fbaSOystein Eftevaag
8*758e9fbaSOystein Eftevaag #include "tss2_esys.h"
9*758e9fbaSOystein Eftevaag
10*758e9fbaSOystein Eftevaag #include "esys_iutil.h"
11*758e9fbaSOystein Eftevaag #define LOGMODULE test
12*758e9fbaSOystein Eftevaag #include "util/log.h"
13*758e9fbaSOystein Eftevaag #include "util/aux_util.h"
14*758e9fbaSOystein Eftevaag
15*758e9fbaSOystein Eftevaag /** This tests the ability to create an ESYS_TR object via Esys_TR_FromTPMPublic
16*758e9fbaSOystein Eftevaag * given a TPM2_HANDLE representing a session handle.
17*758e9fbaSOystein Eftevaag *
18*758e9fbaSOystein Eftevaag * Tested ESAPI commands:
19*758e9fbaSOystein Eftevaag * - Esys_StartAuthSession() (M)
20*758e9fbaSOystein Eftevaag * - Esys_GetCapability() (M)
21*758e9fbaSOystein Eftevaag * - Esys_FlushContext() (M)
22*758e9fbaSOystein Eftevaag *
23*758e9fbaSOystein Eftevaag * @param[in,out] ectx The ESYS_CONTEXT.
24*758e9fbaSOystein Eftevaag * @retval EXIT_FAILURE
25*758e9fbaSOystein Eftevaag * @retval EXIT_SUCCESS
26*758e9fbaSOystein Eftevaag */
27*758e9fbaSOystein Eftevaag
28*758e9fbaSOystein Eftevaag int
test_esys_tr_fromTpmPublic_session(ESYS_CONTEXT * ectx)29*758e9fbaSOystein Eftevaag test_esys_tr_fromTpmPublic_session(ESYS_CONTEXT * ectx)
30*758e9fbaSOystein Eftevaag {
31*758e9fbaSOystein Eftevaag int rc = EXIT_FAILURE;
32*758e9fbaSOystein Eftevaag
33*758e9fbaSOystein Eftevaag ESYS_TR session = ESYS_TR_NONE;
34*758e9fbaSOystein Eftevaag TPMT_SYM_DEF symmetric = {
35*758e9fbaSOystein Eftevaag .algorithm = TPM2_ALG_XOR,
36*758e9fbaSOystein Eftevaag .keyBits = { .exclusiveOr = TPM2_ALG_SHA1 }
37*758e9fbaSOystein Eftevaag };
38*758e9fbaSOystein Eftevaag
39*758e9fbaSOystein Eftevaag TPMS_CAPABILITY_DATA *cap_data = NULL;
40*758e9fbaSOystein Eftevaag
41*758e9fbaSOystein Eftevaag TSS2_RC r = Esys_StartAuthSession(ectx, ESYS_TR_NONE, ESYS_TR_NONE,
42*758e9fbaSOystein Eftevaag ESYS_TR_NONE, ESYS_TR_NONE, ESYS_TR_NONE,
43*758e9fbaSOystein Eftevaag NULL,
44*758e9fbaSOystein Eftevaag TPM2_SE_HMAC, &symmetric, TPM2_ALG_SHA1,
45*758e9fbaSOystein Eftevaag &session);
46*758e9fbaSOystein Eftevaag goto_if_error(r, "Error: During initialization of session", out);
47*758e9fbaSOystein Eftevaag
48*758e9fbaSOystein Eftevaag TPMI_YES_NO more_data;
49*758e9fbaSOystein Eftevaag r = Esys_GetCapability(ectx, ESYS_TR_NONE, ESYS_TR_NONE, ESYS_TR_NONE,
50*758e9fbaSOystein Eftevaag TPM2_CAP_HANDLES,
51*758e9fbaSOystein Eftevaag TPM2_LOADED_SESSION_FIRST,
52*758e9fbaSOystein Eftevaag TPM2_MAX_CAP_HANDLES,
53*758e9fbaSOystein Eftevaag &more_data,
54*758e9fbaSOystein Eftevaag &cap_data);
55*758e9fbaSOystein Eftevaag goto_if_error(r, "Error: getting capability for loaded sessions", out);
56*758e9fbaSOystein Eftevaag
57*758e9fbaSOystein Eftevaag if (cap_data->data.handles.count != 1) {
58*758e9fbaSOystein Eftevaag LOG_ERROR("Expected 1 loaded session handle, got: %"PRIu32,
59*758e9fbaSOystein Eftevaag cap_data->data.handles.count);
60*758e9fbaSOystein Eftevaag goto out;
61*758e9fbaSOystein Eftevaag }
62*758e9fbaSOystein Eftevaag
63*758e9fbaSOystein Eftevaag TPM2_HANDLE tpm2_handle = cap_data->data.handles.handle[0];
64*758e9fbaSOystein Eftevaag
65*758e9fbaSOystein Eftevaag ESYS_TR new_handle = ESYS_TR_NONE;
66*758e9fbaSOystein Eftevaag r = Esys_TR_FromTPMPublic(
67*758e9fbaSOystein Eftevaag ectx,
68*758e9fbaSOystein Eftevaag tpm2_handle,
69*758e9fbaSOystein Eftevaag ESYS_TR_NONE,
70*758e9fbaSOystein Eftevaag ESYS_TR_NONE,
71*758e9fbaSOystein Eftevaag ESYS_TR_NONE,
72*758e9fbaSOystein Eftevaag &new_handle);
73*758e9fbaSOystein Eftevaag goto_if_error(r, "Error: converting TPM2_HANDLE to ESYS_TR object", out);
74*758e9fbaSOystein Eftevaag
75*758e9fbaSOystein Eftevaag r = Esys_TRSess_SetAttributes(ectx, new_handle,
76*758e9fbaSOystein Eftevaag TPMA_SESSION_DECRYPT|TPMA_SESSION_ENCRYPT,
77*758e9fbaSOystein Eftevaag 0xFF);
78*758e9fbaSOystein Eftevaag if (r != TSS2_ESYS_RC_BAD_TR) {
79*758e9fbaSOystein Eftevaag LOG_ERROR("Error: Expected GetCapability call to fail with "
80*758e9fbaSOystein Eftevaag "TSS2_ESYS_RC_BAD_TR, got: "TPM2_ERROR_FORMAT,
81*758e9fbaSOystein Eftevaag TPM2_ERROR_TEXT(r));
82*758e9fbaSOystein Eftevaag goto out;
83*758e9fbaSOystein Eftevaag }
84*758e9fbaSOystein Eftevaag
85*758e9fbaSOystein Eftevaag free(cap_data);
86*758e9fbaSOystein Eftevaag cap_data = NULL;
87*758e9fbaSOystein Eftevaag
88*758e9fbaSOystein Eftevaag r = Esys_GetCapability(ectx, new_handle, ESYS_TR_NONE, ESYS_TR_NONE,
89*758e9fbaSOystein Eftevaag TPM2_CAP_HANDLES,
90*758e9fbaSOystein Eftevaag TPM2_LOADED_SESSION_FIRST,
91*758e9fbaSOystein Eftevaag TPM2_MAX_CAP_HANDLES,
92*758e9fbaSOystein Eftevaag &more_data,
93*758e9fbaSOystein Eftevaag &cap_data);
94*758e9fbaSOystein Eftevaag if (r != TSS2_ESYS_RC_BAD_TR) {
95*758e9fbaSOystein Eftevaag LOG_ERROR("Error: Expected GetCapability call to fail with "
96*758e9fbaSOystein Eftevaag "TSS2_ESYS_RC_BAD_TR, got: "TPM2_ERROR_FORMAT,
97*758e9fbaSOystein Eftevaag TPM2_ERROR_TEXT(r));
98*758e9fbaSOystein Eftevaag goto out;
99*758e9fbaSOystein Eftevaag }
100*758e9fbaSOystein Eftevaag
101*758e9fbaSOystein Eftevaag /* ensure you can flush the frompublic session handle */
102*758e9fbaSOystein Eftevaag session = new_handle;
103*758e9fbaSOystein Eftevaag
104*758e9fbaSOystein Eftevaag rc = EXIT_SUCCESS;
105*758e9fbaSOystein Eftevaag out:
106*758e9fbaSOystein Eftevaag free(cap_data);
107*758e9fbaSOystein Eftevaag
108*758e9fbaSOystein Eftevaag if (session != ESYS_TR_NONE) {
109*758e9fbaSOystein Eftevaag r = Esys_FlushContext(ectx, session);
110*758e9fbaSOystein Eftevaag if (r != TSS2_RC_SUCCESS) {
111*758e9fbaSOystein Eftevaag LOG_ERROR("Error: FlushContext " TPM2_ERROR_FORMAT, TPM2_ERROR_TEXT(r));
112*758e9fbaSOystein Eftevaag rc = EXIT_FAILURE;
113*758e9fbaSOystein Eftevaag }
114*758e9fbaSOystein Eftevaag }
115*758e9fbaSOystein Eftevaag
116*758e9fbaSOystein Eftevaag return rc;
117*758e9fbaSOystein Eftevaag }
118*758e9fbaSOystein Eftevaag
119*758e9fbaSOystein Eftevaag int
test_invoke_esapi(ESYS_CONTEXT * esys_context)120*758e9fbaSOystein Eftevaag test_invoke_esapi(ESYS_CONTEXT * esys_context) {
121*758e9fbaSOystein Eftevaag return test_esys_tr_fromTpmPublic_session(esys_context);
122*758e9fbaSOystein Eftevaag }
123