Angel Pons | 89ab250 | 2020-04-03 01:22:28 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Nicolas Reinecke | b165c4a | 2015-07-04 23:37:06 +0200 | [diff] [blame] | 2 | |
| 3 | #include <stdint.h> |
| 4 | #include <device/pci_ops.h> |
| 5 | #include <southbridge/intel/ibexpeak/pch.h> |
| 6 | #include <drivers/lenovo/hybrid_graphics/hybrid_graphics.h> |
Angel Pons | 95de231 | 2020-02-17 13:08:53 +0100 | [diff] [blame] | 7 | #include <northbridge/intel/ironlake/ironlake.h> |
Nicolas Reinecke | b165c4a | 2015-07-04 23:37:06 +0200 | [diff] [blame] | 8 | |
| 9 | const struct southbridge_usb_port mainboard_usb_ports[] = { |
| 10 | /* Enabled, Current table lookup index, OC map */ |
| 11 | { 1, IF1_557, 0 }, |
| 12 | { 1, IF1_55F, 1 }, |
| 13 | { 1, IF1_74B, 3 }, |
| 14 | { 1, IF1_14B, 3 }, |
| 15 | { 1, IF1_14B, 3 }, |
| 16 | { 1, IF1_74B, 3 }, |
| 17 | { 1, IF1_74B, 3 }, |
| 18 | { 1, IF1_74B, 3 }, |
| 19 | { 1, IF1_55F, 4 }, |
| 20 | { 1, IF1_55F, 5 }, |
| 21 | { 1, IF1_74B, 7 }, |
| 22 | { 1, IF1_74B, 7 }, |
| 23 | { 1, IF1_557, 7 }, |
| 24 | { 1, IF1_55F, 7 }, |
| 25 | }; |
| 26 | |
| 27 | static void hybrid_graphics_init(void) |
| 28 | { |
| 29 | bool peg, igd; |
| 30 | u32 reg32; |
| 31 | |
| 32 | early_hybrid_graphics(&igd, &peg); |
| 33 | |
| 34 | /* Hide disabled devices */ |
Angel Pons | 16fe1e0 | 2020-07-22 16:12:33 +0200 | [diff] [blame^] | 35 | reg32 = pci_read_config32(PCI_DEV(0, 0, 0), DEVEN); |
Nicolas Reinecke | b165c4a | 2015-07-04 23:37:06 +0200 | [diff] [blame] | 36 | reg32 &= ~(DEVEN_PEG10 | DEVEN_IGD); |
| 37 | |
| 38 | if (peg) |
| 39 | reg32 |= DEVEN_PEG10; |
| 40 | |
| 41 | if (igd) |
| 42 | reg32 |= DEVEN_IGD; |
| 43 | else |
| 44 | /* Disable IGD VGA decode, no GTT or GFX stolen */ |
Angel Pons | 16fe1e0 | 2020-07-22 16:12:33 +0200 | [diff] [blame^] | 45 | pci_write_config16(PCI_DEV(0, 0, 0), GGC, 2); |
Nicolas Reinecke | b165c4a | 2015-07-04 23:37:06 +0200 | [diff] [blame] | 46 | |
Angel Pons | 16fe1e0 | 2020-07-22 16:12:33 +0200 | [diff] [blame^] | 47 | pci_write_config32(PCI_DEV(0, 0, 0), DEVEN, reg32); |
Nicolas Reinecke | b165c4a | 2015-07-04 23:37:06 +0200 | [diff] [blame] | 48 | } |
| 49 | |
| 50 | void mainboard_pre_raminit(void) |
| 51 | { |
| 52 | hybrid_graphics_init(); |
| 53 | } |
| 54 | |
| 55 | void mainboard_get_spd_map(u8 *spd_addrmap) |
| 56 | { |
| 57 | spd_addrmap[0] = 0x50; |
Patrick Rudolph | 07b402b | 2019-11-21 09:30:21 +0100 | [diff] [blame] | 58 | spd_addrmap[2] = 0x51; |
Nicolas Reinecke | b165c4a | 2015-07-04 23:37:06 +0200 | [diff] [blame] | 59 | } |