mirror of
https://github.com/fail0verflow/switch-coreboot.git
synced 2025-05-04 01:39:18 -04:00
BUG=none
BRANCH=none
TEST=none
Change-Id: Id20a4c5f8c0f52dc19a52d0220f9b3092b7d491f
Signed-off-by: Patrick Georgi <pgeorgi@chromium.org>
Original-Commit-Id: 70a8e34853
Original-Change-Id: Ic2dd40e73d4a4c091c5ce1f49bbf9ab4d013d7af
Original-Signed-off-by: Arthur Heymans <arthur@aheymans.xyz>
Original-Reviewed-on: https://review.coreboot.org/18704
Original-Tested-by: build bot (Jenkins)
Original-Reviewed-by: Martin Roth <martinroth@google.com>
Reviewed-on: https://chromium-review.googlesource.com/458637
24 lines
853 B
C
24 lines
853 B
C
#include <arch/io.h>
|
|
|
|
/* Just re-define this instead of including i945.h. It blows up romcc. */
|
|
#define PCIEXBAR 0x48
|
|
|
|
static void bootblock_northbridge_init(void)
|
|
{
|
|
uint32_t reg;
|
|
|
|
/*
|
|
* The "io" variant of the config access is explicitly used to
|
|
* setup the PCIEXBAR because CONFIG_MMCONF_SUPPORT is set to
|
|
* to true. That way all subsequent non-explicit config accesses use
|
|
* MCFG. This code also assumes that bootblock_northbridge_init() is
|
|
* the first thing called in the non-asm boot block code. The final
|
|
* assumption is that no assembly code is using the
|
|
* CONFIG_MMCONF_SUPPORT option to do PCI config acceses.
|
|
*
|
|
* The PCIEXBAR is assumed to live in the memory mapped IO space under
|
|
* 4GiB.
|
|
*/
|
|
reg = CONFIG_MMCONF_BASE_ADDRESS | 4 | 1; /* 64MiB - 0-63 buses. */
|
|
pci_io_write_config32(PCI_DEV(0, 0, 0), PCIEXBAR, reg);
|
|
}
|