diff options
author | Matt DeVillier <matt.devillier@gmail.com> | 2017-04-16 01:42:44 -0500 |
---|---|---|
committer | Martin Roth <martinroth@google.com> | 2017-04-24 19:10:09 +0200 |
commit | 6955b9c5b2df5a12f93fb10457330df54a186a17 (patch) | |
tree | 978ef9f9b969b2f2ffcfaa3dc550d0f4cfa416ba | |
parent | ee049fa8027745d8bd90e7abe8aa8a9646d390a8 (diff) | |
download | coreboot-6955b9c5b2df5a12f93fb10457330df54a186a17.tar.xz |
northbridge/haswell: clean up native graphics init code
Clean up NGI code now that libgfxinit has replaced old C code:
- replace #if preprocessor guards with if (IS_ENABLED(...))
- don't guard variable declarations
- remove code that would only be executed for old NGI / isn't
used by libgfxinit
Test: boot google/wolf with VBIOS, NGI, and UEFI/GOP video init,
observe payload and pre-OS graphics display functional.
Change-Id: I96e74f49ea70e09cbac6f8af561de3e18fa7d260
Signed-off-by: Matt DeVillier <matt.devillier@gmail.com>
Reviewed-on: https://review.coreboot.org/19327
Tested-by: build bot (Jenkins)
Reviewed-by: Nico Huber <nico.h@gmx.de>
Reviewed-by: Philippe Mathieu-Daudé <philippe.mathieu.daude@gmail.com>
-rw-r--r-- | src/northbridge/intel/haswell/gma.c | 55 |
1 files changed, 19 insertions, 36 deletions
diff --git a/src/northbridge/intel/haswell/gma.c b/src/northbridge/intel/haswell/gma.c index 31e3cb68d9..9096d8cf9a 100644 --- a/src/northbridge/intel/haswell/gma.c +++ b/src/northbridge/intel/haswell/gma.c @@ -216,13 +216,14 @@ static void power_well_enable(void) { gtt_write(HSW_PWR_WELL_CTL1, HSW_PWR_WELL_ENABLE); gtt_poll(HSW_PWR_WELL_CTL1, HSW_PWR_WELL_STATE, HSW_PWR_WELL_STATE); -#if CONFIG_MAINBOARD_DO_NATIVE_VGA_INIT + /* In the native graphics case, we've got about 20 ms. * after we power up the the AUX channel until we can talk to it. * So get that going right now. We can't turn on the panel, yet, just VDD. */ - gtt_write(PCH_PP_CONTROL, PCH_PP_UNLOCK| EDP_FORCE_VDD | PANEL_POWER_RESET); -#endif + if (IS_ENABLED(CONFIG_MAINBOARD_DO_NATIVE_VGA_INIT)) { + gtt_write(PCH_PP_CONTROL, PCH_PP_UNLOCK| EDP_FORCE_VDD | PANEL_POWER_RESET); + } } static void gma_pm_init_pre_vbios(struct device *dev) @@ -422,13 +423,15 @@ static void gma_pm_init_post_vbios(struct device *dev) static void gma_func0_init(struct device *dev) { -#if CONFIG_MAINBOARD_DO_NATIVE_VGA_INIT - struct northbridge_intel_haswell_config *conf = dev->chip_info; - struct intel_dp dp; -#endif - int lightup_ok = 0; u32 reg32; + u64 physbase; + const struct resource *const linearfb_res = + find_resource(dev, PCI_BASE_ADDRESS_2); + + if (!linearfb_res || !linearfb_res->base) + return; + /* IGD needs to be Bus Master */ reg32 = pci_read_config32(dev, PCI_COMMAND); reg32 |= PCI_COMMAND_MASTER | PCI_COMMAND_MEMORY | PCI_COMMAND_IO; @@ -437,44 +440,24 @@ static void gma_func0_init(struct device *dev) /* Init graphics power management */ gma_pm_init_pre_vbios(dev); - /* Post VBIOS init */ + /* Pre panel init */ gma_setup_panel(dev); -#if CONFIG_MAINBOARD_DO_NATIVE_VGA_INIT - printk(BIOS_SPEW, "NATIVE graphics, run native enable\n"); - /* Default set to 1 since it might be required for - stuff like seabios */ - unsigned int init_fb = 1; - - /* the BAR for graphics space is a well known number for - * sandy and ivy. And the resource code renumbers it. - * So it's almost like having two hardcodes. - */ - dp.graphics = (void *)((uintptr_t)dev->resource_list[1].base); - dp.physbase = pci_read_config32(dev, 0x5c) & ~0xf; - dp.panel_power_down_delay = conf->gpu_panel_power_down_delay; - dp.panel_power_up_delay = conf->gpu_panel_power_up_delay; - dp.panel_power_cycle_delay = conf->gpu_panel_power_cycle_delay; - -#if IS_ENABLED(CONFIG_CHROMEOS) - init_fb = display_init_required(); -#endif - if (IS_ENABLED(CONFIG_MAINBOARD_USE_LIBGFXINIT)) { - gma_gfxinit(gtt_res->base, (u32)dp.graphics, - dp.physbase, &lightup_ok); - } else { - lightup_ok = panel_lightup(&dp, init_fb); + if (IS_ENABLED(CONFIG_MAINBOARD_DO_NATIVE_VGA_INIT)) { + printk(BIOS_SPEW, "NATIVE graphics, run native enable\n"); + physbase = pci_read_config32(dev, 0x5c) & ~0xf; + gma_gfxinit(gtt_res->base, linearfb_res->base, + physbase, &lightup_ok); + gfx_set_init_done(1); } - gfx_set_init_done(1); -#endif if (! lightup_ok) { printk(BIOS_SPEW, "FUI did not run; using VBIOS\n"); mdelay(CONFIG_PRE_GRAPHICS_DELAY); pci_dev_init(dev); } - /* Post VBIOS init */ + /* Post panel init */ gma_pm_init_post_vbios(dev); } |