提交 829bf067 编写于 作者: S Stefan Berger 提交者: Rajiv Andrade

tpm: Use interface timeouts returned from the TPM

The TPM driver currently discards the interface timeout values returned
from the TPM. The check of the response packet needs to consider that
the return_code field is 0 on success and the size of the expected
packet is equivalent to the header size + u32 length indicator for the
TPM_GetCapability() result + 4 interface timeout indicators of type u32.
Signed-off-by: NStefan Berger <stefanb@linux.vnet.ibm.com>
Signed-off-by: NRajiv Andrade <srajiv@linux.vnet.ibm.com>
上级 04ab2293
...@@ -545,9 +545,10 @@ void tpm_get_timeouts(struct tpm_chip *chip) ...@@ -545,9 +545,10 @@ void tpm_get_timeouts(struct tpm_chip *chip)
if (rc) if (rc)
goto duration; goto duration;
if (be32_to_cpu(tpm_cmd.header.out.length) if (be32_to_cpu(tpm_cmd.header.out.return_code) != 0 ||
!= 4 * sizeof(u32)) be32_to_cpu(tpm_cmd.header.out.length)
goto duration; != sizeof(tpm_cmd.header.out) + sizeof(u32) + 4 * sizeof(u32))
return;
timeout_cap = &tpm_cmd.params.getcap_out.cap.timeout; timeout_cap = &tpm_cmd.params.getcap_out.cap.timeout;
/* Don't overwrite default if value is 0 */ /* Don't overwrite default if value is 0 */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册
新手
引导
客服 返回
顶部