esys-lock.int.c 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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. #ifdef HAVE_CONFIG_H
  7. #include <config.h>
  8. #endif
  9. #include <stdlib.h>
  10. #include "tss2_esys.h"
  11. #include "esys_iutil.h"
  12. #include "test-esys.h"
  13. #define LOGMODULE test
  14. #include "util/log.h"
  15. #include "util/aux_util.h"
  16. /** Test the ESYS functions related to TPM locks.
  17. *
  18. *\b Note: platform authorization needed.
  19. *
  20. * Tested ESYS commands:
  21. * - Esys_DictionaryAttackLockReset() (M)
  22. * - Esys_DictionaryAttackParameters() (M)
  23. * - Esys_NV_GlobalWriteLock() (O)
  24. *
  25. * @param[in,out] esys_context The ESYS_CONTEXT.
  26. * @retval EXIT_FAILURE
  27. * @retval EXIT_SKIP
  28. * @retval EXIT_SUCCESS
  29. */
  30. int
  31. test_esys_lock(ESYS_CONTEXT * esys_context)
  32. {
  33. TSS2_RC r;
  34. int failure_return = EXIT_FAILURE;
  35. r = Esys_DictionaryAttackLockReset(
  36. esys_context,
  37. ESYS_TR_RH_LOCKOUT,
  38. ESYS_TR_PASSWORD,
  39. ESYS_TR_NONE,
  40. ESYS_TR_NONE);
  41. goto_if_error(r, "Error: DictionaryAttackLockReset", error);
  42. UINT32 newMaxTries = 3;
  43. UINT32 newRecoveryTime = 3600;
  44. UINT32 lockoutRecovery = 1000;
  45. r = Esys_DictionaryAttackParameters(esys_context, ESYS_TR_RH_LOCKOUT,
  46. ESYS_TR_PASSWORD, ESYS_TR_NONE,
  47. ESYS_TR_NONE,
  48. newMaxTries, newRecoveryTime,
  49. lockoutRecovery);
  50. goto_if_error(r, "Error: DictionaryAttackParameters", error);
  51. r = Esys_NV_GlobalWriteLock(esys_context, ESYS_TR_RH_PLATFORM,
  52. ESYS_TR_PASSWORD, ESYS_TR_NONE, ESYS_TR_NONE);
  53. if ((r == TPM2_RC_COMMAND_CODE) ||
  54. (r == (TPM2_RC_COMMAND_CODE | TSS2_RESMGR_RC_LAYER)) ||
  55. (r == (TPM2_RC_COMMAND_CODE | TSS2_RESMGR_TPM_RC_LAYER))) {
  56. LOG_WARNING("Command TPM2_NV_GlobalWriteLock not supported by TPM.");
  57. failure_return = EXIT_SKIP;
  58. goto error;
  59. }
  60. if (number_rc(r) == TPM2_RC_BAD_AUTH) {
  61. /* Platform authorization not possible test will be skipped */
  62. LOG_WARNING("Platform authorization not possible.");
  63. return EXIT_SKIP;
  64. }
  65. goto_if_error(r, "Error: NV_GlobalWriteLock", error);
  66. return EXIT_SUCCESS;
  67. error:
  68. return failure_return;
  69. }
  70. int
  71. test_invoke_esys(ESYS_CONTEXT * esys_context) {
  72. return test_esys_lock(esys_context);
  73. }