diff options
Diffstat (limited to 'src/southbridge/intel/common/finalize.c')
-rw-r--r-- | src/southbridge/intel/common/finalize.c | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/src/southbridge/intel/common/finalize.c b/src/southbridge/intel/common/finalize.c new file mode 100644 index 0000000000..f1c33b9b06 --- /dev/null +++ b/src/southbridge/intel/common/finalize.c @@ -0,0 +1,76 @@ +/* + * This file is part of the coreboot project. + * + * Copyright (C) 2012 The Chromium OS Authors. All rights reserved. + * + * 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 <arch/io.h> +#include <console/post_codes.h> +#include <device/pci_ops.h> +#include <southbridge/intel/common/pmbase.h> +#include <southbridge/intel/common/pmutil.h> +#include <southbridge/intel/common/rcba.h> +#include <spi-generic.h> + +#include "finalize.h" + +void intel_pch_finalize_smm(void) +{ + const pci_devfn_t lpc_dev = PCI_DEV(0, 0x1f, 0); + + if (IS_ENABLED(CONFIG_LOCK_SPI_FLASH_RO) || + IS_ENABLED(CONFIG_LOCK_SPI_FLASH_NO_ACCESS)) { + int i; + u32 lockmask = 1UL << 31; + if (IS_ENABLED(CONFIG_LOCK_SPI_FLASH_NO_ACCESS)) + lockmask |= 1 << 15; + for (i = 0; i < 20; i += 4) + RCBA32(0x3874 + i) = RCBA32(0x3854 + i) | lockmask; + } + + /* Lock SPIBAR */ + RCBA32_OR(0x3804, (1 << 15)); + + if (IS_ENABLED(CONFIG_SPI_FLASH_SMM)) + /* Re-init SPI driver to handle locked BAR */ + spi_init(); + + /* TCLOCKDN: TC Lockdown */ + RCBA32_OR(0x0050, (1UL << 31)); + + /* BIOS Interface Lockdown */ + RCBA32_OR(0x3410, (1 << 0)); + + /* Function Disable SUS Well Lockdown */ + RCBA_AND_OR(8, 0x3420, ~0U, (1 << 7)); + + pci_or_config16(lpc_dev, D31F0_GEN_PMCON_1, SMI_LOCK); + + pci_or_config8(lpc_dev, D31F0_GEN_PMCON_LOCK, + ACPI_BASE_LOCK | SLP_STR_POL_LOCK); + + pci_update_config32(lpc_dev, D31F0_ETR3, ~ETR3_CF9GR, ETR3_CF9LOCK); + + if (IS_ENABLED(CONFIG_SOUTHBRIDGE_INTEL_LYNXPOINT)) + /* PMSYNC */ + RCBA32_OR(0x33c4, (1UL << 31)); + + /* R/WO registers */ + RCBA32(0x21a4) = RCBA32(0x21a4); + pci_write_config32(PCI_DEV(0, 27, 0), 0x74, + pci_read_config32(PCI_DEV(0, 27, 0), 0x74)); + + write_pmbase16(TCO1_CNT, read_pmbase16(TCO1_CNT) | TCO_LOCK); + + outb(POST_OS_BOOT, CONFIG_POST_IO_PORT); +} |