From 9d9a121fa0cc0a5b303aaf377ce2a8e426ef0d3a Mon Sep 17 00:00:00 2001 From: Aaron Durbin Date: Wed, 19 Apr 2017 10:02:27 -0500 Subject: soc/intel/common: provide default tis_plat_irq_status() implementation On Intel platforms utilizing the CR50 TPM the interrupts are routed to GPIOs connected to the GPE blocks. Therefore, provide a common implementation for tis_plat_irq_status() to reduce code duplication. This code could be further extended to not be added based on MAINBOARD_HAS_TPM_CR50, but that's all that's using it for now. Change-Id: I955df0a536408b2ccd07146893337c53799e243f Signed-off-by: Aaron Durbin Reviewed-on: https://review.coreboot.org/19369 Reviewed-by: Furquan Shaikh Reviewed-by: Duncan Laurie Tested-by: build bot (Jenkins) --- src/soc/intel/common/Kconfig | 6 ++++++ src/soc/intel/common/Makefile.inc | 5 +++++ src/soc/intel/common/tpm_tis.c | 22 ++++++++++++++++++++++ 3 files changed, 33 insertions(+) create mode 100644 src/soc/intel/common/tpm_tis.c (limited to 'src/soc/intel') diff --git a/src/soc/intel/common/Kconfig b/src/soc/intel/common/Kconfig index 919cb50406..7612850965 100644 --- a/src/soc/intel/common/Kconfig +++ b/src/soc/intel/common/Kconfig @@ -130,4 +130,10 @@ config SOC_INTEL_COMMON_NHLT bool default n +config TPM_TIS_ACPI_INTERRUPT + int + help + acpi_get_gpe() is used to provide interrupt status to TPM layer. + This option specifies the GPE number. + endif # SOC_INTEL_COMMON diff --git a/src/soc/intel/common/Makefile.inc b/src/soc/intel/common/Makefile.inc index acfd0548b2..b01fc8a70e 100644 --- a/src/soc/intel/common/Makefile.inc +++ b/src/soc/intel/common/Makefile.inc @@ -37,6 +37,11 @@ ramstage-$(CONFIG_SOC_INTEL_COMMON_NHLT) += nhlt.c smm-$(CONFIG_SOC_INTEL_COMMON_SMI) += smihandler.c +bootblock-$(CONFIG_MAINBOARD_HAS_TPM_CR50) += tpm_tis.c +verstage-$(CONFIG_MAINBOARD_HAS_TPM_CR50) += tpm_tis.c +romstage-$(CONFIG_MAINBOARD_HAS_TPM_CR50) += tpm_tis.c +ramstage-$(CONFIG_MAINBOARD_HAS_TPM_CR50) += tpm_tis.c + # Create and add the MRC cache to the cbfs image ifneq ($(CONFIG_CHROMEOS),y) $(obj)/mrc.cache: $(obj)/config.h diff --git a/src/soc/intel/common/tpm_tis.c b/src/soc/intel/common/tpm_tis.c new file mode 100644 index 0000000000..ed57cef488 --- /dev/null +++ b/src/soc/intel/common/tpm_tis.c @@ -0,0 +1,22 @@ +/* + * This file is part of the coreboot project. + * + * Copyright 2017 Google Inc. + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; version 2 of the License. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + */ + +#include +#include + +int tis_plat_irq_status(void) +{ + return acpi_get_gpe(CONFIG_TPM_TIS_ACPI_INTERRUPT); +} -- cgit v1.2.3