soc/intel/skylake: Use common opregion implementation

Enable SOC_INTEL_COMMON_GFX_OPREGION for all FSP versions.
Allows to get rid of opregion.c, as it's no longer needed.

Change-Id: I39190488e12917a09dbf7ee3947a33940ebc290b
Signed-off-by: Patrick Rudolph <siro@das-labor.org>
Reviewed-on: https://review.coreboot.org/20222
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Matt DeVillier <matt.devillier@gmail.com>
This commit is contained in:
Patrick Rudolph 2017-06-15 09:22:06 +02:00
parent 43be77db31
commit c1055ab07a
5 changed files with 2 additions and 55 deletions

View File

@ -83,6 +83,7 @@ config CPU_SPECIFIC_OPTIONS
select UDELAY_TSC select UDELAY_TSC
select ACPI_NHLT select ACPI_NHLT
select HAVE_FSP_GOP select HAVE_FSP_GOP
select SOC_INTEL_COMMON_GFX_OPREGION
config MAINBOARD_USES_FSP2_0 config MAINBOARD_USES_FSP2_0
bool bool
@ -93,7 +94,6 @@ config USE_FSP2_0_DRIVER
depends on MAINBOARD_USES_FSP2_0 depends on MAINBOARD_USES_FSP2_0
select PLATFORM_USES_FSP2_0 select PLATFORM_USES_FSP2_0
select ADD_VBT_DATA_FILE if RUN_FSP_GOP select ADD_VBT_DATA_FILE if RUN_FSP_GOP
select SOC_INTEL_COMMON_GFX_OPREGION
select POSTCAR_CONSOLE select POSTCAR_CONSOLE
select POSTCAR_STAGE select POSTCAR_STAGE

View File

@ -56,7 +56,6 @@ ramstage-y += irq.c
ramstage-y += lpc.c ramstage-y += lpc.c
ramstage-y += me.c ramstage-y += me.c
ramstage-y += memmap.c ramstage-y += memmap.c
ramstage-$(CONFIG_PLATFORM_USES_FSP1_1) += opregion.c
ramstage-y += pch.c ramstage-y += pch.c
ramstage-y += pei_data.c ramstage-y += pei_data.c
ramstage-y += pmc.c ramstage-y += pmc.c

View File

@ -24,7 +24,7 @@
#include <device/pci.h> #include <device/pci.h>
#include <device/pci_ids.h> #include <device/pci_ids.h>
#include <drivers/intel/gma/i915_reg.h> #include <drivers/intel/gma/i915_reg.h>
#include <fsp/util.h> #include <soc/intel/common/opregion.h>
#include <soc/acpi.h> #include <soc/acpi.h>
#include <soc/cpu.h> #include <soc/cpu.h>
#include <soc/pm.h> #include <soc/pm.h>

View File

@ -19,7 +19,6 @@
#include <chip.h> #include <chip.h>
#include <device/device.h> #include <device/device.h>
#include <fsp/gop.h>
#include <fsp/ramstage.h> #include <fsp/ramstage.h>
#include <fsp/soc_binding.h> #include <fsp/soc_binding.h>
@ -31,7 +30,6 @@ void pch_enable_dev(device_t dev);
void soc_init_pre_device(void *chip_info); void soc_init_pre_device(void *chip_info);
void soc_fsp_load(void); void soc_fsp_load(void);
const char *soc_acpi_name(struct device *dev); const char *soc_acpi_name(struct device *dev);
int init_igd_opregion(igd_opregion_t *igd_opregion);
extern struct pci_operations soc_pci_ops; extern struct pci_operations soc_pci_ops;
/* Get igd framebuffer bar */ /* Get igd framebuffer bar */

View File

@ -1,50 +0,0 @@
/*
* This file is part of the coreboot project.
*
* Copyright (C) 2016 Intel Corporation.
*
* 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; version 2 of the License.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
#include <console/console.h>
#include <soc/ramstage.h>
#include <fsp/gop.h>
#include <stdlib.h>
#include <string.h>
enum cb_err init_igd_opregion(igd_opregion_t *opregion)
{
const optionrom_vbt_t *vbt;
uint32_t vbt_len;
memset(opregion, 0, sizeof(igd_opregion_t));
/* Read VBT table from flash */
vbt = fsp_get_vbt(&vbt_len);
if (!vbt)
die("vbt data not found");
memcpy(&opregion->header.signature, IGD_OPREGION_SIGNATURE,
sizeof(IGD_OPREGION_SIGNATURE) - 1);
memcpy(opregion->header.vbios_version, vbt->coreblock_biosbuild,
sizeof(u32));
memcpy(opregion->vbt.gvd1, vbt, vbt->hdr_vbt_size <
sizeof(opregion->vbt.gvd1) ? vbt->hdr_vbt_size :
sizeof(opregion->vbt.gvd1));
/* Size, in KB, of the entire OpRegion structure (including header)*/
opregion->header.size = sizeof(igd_opregion_t) / KiB;
opregion->header.version = IGD_OPREGION_VERSION;
/* We just assume we're mobile for now */
opregion->header.mailboxes = MAILBOXES_MOBILE;
return CB_SUCCESS;
}