Angel Pons | 4b42983 | 2020-04-02 23:48:50 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Patrick Georgi | 2efc880 | 2012-11-06 11:03:53 +0100 | [diff] [blame] | 2 | |
Kyösti Mälkki | f1b58b7 | 2019-03-01 13:43:02 +0200 | [diff] [blame] | 3 | #include <device/pci_ops.h> |
Angel Pons | 2f30e8c | 2020-09-16 13:29:21 +0200 | [diff] [blame] | 4 | #include <southbridge/intel/i82801ix/i82801ix.h> |
Patrick Georgi | 2efc880 | 2012-11-06 11:03:53 +0100 | [diff] [blame] | 5 | #include "gm45.h" |
| 6 | |
| 7 | void gm45_early_init(void) |
| 8 | { |
Furquan Shaikh | 25f75b2 | 2016-08-29 22:51:41 -0700 | [diff] [blame] | 9 | const pci_devfn_t d0f0 = PCI_DEV(0, 0, 0); |
Patrick Georgi | 2efc880 | 2012-11-06 11:03:53 +0100 | [diff] [blame] | 10 | |
Patrick Georgi | 2efc880 | 2012-11-06 11:03:53 +0100 | [diff] [blame] | 11 | /* Setup MCHBAR. */ |
Angel Pons | f462b3d | 2021-01-20 00:36:31 +0100 | [diff] [blame] | 12 | pci_write_config32(d0f0, D0F0_MCHBAR_LO, CONFIG_FIXED_MCHBAR_MMIO_BASE | 1); |
Patrick Georgi | 2efc880 | 2012-11-06 11:03:53 +0100 | [diff] [blame] | 13 | |
| 14 | /* Setup DMIBAR. */ |
Angel Pons | f462b3d | 2021-01-20 00:36:31 +0100 | [diff] [blame] | 15 | pci_write_config32(d0f0, D0F0_DMIBAR_LO, CONFIG_FIXED_DMIBAR_MMIO_BASE | 1); |
Patrick Georgi | 2efc880 | 2012-11-06 11:03:53 +0100 | [diff] [blame] | 16 | |
| 17 | /* Setup EPBAR. */ |
Angel Pons | f462b3d | 2021-01-20 00:36:31 +0100 | [diff] [blame] | 18 | pci_write_config32(d0f0, D0F0_EPBAR_LO, CONFIG_FIXED_EPBAR_MMIO_BASE | 1); |
Patrick Georgi | 2efc880 | 2012-11-06 11:03:53 +0100 | [diff] [blame] | 19 | |
| 20 | pci_write_config32(d0f0, D0F0_PMBASE, DEFAULT_PMBASE | 1); |
| 21 | |
| 22 | /* Set C0000-FFFFF to access RAM on both reads and writes */ |
| 23 | pci_write_config8(d0f0, D0F0_PAM(0), 0x30); |
| 24 | pci_write_config8(d0f0, D0F0_PAM(1), 0x33); |
| 25 | pci_write_config8(d0f0, D0F0_PAM(2), 0x33); |
| 26 | pci_write_config8(d0f0, D0F0_PAM(3), 0x33); |
| 27 | pci_write_config8(d0f0, D0F0_PAM(4), 0x33); |
| 28 | pci_write_config8(d0f0, D0F0_PAM(5), 0x33); |
| 29 | pci_write_config8(d0f0, D0F0_PAM(6), 0x33); |
| 30 | } |