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