TPMLIB_GetTPMProperty(3) | TPMLIB_GetTPMProperty(3) |
TPMLIB_GetTPMProperty - Get a runtime property of the TPM
TPM library (libtpms, -ltpms)
#include <libtpms/tpm_library.h>
TPM_RESULT TPMLIB_GetTPMProperty(enum TPMLIB_TPMProperty, int *result);
The TPMLIB_GetTPMProperty() call is used to retrieve run-time parameters of the TPM such as the number of authorization sessions it can hold or the maximum sizes of the permanent state, savestate or volatile state blobs.
This function can be called before or after the TPM has been created. The current implementation of libtpms will return the same value before and after the TPM was started.
With the introduction of the function TPMLIB_ChooseTPMVersion(), the call to this function should be executed after the TPM version has been chosen. The reason is that different TPM versions may return different values.
The following properties have been defined:
For a complete list of TPM error codes please consult the include file libtpms/tpm_error.h
#include <stdio.h> #include <libtpms/tpm_library.h> #include <libtpms/tpm_error.h> int main(void) { TPM_RESULT res; int result; int rc = 0; if (TPMLIB_MainInit() != TPM_SUCCESS) { fprintf(stderr, "Could not start the TPM.\n"); return 1; } if (TPMLIB_GetTPMProperty(TPMPROP_TPM_RSA_KEY_LENGTH_MAX, &result) != TPM_SUCCESS) { fprintf(stderr, "Could not read the max. size of RSA keys.\n"); goto err_exit; } fprintf(stdout, "Max. size of RSA keys: %d\n", result); err_exit: TPMLIB_Terminate(); return 0; }
TPMLIB_MainInit(3), TPMLIB_Terminate(3), TPMLIB_Process(3), TPMLIB_RegisterCallbacks(3), TPMLIB_GetVersion(3), TPMLIB_ChooseTPMVersion(3)
2024-03-31 | libtpms |