xref: /aosp_15_r20/external/tpm2-tss/test/integration/esys-testparms.int.c (revision 758e9fba6fc9adbf15340f70c73baee7b168b1c9)
1 /* SPDX-License-Identifier: BSD-2-Clause */
2 /*******************************************************************************
3  * Copyright 2017-2018, Fraunhofer SIT sponsored by Infineon Technologies AG
4  * All rights reserved.
5  *******************************************************************************/
6 
7 #ifdef HAVE_CONFIG_H
8 #include <config.h>
9 #endif
10 
11 #include <stdlib.h>
12 
13 #include "tss2_esys.h"
14 
15 #include "esys_iutil.h"
16 #define LOGMODULE test
17 #include "util/log.h"
18 #include "util/aux_util.h"
19 
20 /** Test the ESAPI function Esys_TestParms.
21  *
22  * Tested ESAPI commands:
23  *  - Esys_TestParms() (M)
24  *
25  * @param[in,out] esys_context The ESYS_CONTEXT.
26  * @retval EXIT_FAILURE
27  * @retval EXIT_SUCCESS
28  */
29 int
test_esys_testparms(ESYS_CONTEXT * esys_context)30 test_esys_testparms(ESYS_CONTEXT * esys_context)
31 {
32     TSS2_RC r;
33 
34     TPMT_PUBLIC_PARMS parameters = {
35         .type = TPM2_ALG_RSA,
36         .parameters = {
37             .rsaDetail = {
38                  .symmetric = {
39                      .algorithm = TPM2_ALG_AES,
40                      .keyBits.aes = 128,
41                  .mode.aes = TPM2_ALG_CFB,
42                  },
43                  .scheme = {
44                       .scheme =
45                       TPM2_ALG_NULL,
46                   },
47              .keyBits = 2048,
48                  .exponent = 0,
49              }
50         }
51     };
52 
53     r = Esys_TestParms (
54         esys_context,
55         ESYS_TR_NONE,
56         ESYS_TR_NONE,
57         ESYS_TR_NONE,
58         &parameters
59         );
60     goto_if_error(r, "Error: TestParms", error);
61 
62     return EXIT_SUCCESS;
63 
64  error:
65     return EXIT_FAILURE;
66 }
67 
68 int
test_invoke_esapi(ESYS_CONTEXT * esys_context)69 test_invoke_esapi(ESYS_CONTEXT * esys_context) {
70     return test_esys_testparms(esys_context);
71 }
72