1. 23 3月, 2018 2 次提交
    • J
      tpm: fix intermittent failure with self tests · 2be8ffed
      James Bottomley 提交于
      My Nuvoton 6xx in a Dell XPS-13 has been intermittently failing to work
      (necessitating a reboot). The problem seems to be that the TPM gets into a
      state where the partial self-test doesn't return TPM_RC_SUCCESS (meaning
      all tests have run to completion), but instead returns TPM_RC_TESTING
      (meaning some tests are still running in the background).  There are
      various theories that resending the self-test command actually causes the
      tests to restart and thus triggers more TPM_RC_TESTING returns until the
      timeout is exceeded.
      
      There are several issues here: firstly being we shouldn't slow down the
      boot sequence waiting for the self test to complete once the TPM
      backgrounds them.  It will actually make available all functions that have
      passed and if it gets a failure return TPM_RC_FAILURE to every subsequent
      command.  So the fix is to kick off self tests once and if they return
      TPM_RC_TESTING log that as a backgrounded self test and continue on.  In
      order to prevent other tpm users from seeing any TPM_RC_TESTING returns
      (which it might if they send a command that needs a TPM subsystem which is
      still under test), we loop in tpm_transmit_cmd until either a timeout or we
      don't get a TPM_RC_TESTING return.
      
      Finally, there have been observations of strange returns from a partial
      test. One Nuvoton is occasionally returning TPM_RC_COMMAND_CODE, so treat
      any unexpected return from a partial self test as an indication we need to
      run a full self test.
      
      [jarkko.sakkinen@linux.intel.com: cleaned up some klog messages and
       dropped tpm_transmit_check() helper function from James' original
       commit.]
      
      Fixes: 2482b1bb ("tpm: Trigger only missing TPM 2.0 self tests")
      Cc: stable@vger.kernel.org
      Signed-off-by: NJames Bottomley <James.Bottomley@HansenPartnership.com>
      Reviewed-by: NJarkko Sakkinen <jarkko.sakkine@linux.intel.com>
      Tested-by: NJarkko Sakkinen <jarkko.sakkine@linux.intel.com>
      Signed-off-by: NJarkko Sakkinen <jarkko.sakkine@linux.intel.com>
      2be8ffed
    • T
      tpm2: add longer timeouts for creation commands. · 076d3564
      Tomas Winkler 提交于
      TPM2_CC_Create(0x153) and TPM2_CC_CreatePrimary (0x131) involve generation
      of crypto keys which can be a computationally intensive task. The timeout
      is set to 3min. Rather than increasing default timeout a new constant is
      added, to not stall for too long on regular commands failures.
      Signed-off-by: NTomas Winkler <tomas.winkler@intel.com>
      Reviewed-by: NJarkko Sakkinen <jarkko.sakkinen@linux.intel.com>
      Tested-by: NJarkko Sakkinen <jarkko.sakkinen@linux.intel.com>
      Signed-off-by: NJarkko Sakkinen <jarkko.sakkinen@linux.intel.com>
      076d3564
  2. 27 2月, 2018 1 次提交
  3. 08 1月, 2018 1 次提交
  4. 18 10月, 2017 4 次提交
  5. 24 9月, 2017 1 次提交
  6. 07 7月, 2017 3 次提交
  7. 14 6月, 2017 1 次提交
  8. 04 4月, 2017 3 次提交
  9. 20 2月, 2017 1 次提交
  10. 04 2月, 2017 3 次提交
  11. 24 1月, 2017 2 次提交
  12. 28 11月, 2016 1 次提交
  13. 15 9月, 2016 4 次提交
  14. 03 9月, 2016 1 次提交
  15. 19 7月, 2016 2 次提交
  16. 25 6月, 2016 3 次提交
  17. 20 2月, 2016 1 次提交
  18. 10 2月, 2016 1 次提交
  19. 20 12月, 2015 2 次提交
  20. 09 11月, 2015 1 次提交
  21. 19 10月, 2015 1 次提交
  22. 15 2月, 2015 1 次提交