/* * This file is part of the coreboot project. * * Copyright (C) 2016 Intel Corp. * (Written by Andrey Petrov for 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; either version 2 of the License, or * (at your option) any later version. */ #include #include #include #include #include #include #include #include void asmlinkage bootblock_c_entry(void) { device_t dev = NB_DEV_ROOT; /* Set PCI Express BAR */ pci_io_write_config32(dev, PCIEXBAR, CONFIG_MMCONF_BASE_ADDRESS | 1); dev = P2SB_DEV; /* BAR and MMIO enable for IOSF, so that GPIOs can be configured */ pci_write_config32(dev, PCI_BASE_ADDRESS_0, CONFIG_IOSF_BASE_ADDRESS); pci_write_config32(dev, PCI_BASE_ADDRESS_1, 0); pci_write_config16(dev, PCI_COMMAND, PCI_COMMAND_MASTER | PCI_COMMAND_MEMORY); /* Call lib/bootblock.c main */ main(); } void platform_prog_run(struct prog *prog) { /* Flush L1D cache to L2 */ msr_t msr = rdmsr(MSR_POWER_MISC); msr.lo |= (1 << 8); wrmsr(MSR_POWER_MISC, msr); }