From 6d2eec02876c251f9217a58f0e7f15a354412b1d Mon Sep 17 00:00:00 2001 From: Michael Kinney Date: Thu, 21 Jan 2016 19:29:50 +0000 Subject: [PATCH] SecurityPkg/Tcg2Config: Remove use of IoLib Remove the use of the IoLib and Mmioxx() calls to detect dTPM. This module calls the Tpm12DeviceLib to detect a TPM and the implementation of the Tpm12DeviceLib for dTPM performs the same Mmioxx() calls to detect a dTPM. This change makes this module more generic and portable by maximizing the use of the Tpm12DeviceLib abstraction for TPM detection. Cc: Chao Zhang Cc: Jiewen Yao Contributed-under: TianoCore Contribution Agreement 1.0 Signed-off-by: Michael Kinney Reviewed-by: Chao Zhang Reviewed-by: Jiewen Yao git-svn-id: https://svn.code.sf.net/p/edk2/code/trunk/edk2@19725 6f19259b-4bc3-4df7-8a09-765794883524 --- SecurityPkg/Tcg/Tcg2Config/Tcg2ConfigPei.inf | 3 +- SecurityPkg/Tcg/Tcg2Config/TpmDetection.c | 35 +++----------------- 2 files changed, 6 insertions(+), 32 deletions(-) diff --git a/SecurityPkg/Tcg/Tcg2Config/Tcg2ConfigPei.inf b/SecurityPkg/Tcg/Tcg2Config/Tcg2ConfigPei.inf index cd6a92da1c..8dd0b63e48 100644 --- a/SecurityPkg/Tcg/Tcg2Config/Tcg2ConfigPei.inf +++ b/SecurityPkg/Tcg/Tcg2Config/Tcg2ConfigPei.inf @@ -4,7 +4,7 @@ # This module initializes TPM device type based on variable and detection. # NOTE: This module is only for reference only, each platform should have its own setup page. # -# Copyright (c) 2015, Intel Corporation. All rights reserved.
+# Copyright (c) 2015 - 2016, Intel Corporation. All rights reserved.
# This program and the accompanying materials # are licensed and made available under the terms and conditions of the BSD License # which accompanies this distribution. The full text of the license may be found at @@ -49,7 +49,6 @@ DebugLib PcdLib TimerLib - IoLib Tpm12CommandLib Tpm12DeviceLib diff --git a/SecurityPkg/Tcg/Tcg2Config/TpmDetection.c b/SecurityPkg/Tcg/Tcg2Config/TpmDetection.c index 33f3a21d87..7e6ca44205 100644 --- a/SecurityPkg/Tcg/Tcg2Config/TpmDetection.c +++ b/SecurityPkg/Tcg/Tcg2Config/TpmDetection.c @@ -1,7 +1,7 @@ /** @file TPM1.2/dTPM2.0 auto detection. -Copyright (c) 2015, Intel Corporation. All rights reserved.
+Copyright (c) 2015 - 2016, Intel Corporation. All rights reserved.
This program and the accompanying materials are licensed and made available under the terms and conditions of the BSD License which accompanies this distribution. The full text of the license may be found at @@ -18,7 +18,6 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. #include #include -#include #include #include #include @@ -28,29 +27,6 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED. #include "Tcg2ConfigNvData.h" -/** - This routine return if dTPM (1.2 or 2.0) present. - - @retval TRUE dTPM present - @retval FALSE dTPM not present -**/ -BOOLEAN -IsDtpmPresent ( - VOID - ) -{ - UINT8 RegRead; - - RegRead = MmioRead8 ((UINTN)PcdGet64 (PcdTpmBaseAddress)); - if (RegRead == 0xFF) { - DEBUG ((EFI_D_ERROR, "DetectTpmDevice: Dtpm not present\n")); - return FALSE; - } else { - DEBUG ((EFI_D_INFO, "DetectTpmDevice: Dtpm present\n")); - return TRUE; - } -} - /** This routine check both SetupVariable and real TPM device, and return final TpmDevice configuration. @@ -100,10 +76,6 @@ DetectTpmDevice ( } DEBUG ((EFI_D_INFO, "DetectTpmDevice:\n")); - if (!IsDtpmPresent ()) { - // dTPM not available - return TPM_DEVICE_NULL; - } // dTPM available and not disabled by setup // We need check if it is TPM1.2 or TPM2.0 @@ -111,7 +83,10 @@ DetectTpmDevice ( Status = Tpm12RequestUseTpm (); if (EFI_ERROR (Status)) { - return TPM_DEVICE_2_0_DTPM; + // + // dTPM not available + // + return TPM_DEVICE_NULL; } if (BootMode == BOOT_ON_S3_RESUME) {