igd.asl rewrite
Old igd.asl had inconsistent addresses (between _DOD and actual device) and ghost devices. Any of those is enough to make brightness on windows fail and make igd.asl out-of-ACPI-spec. Also old code favoured ridiculous copying of the same thing 6 times per chipset. Leave only hooking up and chipset-specific part in chipset directory. Move NVS handling and ACPI-spec parts to a common file. Change-Id: I556769e5e28b83e7465e3db689e26c8c0ab44757 Signed-off-by: Vladimir Serbinenko <phcoder@gmail.com> Reviewed-on: http://review.coreboot.org/7472 Tested-by: build bot (Jenkins) Reviewed-by: Edward O'Callaghan <edward.ocallaghan@koparo.com> Reviewed-by: Timothy Pearson <tpearson@raptorengineeringinc.com>
This commit is contained in:
@@ -34,6 +34,7 @@
|
||||
#include <arch/acpigen.h>
|
||||
#include <cbmem.h>
|
||||
#include <string.h>
|
||||
#include <drivers/intel/gma/i915.h>
|
||||
#include "nvs.h"
|
||||
|
||||
#define NMI_OFF 0
|
||||
@@ -617,12 +618,18 @@ static void southbridge_inject_dsdt(void)
|
||||
global_nvs_t *gnvs = cbmem_add (CBMEM_ID_ACPI_GNVS, sizeof (*gnvs));
|
||||
|
||||
if (gnvs) {
|
||||
const struct i915_gpu_controller_info *gfx = intel_gma_get_controller_info();
|
||||
|
||||
memset(gnvs, 0, sizeof(*gnvs));
|
||||
|
||||
gnvs->apic = 1;
|
||||
gnvs->mpen = 1; /* Enable Multi Processing */
|
||||
|
||||
acpi_create_gnvs(gnvs);
|
||||
|
||||
gnvs->ndid = gfx->ndid;
|
||||
memcpy(gnvs->did, gfx->did, sizeof(gnvs->did));
|
||||
|
||||
/* And tell SMI about it */
|
||||
smm_setup_structures(gnvs, NULL, NULL);
|
||||
|
||||
|
Reference in New Issue
Block a user