skylake: Use COMMON_FADT
Remove the FADT from the individual mainboards and select and use COMMON_FADT in the SOC instead. Set the ACPI revision to 5. Change-Id: Ieb87c467c71bc125f80c7d941486c2fbc9cd4020 Signed-off-by: Duncan Laurie <dlaurie@chromium.org> Reviewed-on: https://review.coreboot.org/17138 Tested-by: build bot (Jenkins) Reviewed-by: Furquan Shaikh <furquan@google.com>
This commit is contained in:
		| @@ -1,47 +0,0 @@ | |||||||
| /* |  | ||||||
|  * This file is part of the coreboot project. |  | ||||||
|  * |  | ||||||
|  * Copyright (C) 2007-2009 coresystems GmbH |  | ||||||
|  * Copyright (C) 2015 Google Inc. |  | ||||||
|  * Copyright (C) 2015 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 <string.h> |  | ||||||
| #include <soc/acpi.h> |  | ||||||
|  |  | ||||||
| void acpi_create_fadt(acpi_fadt_t *fadt, acpi_facs_t *facs, void *dsdt) |  | ||||||
| { |  | ||||||
| 	acpi_header_t *header = &(fadt->header); |  | ||||||
|  |  | ||||||
| 	memset((void *) fadt, 0, sizeof(acpi_fadt_t)); |  | ||||||
| 	memcpy(header->signature, "FACP", 4); |  | ||||||
| 	header->length = sizeof(acpi_fadt_t); |  | ||||||
| 	header->revision = 5; |  | ||||||
| 	memcpy(header->oem_id, OEM_ID, 6); |  | ||||||
| 	memcpy(header->oem_table_id, ACPI_TABLE_CREATOR, 8); |  | ||||||
| 	memcpy(header->asl_compiler_id, ASLC, 4); |  | ||||||
| 	header->asl_compiler_revision = 1; |  | ||||||
|  |  | ||||||
| 	fadt->firmware_ctrl = (unsigned long) facs; |  | ||||||
| 	fadt->dsdt = (unsigned long) dsdt; |  | ||||||
| 	fadt->model = 1; |  | ||||||
| 	fadt->preferred_pm_profile = PM_MOBILE; |  | ||||||
|  |  | ||||||
| 	fadt->x_firmware_ctl_l = (unsigned long)facs; |  | ||||||
| 	fadt->x_firmware_ctl_h = 0; |  | ||||||
| 	fadt->x_dsdt_l = (unsigned long)dsdt; |  | ||||||
| 	fadt->x_dsdt_h = 0; |  | ||||||
|  |  | ||||||
| 	acpi_fill_in_fadt(fadt); |  | ||||||
|  |  | ||||||
| 	header->checksum = acpi_checksum((void *) fadt, header->length); |  | ||||||
| } |  | ||||||
| @@ -1,47 +0,0 @@ | |||||||
| /* |  | ||||||
|  * This file is part of the coreboot project. |  | ||||||
|  * |  | ||||||
|  * Copyright (C) 2007-2009 coresystems GmbH |  | ||||||
|  * Copyright (C) 2015 Google Inc. |  | ||||||
|  * Copyright (C) 2015 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 <string.h> |  | ||||||
| #include <soc/acpi.h> |  | ||||||
|  |  | ||||||
| void acpi_create_fadt(acpi_fadt_t *fadt, acpi_facs_t *facs, void *dsdt) |  | ||||||
| { |  | ||||||
| 	acpi_header_t *header = &(fadt->header); |  | ||||||
|  |  | ||||||
| 	memset((void *) fadt, 0, sizeof(acpi_fadt_t)); |  | ||||||
| 	memcpy(header->signature, "FACP", 4); |  | ||||||
| 	header->length = sizeof(acpi_fadt_t); |  | ||||||
| 	header->revision = 5; |  | ||||||
| 	memcpy(header->oem_id, OEM_ID, 6); |  | ||||||
| 	memcpy(header->oem_table_id, ACPI_TABLE_CREATOR, 8); |  | ||||||
| 	memcpy(header->asl_compiler_id, ASLC, 4); |  | ||||||
| 	header->asl_compiler_revision = 1; |  | ||||||
|  |  | ||||||
| 	fadt->firmware_ctrl = (unsigned long) facs; |  | ||||||
| 	fadt->dsdt = (unsigned long) dsdt; |  | ||||||
| 	fadt->model = 1; |  | ||||||
| 	fadt->preferred_pm_profile = PM_MOBILE; |  | ||||||
|  |  | ||||||
| 	fadt->x_firmware_ctl_l = (unsigned long)facs; |  | ||||||
| 	fadt->x_firmware_ctl_h = 0; |  | ||||||
| 	fadt->x_dsdt_l = (unsigned long)dsdt; |  | ||||||
| 	fadt->x_dsdt_h = 0; |  | ||||||
|  |  | ||||||
| 	acpi_fill_in_fadt(fadt); |  | ||||||
|  |  | ||||||
| 	header->checksum = acpi_checksum((void *) fadt, header->length); |  | ||||||
| } |  | ||||||
| @@ -1,47 +0,0 @@ | |||||||
| /* |  | ||||||
|  * This file is part of the coreboot project. |  | ||||||
|  * |  | ||||||
|  * Copyright (C) 2007-2009 coresystems GmbH |  | ||||||
|  * Copyright (C) 2014 Google Inc. |  | ||||||
|  * Copyright (C) 2015 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 <string.h> |  | ||||||
| #include <soc/acpi.h> |  | ||||||
|  |  | ||||||
| void acpi_create_fadt(acpi_fadt_t *fadt, acpi_facs_t *facs, void *dsdt) |  | ||||||
| { |  | ||||||
| 	acpi_header_t *header = &(fadt->header); |  | ||||||
|  |  | ||||||
| 	memset((void *) fadt, 0, sizeof(acpi_fadt_t)); |  | ||||||
| 	memcpy(header->signature, "FACP", 4); |  | ||||||
| 	header->length = sizeof(acpi_fadt_t); |  | ||||||
| 	header->revision = 5; |  | ||||||
| 	memcpy(header->oem_id, OEM_ID, 6); |  | ||||||
| 	memcpy(header->oem_table_id, ACPI_TABLE_CREATOR, 8); |  | ||||||
| 	memcpy(header->asl_compiler_id, ASLC, 4); |  | ||||||
| 	header->asl_compiler_revision = 1; |  | ||||||
|  |  | ||||||
| 	fadt->firmware_ctrl = (unsigned long) facs; |  | ||||||
| 	fadt->dsdt = (unsigned long) dsdt; |  | ||||||
| 	fadt->model = 1; |  | ||||||
| 	fadt->preferred_pm_profile = PM_MOBILE; |  | ||||||
|  |  | ||||||
| 	fadt->x_firmware_ctl_l = (unsigned long)facs; |  | ||||||
| 	fadt->x_firmware_ctl_h = 0; |  | ||||||
| 	fadt->x_dsdt_l = (unsigned long)dsdt; |  | ||||||
| 	fadt->x_dsdt_h = 0; |  | ||||||
|  |  | ||||||
| 	acpi_fill_in_fadt(fadt); |  | ||||||
|  |  | ||||||
| 	header->checksum = acpi_checksum((void *) fadt, header->length); |  | ||||||
| } |  | ||||||
| @@ -1,47 +0,0 @@ | |||||||
| /* |  | ||||||
|  * This file is part of the coreboot project. |  | ||||||
|  * |  | ||||||
|  * Copyright (C) 2007-2009 coresystems GmbH |  | ||||||
|  * Copyright (C) 2014 Google Inc. |  | ||||||
|  * 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 <string.h> |  | ||||||
| #include <soc/acpi.h> |  | ||||||
|  |  | ||||||
| void acpi_create_fadt(acpi_fadt_t *fadt, acpi_facs_t *facs, void *dsdt) |  | ||||||
| { |  | ||||||
| 	acpi_header_t *header = &(fadt->header); |  | ||||||
|  |  | ||||||
| 	memset((void *) fadt, 0, sizeof(acpi_fadt_t)); |  | ||||||
| 	memcpy(header->signature, "FACP", 4); |  | ||||||
| 	header->length = sizeof(acpi_fadt_t); |  | ||||||
| 	header->revision = 5; |  | ||||||
| 	memcpy(header->oem_id, OEM_ID, 6); |  | ||||||
| 	memcpy(header->oem_table_id, ACPI_TABLE_CREATOR, 8); |  | ||||||
| 	memcpy(header->asl_compiler_id, ASLC, 4); |  | ||||||
| 	header->asl_compiler_revision = 1; |  | ||||||
|  |  | ||||||
| 	fadt->firmware_ctrl = (unsigned long) facs; |  | ||||||
| 	fadt->dsdt = (unsigned long) dsdt; |  | ||||||
| 	fadt->model = 1; |  | ||||||
| 	fadt->preferred_pm_profile = PM_MOBILE; |  | ||||||
|  |  | ||||||
| 	fadt->x_firmware_ctl_l = (unsigned long)facs; |  | ||||||
| 	fadt->x_firmware_ctl_h = 0; |  | ||||||
| 	fadt->x_dsdt_l = (unsigned long)dsdt; |  | ||||||
| 	fadt->x_dsdt_h = 0; |  | ||||||
|  |  | ||||||
| 	acpi_fill_in_fadt(fadt); |  | ||||||
|  |  | ||||||
| 	header->checksum = acpi_checksum((void *) fadt, header->length); |  | ||||||
| } |  | ||||||
| @@ -1,47 +0,0 @@ | |||||||
| /* |  | ||||||
|  * This file is part of the coreboot project. |  | ||||||
|  * |  | ||||||
|  * Copyright (C) 2007-2009 coresystems GmbH |  | ||||||
|  * Copyright (C) 2014 Google Inc. |  | ||||||
|  * Copyright (C) 2015 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 <string.h> |  | ||||||
| #include <soc/acpi.h> |  | ||||||
|  |  | ||||||
| void acpi_create_fadt(acpi_fadt_t *fadt, acpi_facs_t *facs, void *dsdt) |  | ||||||
| { |  | ||||||
| 	acpi_header_t *header = &(fadt->header); |  | ||||||
|  |  | ||||||
| 	memset((void *) fadt, 0, sizeof(acpi_fadt_t)); |  | ||||||
| 	memcpy(header->signature, "FACP", 4); |  | ||||||
| 	header->length = sizeof(acpi_fadt_t); |  | ||||||
| 	header->revision = 5; |  | ||||||
| 	memcpy(header->oem_id, OEM_ID, 6); |  | ||||||
| 	memcpy(header->oem_table_id, ACPI_TABLE_CREATOR, 8); |  | ||||||
| 	memcpy(header->asl_compiler_id, ASLC, 4); |  | ||||||
| 	header->asl_compiler_revision = 1; |  | ||||||
|  |  | ||||||
| 	fadt->firmware_ctrl = (unsigned long) facs; |  | ||||||
| 	fadt->dsdt = (unsigned long) dsdt; |  | ||||||
| 	fadt->model = 1; |  | ||||||
| 	fadt->preferred_pm_profile = PM_MOBILE; |  | ||||||
|  |  | ||||||
| 	fadt->x_firmware_ctl_l = (unsigned long)facs; |  | ||||||
| 	fadt->x_firmware_ctl_h = 0; |  | ||||||
| 	fadt->x_dsdt_l = (unsigned long)dsdt; |  | ||||||
| 	fadt->x_dsdt_h = 0; |  | ||||||
|  |  | ||||||
| 	acpi_fill_in_fadt(fadt); |  | ||||||
|  |  | ||||||
| 	header->checksum = acpi_checksum((void *) fadt, header->length); |  | ||||||
| } |  | ||||||
| @@ -19,6 +19,7 @@ config CPU_SPECIFIC_OPTIONS | |||||||
| 	select CACHE_RELOCATED_RAMSTAGE_OUTSIDE_CBMEM if RELOCATABLE_RAMSTAGE | 	select CACHE_RELOCATED_RAMSTAGE_OUTSIDE_CBMEM if RELOCATABLE_RAMSTAGE | ||||||
| 	select C_ENVIRONMENT_BOOTBLOCK | 	select C_ENVIRONMENT_BOOTBLOCK | ||||||
| 	select COLLECT_TIMESTAMPS | 	select COLLECT_TIMESTAMPS | ||||||
|  | 	select COMMON_FADT | ||||||
| 	select CPU_INTEL_FIRMWARE_INTERFACE_TABLE | 	select CPU_INTEL_FIRMWARE_INTERFACE_TABLE | ||||||
| 	select GENERIC_GPIO_LIB | 	select GENERIC_GPIO_LIB | ||||||
| 	select HAVE_HARD_RESET | 	select HAVE_HARD_RESET | ||||||
|   | |||||||
| @@ -223,12 +223,15 @@ unsigned long acpi_fill_madt(unsigned long current) | |||||||
| 	return acpi_madt_irq_overrides(current); | 	return acpi_madt_irq_overrides(current); | ||||||
| } | } | ||||||
|  |  | ||||||
| void acpi_fill_in_fadt(acpi_fadt_t *fadt) | void acpi_fill_fadt(acpi_fadt_t *fadt) | ||||||
| { | { | ||||||
| 	const uint16_t pmbase = ACPI_BASE_ADDRESS; | 	const uint16_t pmbase = ACPI_BASE_ADDRESS; | ||||||
| 	const struct device *dev = dev_find_slot(0, PCH_DEVFN_LPC); | 	const struct device *dev = dev_find_slot(0, PCH_DEVFN_LPC); | ||||||
| 	config_t *config = dev->chip_info; | 	config_t *config = dev->chip_info; | ||||||
|  |  | ||||||
|  | 	/* Use ACPI 5.0 revision */ | ||||||
|  | 	fadt->header.revision = ACPI_FADT_REV_ACPI_5_0; | ||||||
|  |  | ||||||
| 	fadt->sci_int = acpi_sci_irq(); | 	fadt->sci_int = acpi_sci_irq(); | ||||||
| 	fadt->smi_cmd = APM_CNT; | 	fadt->smi_cmd = APM_CNT; | ||||||
| 	fadt->acpi_enable = APM_CNT_ACPI_ENABLE; | 	fadt->acpi_enable = APM_CNT_ACPI_ENABLE; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user