xref: /aosp_15_r20/external/tpm2-tss/test/integration/sapi-tpm-properties.int.c (revision 758e9fba6fc9adbf15340f70c73baee7b168b1c9)
1*758e9fbaSOystein Eftevaag /* SPDX-License-Identifier: BSD-2-Clause */
2*758e9fbaSOystein Eftevaag /***********************************************************************
3*758e9fbaSOystein Eftevaag  * Copyright (c) 2017-2018, Intel Corporation
4*758e9fbaSOystein Eftevaag  *
5*758e9fbaSOystein Eftevaag  * All rights reserved.
6*758e9fbaSOystein Eftevaag  ***********************************************************************/
7*758e9fbaSOystein Eftevaag #ifdef HAVE_CONFIG_H
8*758e9fbaSOystein Eftevaag #include <config.h>
9*758e9fbaSOystein Eftevaag #endif
10*758e9fbaSOystein Eftevaag 
11*758e9fbaSOystein Eftevaag #include <stdio.h>
12*758e9fbaSOystein Eftevaag #include <stdlib.h>
13*758e9fbaSOystein Eftevaag 
14*758e9fbaSOystein Eftevaag #include "tss2_sys.h"
15*758e9fbaSOystein Eftevaag 
16*758e9fbaSOystein Eftevaag #define LOGMODULE test
17*758e9fbaSOystein Eftevaag #include "util/log.h"
18*758e9fbaSOystein Eftevaag #include "test.h"
19*758e9fbaSOystein Eftevaag 
20*758e9fbaSOystein Eftevaag int
test_invoke(TSS2_SYS_CONTEXT * sapi_context)21*758e9fbaSOystein Eftevaag test_invoke (TSS2_SYS_CONTEXT *sapi_context)
22*758e9fbaSOystein Eftevaag {
23*758e9fbaSOystein Eftevaag     TSS2_RC rc;
24*758e9fbaSOystein Eftevaag     TPMS_CAPABILITY_DATA capability_data;
25*758e9fbaSOystein Eftevaag 
26*758e9fbaSOystein Eftevaag     LOG_INFO("Get TPM Properties Test started.");
27*758e9fbaSOystein Eftevaag     rc = Tss2_Sys_GetCapability(sapi_context, 0, TPM2_CAP_TPM_PROPERTIES,
28*758e9fbaSOystein Eftevaag                                 TPM2_PT_MANUFACTURER, 1, 0, &capability_data, 0);
29*758e9fbaSOystein Eftevaag     if (rc != TSS2_RC_SUCCESS ||
30*758e9fbaSOystein Eftevaag         capability_data.data.tpmProperties.tpmProperty[0].property != TPM2_PT_MANUFACTURER) {
31*758e9fbaSOystein Eftevaag         LOG_ERROR("Get TPM Properties TPM2_PT_MANUFACTURER FAILED! Response Code : 0x%x", rc);
32*758e9fbaSOystein Eftevaag         exit(1);
33*758e9fbaSOystein Eftevaag     }
34*758e9fbaSOystein Eftevaag     LOG_INFO("TPM Manufacturer 0x%x", capability_data.data.tpmProperties.tpmProperty[0].value);
35*758e9fbaSOystein Eftevaag 
36*758e9fbaSOystein Eftevaag     rc = Tss2_Sys_GetCapability(sapi_context, 0, TPM2_CAP_TPM_PROPERTIES,
37*758e9fbaSOystein Eftevaag                                 TPM2_PT_REVISION, 1, 0, &capability_data, 0);
38*758e9fbaSOystein Eftevaag     if (rc != TSS2_RC_SUCCESS ||
39*758e9fbaSOystein Eftevaag         capability_data.data.tpmProperties.tpmProperty[0].property != TPM2_PT_REVISION) {
40*758e9fbaSOystein Eftevaag         LOG_ERROR("Get TPM Properties TPM2_PT_REVISION FAILED! Response Code : 0x%x", rc);
41*758e9fbaSOystein Eftevaag         exit(1);
42*758e9fbaSOystein Eftevaag     }
43*758e9fbaSOystein Eftevaag     LOG_INFO("TPM revision 0x%X", capability_data.data.tpmProperties.tpmProperty[0].value);
44*758e9fbaSOystein Eftevaag 
45*758e9fbaSOystein Eftevaag     LOG_INFO("Get TPM Properties Test Passed!");
46*758e9fbaSOystein Eftevaag     return 0;
47*758e9fbaSOystein Eftevaag }
48