aboutsummaryrefslogtreecommitdiff
path: root/src/soc/intel/fsp_broadwell_de/ramstage.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/soc/intel/fsp_broadwell_de/ramstage.c')
-rw-r--r--src/soc/intel/fsp_broadwell_de/ramstage.c129
1 files changed, 0 insertions, 129 deletions
diff --git a/src/soc/intel/fsp_broadwell_de/ramstage.c b/src/soc/intel/fsp_broadwell_de/ramstage.c
deleted file mode 100644
index fd5a0392ff..0000000000
--- a/src/soc/intel/fsp_broadwell_de/ramstage.c
+++ /dev/null
@@ -1,129 +0,0 @@
-/*
- * This file is part of the coreboot project.
- *
- * Copyright (C) 2013 Google Inc.
- * Copyright (C) 2015-2016 Intel Corp.
- *
- * 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 <stdlib.h>
-#include <arch/cpu.h>
-#include <console/console.h>
-#include <cpu/intel/microcode.h>
-#include <cpu/x86/cr.h>
-#include <cpu/x86/msr.h>
-#include <device/device.h>
-#include <device/pci_def.h>
-#include <device/pci_ops.h>
-#include <soc/lpc.h>
-#include <soc/msr.h>
-#include <soc/pattrs.h>
-#include <soc/pci_devs.h>
-#include <soc/ramstage.h>
-#include <soc/broadwell_de.h>
-
-/* Global PATTRS */
-DEFINE_PATTRS;
-
-#define SHOW_PATTRS 1
-
-static void detect_num_cpus(struct pattrs *attrs)
-{
- msr_t core_thread_count = rdmsr(MSR_CORE_THREAD_COUNT);
- attrs->num_cpus = core_thread_count.lo & 0xffff;
-}
-
-static inline void fill_in_msr(msr_t *msr, int idx)
-{
- *msr = rdmsr(idx);
- if (SHOW_PATTRS) {
- printk(BIOS_DEBUG, "msr(%x) = %08x%08x\n",
- idx, msr->hi, msr->lo);
- }
-}
-
-static const char *stepping_str[] = {
- "U0", "V1", "V2", "Y0"
-};
-
-static void fill_in_pattrs(void)
-{
- struct device *dev;
- struct pattrs *attrs = (struct pattrs *)pattrs_get();
-
- attrs->cpuid = cpuid_eax(1);
- attrs->stepping = (attrs->cpuid & 0x0F) - 1;
- dev = pcidev_on_root(LPC_DEV, LPC_FUNC);
- attrs->revid = pci_read_config8(dev, REVID);
- attrs->microcode_patch = intel_microcode_find();
- attrs->address_bits = cpuid_eax(0x80000008) & 0xff;
- detect_num_cpus(attrs);
-
- if (SHOW_PATTRS) {
- printk(BIOS_DEBUG, "CPUID: %08x\n", attrs->cpuid);
- printk(BIOS_DEBUG, "Cores: %d\n", attrs->num_cpus);
- printk(BIOS_DEBUG, "Stepping: %s\n", (attrs->stepping >= ARRAY_SIZE(stepping_str))
- ? "??" : stepping_str[attrs->stepping]);
- printk(BIOS_DEBUG, "Revision ID: %02x\n", attrs->revid);
- }
-
- fill_in_msr(&attrs->platform_id, IA32_PLATFORM_ID);
- fill_in_msr(&attrs->platform_info, MSR_PLATFORM_INFO);
-}
-
-void broadwell_de_init_pre_device(void)
-{
- fill_in_pattrs();
-}
-
-/*
- * Set DPR region.
- */
-void broadwell_de_set_dpr(const uintptr_t addr, const size_t size)
-{
- struct device *dev;
- uint32_t dpr_reg;
- /*
- * DMA Protected Range can be reserved below TSEG for PCODE patch
- * or TXT/BootGuard related data. Rather than reporting a base address
- * the DPR register reports the TOP of the region, which is the same
- * as TSEG base. The region size is reported in MiB in bits 11:4.
- */
- dev = pcidev_on_root(VTD_DEV, VTD_FUNC);
- dpr_reg = pci_read_config32(dev, IIO_LTDPR);
- if (dpr_reg & DPR_LOCK) {
- printk(BIOS_ERR, "ERROR: HOSTBRIDGE[DPR] is already locked\n");
- return;
- }
-
- dpr_reg &= ~(DPR_ADDR_MASK | DPR_SIZE_MASK);
- dpr_reg |= addr & DPR_ADDR_MASK;
- dpr_reg |= (size >> (20 - DPR_SIZE_SHIFT)) & DPR_SIZE_MASK;
- dpr_reg |= DPR_EPM;
- pci_write_config32(dev, IIO_LTDPR, dpr_reg);
-}
-
-/*
- * Lock DPR register.
- */
-void broadwell_de_lock_dpr(void)
-{
- struct device *dev;
- uint32_t dpr_reg;
- dev = pcidev_on_root(VTD_DEV, VTD_FUNC);
- dpr_reg = pci_read_config32(dev, IIO_LTDPR);
- if (dpr_reg & DPR_LOCK) {
- printk(BIOS_ERR, "ERROR: HOSTBRIDGE[DPR] is already locked\n");
- return;
- }
- dpr_reg |= DPR_LOCK;
- pci_write_config32(dev, IIO_LTDPR, dpr_reg);
-}