src: Make HAVE_CF9_RESET set the FADT reset register
All supported x86 chips select HAVE_CF9_RESET, and also use 0xcf9 as reset register in FADT. How unsurprising. We might as well use that information to automatically fill in the FADT accordingly. So, do it. To avoid having x86-specific code under arch-agnostic `acpi/`, create a new optional `arch_fill_fadt` function, and override it for x86 systems. Tested on Asus P8Z77-V LX2 with Linux 5.7.6 and Windows 10 at the end of the patch train, both operating systems are able to boot successfully. Change-Id: Ib436b04aafd66c3ddfa205b870c1e95afb3e846d Signed-off-by: Angel Pons <th3fanbus@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/43389 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Patrick Rudolph <siro@das-labor.org> Reviewed-by: Frans Hendriks <fhendriks@eltan.com>
This commit is contained in:
parent
3eb8dbaee2
commit
79572e4f32
@ -1219,6 +1219,7 @@ void acpi_write_bert(acpi_bert_t *bert, uintptr_t region, size_t length)
|
|||||||
header->checksum = acpi_checksum((void *)bert, header->length);
|
header->checksum = acpi_checksum((void *)bert, header->length);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
__weak void arch_fill_fadt(acpi_fadt_t *fadt) { }
|
||||||
__weak void soc_fill_fadt(acpi_fadt_t *fadt) { }
|
__weak void soc_fill_fadt(acpi_fadt_t *fadt) { }
|
||||||
__weak void mainboard_fill_fadt(acpi_fadt_t *fadt) { }
|
__weak void mainboard_fill_fadt(acpi_fadt_t *fadt) { }
|
||||||
|
|
||||||
@ -1259,6 +1260,8 @@ void acpi_create_fadt(acpi_fadt_t *fadt, acpi_facs_t *facs, void *dsdt)
|
|||||||
else
|
else
|
||||||
fadt->preferred_pm_profile = PM_DESKTOP;
|
fadt->preferred_pm_profile = PM_DESKTOP;
|
||||||
|
|
||||||
|
arch_fill_fadt(fadt);
|
||||||
|
|
||||||
acpi_fill_fadt(fadt);
|
acpi_fill_fadt(fadt);
|
||||||
|
|
||||||
soc_fill_fadt(fadt);
|
soc_fill_fadt(fadt);
|
||||||
|
@ -235,6 +235,7 @@ $(CONFIG_CBFS_PREFIX)/postcar-compression := none
|
|||||||
|
|
||||||
ifeq ($(CONFIG_ARCH_RAMSTAGE_X86_32)$(CONFIG_ARCH_RAMSTAGE_X86_64),y)
|
ifeq ($(CONFIG_ARCH_RAMSTAGE_X86_32)$(CONFIG_ARCH_RAMSTAGE_X86_64),y)
|
||||||
|
|
||||||
|
ramstage-y += acpi.c
|
||||||
ramstage-$(CONFIG_HAVE_ACPI_RESUME) += acpi_s3.c
|
ramstage-$(CONFIG_HAVE_ACPI_RESUME) += acpi_s3.c
|
||||||
ramstage-$(CONFIG_ACPI_BERT) += acpi_bert_storage.c
|
ramstage-$(CONFIG_ACPI_BERT) += acpi_bert_storage.c
|
||||||
ramstage-y += boot.c
|
ramstage-y += boot.c
|
||||||
|
20
src/arch/x86/acpi.c
Normal file
20
src/arch/x86/acpi.c
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
|
|
||||||
|
#include <acpi/acpi.h>
|
||||||
|
#include <cf9_reset.h>
|
||||||
|
|
||||||
|
void arch_fill_fadt(acpi_fadt_t *fadt)
|
||||||
|
{
|
||||||
|
if (CONFIG(HAVE_CF9_RESET)) {
|
||||||
|
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
||||||
|
fadt->reset_reg.bit_width = 8;
|
||||||
|
fadt->reset_reg.bit_offset = 0;
|
||||||
|
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
||||||
|
fadt->reset_reg.addrl = RST_CNT;
|
||||||
|
fadt->reset_reg.addrh = 0;
|
||||||
|
|
||||||
|
fadt->reset_value = RST_CPU | SYS_RST;
|
||||||
|
|
||||||
|
fadt->flags |= ACPI_FADT_RESET_REGISTER;
|
||||||
|
}
|
||||||
|
}
|
@ -880,6 +880,7 @@ void acpi_write_bert(acpi_bert_t *bert, uintptr_t region, size_t length);
|
|||||||
void acpi_create_fadt(acpi_fadt_t *fadt, acpi_facs_t *facs, void *dsdt);
|
void acpi_create_fadt(acpi_fadt_t *fadt, acpi_facs_t *facs, void *dsdt);
|
||||||
|
|
||||||
void acpi_fill_fadt(acpi_fadt_t *fadt);
|
void acpi_fill_fadt(acpi_fadt_t *fadt);
|
||||||
|
void arch_fill_fadt(acpi_fadt_t *fadt);
|
||||||
void soc_fill_fadt(acpi_fadt_t *fadt);
|
void soc_fill_fadt(acpi_fadt_t *fadt);
|
||||||
void mainboard_fill_fadt(acpi_fadt_t *fadt);
|
void mainboard_fill_fadt(acpi_fadt_t *fadt);
|
||||||
|
|
||||||
|
@ -122,24 +122,11 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_S4_RTC_WAKE |
|
ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_32BIT_TIMER |
|
ACPI_FADT_32BIT_TIMER |
|
||||||
ACPI_FADT_RESET_REGISTER |
|
|
||||||
ACPI_FADT_PCI_EXPRESS_WAKE |
|
ACPI_FADT_PCI_EXPRESS_WAKE |
|
||||||
ACPI_FADT_PLATFORM_CLOCK |
|
ACPI_FADT_PLATFORM_CLOCK |
|
||||||
ACPI_FADT_S4_RTC_VALID |
|
ACPI_FADT_S4_RTC_VALID |
|
||||||
ACPI_FADT_REMOTE_POWER_ON;
|
ACPI_FADT_REMOTE_POWER_ON;
|
||||||
|
|
||||||
/* Format is from 5.2.3.1: Generic Address Structure */
|
|
||||||
/* reset_reg: see section 4.7.3.6 ACPI 3.0a spec */
|
|
||||||
/* 8 bit write of value 0x06 to 0xCF9 in IO space */
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = SYS_RESET;
|
|
||||||
fadt->reset_reg.addrh = 0x0;
|
|
||||||
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
fadt->ARM_boot_arch = 0; /* MUST be 0 ACPI 3.0 */
|
fadt->ARM_boot_arch = 0; /* MUST be 0 ACPI 3.0 */
|
||||||
fadt->FADT_MinorVersion = 0; /* MUST be 0 ACPI 3.0 */
|
fadt->FADT_MinorVersion = 0; /* MUST be 0 ACPI 3.0 */
|
||||||
|
|
||||||
|
@ -94,24 +94,11 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_S4_RTC_WAKE |
|
ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_32BIT_TIMER |
|
ACPI_FADT_32BIT_TIMER |
|
||||||
ACPI_FADT_RESET_REGISTER |
|
|
||||||
ACPI_FADT_PCI_EXPRESS_WAKE |
|
ACPI_FADT_PCI_EXPRESS_WAKE |
|
||||||
ACPI_FADT_PLATFORM_CLOCK |
|
ACPI_FADT_PLATFORM_CLOCK |
|
||||||
ACPI_FADT_S4_RTC_VALID |
|
ACPI_FADT_S4_RTC_VALID |
|
||||||
ACPI_FADT_REMOTE_POWER_ON;
|
ACPI_FADT_REMOTE_POWER_ON;
|
||||||
|
|
||||||
/* Format is from 5.2.3.1: Generic Address Structure */
|
|
||||||
/* reset_reg: see section 4.7.3.6 ACPI 3.0a spec */
|
|
||||||
/* 8 bit write of value 0x06 to 0xCF9 in IO space */
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = SYS_RESET;
|
|
||||||
fadt->reset_reg.addrh = 0x0;
|
|
||||||
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
fadt->ARM_boot_arch = 0; /* MUST be 0 ACPI 3.0 */
|
fadt->ARM_boot_arch = 0; /* MUST be 0 ACPI 3.0 */
|
||||||
fadt->FADT_MinorVersion = 0; /* MUST be 0 ACPI 3.0 */
|
fadt->FADT_MinorVersion = 0; /* MUST be 0 ACPI 3.0 */
|
||||||
|
|
||||||
|
@ -41,16 +41,8 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
|
|
||||||
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
||||||
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_RESET_REGISTER | ACPI_FADT_SEALED_CASE |
|
ACPI_FADT_SEALED_CASE | ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_S4_RTC_WAKE | ACPI_FADT_PLATFORM_CLOCK;
|
ACPI_FADT_PLATFORM_CLOCK;
|
||||||
|
|
||||||
fadt->reset_reg.space_id = 1;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = 1;
|
fadt->x_pm1a_evt_blk.space_id = 1;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
||||||
|
@ -41,16 +41,8 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
|
|
||||||
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
||||||
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_RESET_REGISTER | ACPI_FADT_SEALED_CASE |
|
ACPI_FADT_SEALED_CASE | ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_S4_RTC_WAKE | ACPI_FADT_PLATFORM_CLOCK;
|
ACPI_FADT_PLATFORM_CLOCK;
|
||||||
|
|
||||||
fadt->reset_reg.space_id = 1;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = 1;
|
fadt->x_pm1a_evt_blk.space_id = 1;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
||||||
|
@ -40,16 +40,8 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
|
|
||||||
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
||||||
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_RESET_REGISTER | ACPI_FADT_SEALED_CASE |
|
ACPI_FADT_SEALED_CASE | ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_S4_RTC_WAKE | ACPI_FADT_PLATFORM_CLOCK;
|
ACPI_FADT_PLATFORM_CLOCK;
|
||||||
|
|
||||||
fadt->reset_reg.space_id = 1;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = 1;
|
fadt->x_pm1a_evt_blk.space_id = 1;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
||||||
|
@ -119,14 +119,8 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
|
|
||||||
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
||||||
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_RESET_REGISTER | ACPI_FADT_SEALED_CASE |
|
ACPI_FADT_SEALED_CASE | ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_S4_RTC_WAKE | ACPI_FADT_PLATFORM_CLOCK;
|
ACPI_FADT_PLATFORM_CLOCK;
|
||||||
|
|
||||||
fadt->reset_reg.space_id = 1;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.addrl = RST_CNT;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_value = RST_CPU | SYS_RST;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = 1;
|
fadt->x_pm1a_evt_blk.space_id = 1;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
||||||
|
@ -140,17 +140,8 @@ void soc_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
|
|
||||||
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
||||||
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_RESET_REGISTER | ACPI_FADT_SLEEP_TYPE |
|
ACPI_FADT_SLEEP_TYPE | ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_S4_RTC_WAKE | ACPI_FADT_PLATFORM_CLOCK;
|
ACPI_FADT_PLATFORM_CLOCK;
|
||||||
|
|
||||||
/* Reset Register */
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xCF9;
|
|
||||||
fadt->reset_reg.addrh = 0x00;
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
/* PM1 Status & PM1 Enable */
|
/* PM1 Status & PM1 Enable */
|
||||||
fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
|
fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
|
||||||
|
@ -25,7 +25,7 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
uint32_t pmbase = pci_read_config32(dev, R_QNC_LPC_PM1BLK)
|
uint32_t pmbase = pci_read_config32(dev, R_QNC_LPC_PM1BLK)
|
||||||
& B_QNC_LPC_PM1BLK_MASK;
|
& B_QNC_LPC_PM1BLK_MASK;
|
||||||
|
|
||||||
fadt->flags |= ACPI_FADT_RESET_REGISTER | ACPI_FADT_PLATFORM_CLOCK;
|
fadt->flags |= ACPI_FADT_PLATFORM_CLOCK;
|
||||||
|
|
||||||
/* PM1 Status: ACPI 4.8.3.1.1 */
|
/* PM1 Status: ACPI 4.8.3.1.1 */
|
||||||
fadt->pm1a_evt_blk = pmbase + R_QNC_PM1BLK_PM1S;
|
fadt->pm1a_evt_blk = pmbase + R_QNC_PM1BLK_PM1S;
|
||||||
@ -60,17 +60,6 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
fadt->x_pm_tmr_blk.addrl = fadt->pm_tmr_blk;
|
fadt->x_pm_tmr_blk.addrl = fadt->pm_tmr_blk;
|
||||||
fadt->x_pm_tmr_blk.addrh = 0x0;
|
fadt->x_pm_tmr_blk.addrh = 0x0;
|
||||||
|
|
||||||
/* Reset Register: ACPI 4.8.3.6, 5.2.3.2 */
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
|
|
||||||
/* Soft/Warm Reset */
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
/* General-Purpose Event 0 Registers: ACPI 4.8.4.1 */
|
/* General-Purpose Event 0 Registers: ACPI 4.8.4.1 */
|
||||||
fadt->gpe0_blk = gpe0_base;
|
fadt->gpe0_blk = gpe0_base;
|
||||||
fadt->gpe0_blk_len = 4 * 2;
|
fadt->gpe0_blk_len = 4 * 2;
|
||||||
|
@ -46,20 +46,12 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
|
|
||||||
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
||||||
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_RESET_REGISTER | ACPI_FADT_SEALED_CASE |
|
ACPI_FADT_SEALED_CASE | ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_S4_RTC_WAKE | ACPI_FADT_PLATFORM_CLOCK;
|
ACPI_FADT_PLATFORM_CLOCK;
|
||||||
|
|
||||||
if (config->s0ix_enable)
|
if (config->s0ix_enable)
|
||||||
fadt->flags |= ACPI_FADT_LOW_PWR_IDLE_S0;
|
fadt->flags |= ACPI_FADT_LOW_PWR_IDLE_S0;
|
||||||
|
|
||||||
fadt->reset_reg.space_id = 1;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = 1;
|
fadt->x_pm1a_evt_blk.space_id = 1;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
||||||
fadt->x_pm1a_evt_blk.bit_offset = 0;
|
fadt->x_pm1a_evt_blk.bit_offset = 0;
|
||||||
|
@ -297,13 +297,7 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
fadt->day_alrm = 0xd;
|
fadt->day_alrm = 0xd;
|
||||||
|
|
||||||
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED | ACPI_FADT_C2_MP_SUPPORTED |
|
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED | ACPI_FADT_C2_MP_SUPPORTED |
|
||||||
ACPI_FADT_RESET_REGISTER | ACPI_FADT_PLATFORM_CLOCK;
|
ACPI_FADT_PLATFORM_CLOCK;
|
||||||
|
|
||||||
fadt->reset_reg.space_id = 1;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.addrl = RST_CNT;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_value = RST_CPU | SYS_RST;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = 1;
|
fadt->x_pm1a_evt_blk.space_id = 1;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
||||||
|
@ -263,17 +263,8 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
|
|
||||||
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
||||||
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_RESET_REGISTER | ACPI_FADT_SLEEP_TYPE |
|
ACPI_FADT_SLEEP_TYPE | ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_S4_RTC_WAKE | ACPI_FADT_PLATFORM_CLOCK;
|
ACPI_FADT_PLATFORM_CLOCK;
|
||||||
|
|
||||||
/* Reset Register */
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xCF9;
|
|
||||||
fadt->reset_reg.addrh = 0x00;
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
/* PM1 Status & PM1 Enable */
|
/* PM1 Status & PM1 Enable */
|
||||||
fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
|
fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
|
||||||
|
@ -64,18 +64,6 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
ACPI_FADT_S4_RTC_VALID |
|
ACPI_FADT_S4_RTC_VALID |
|
||||||
ACPI_FADT_REMOTE_POWER_ON;
|
ACPI_FADT_REMOTE_POWER_ON;
|
||||||
|
|
||||||
/* Format is from 5.2.3.1: Generic Address Structure */
|
|
||||||
/* reset_reg: see section 4.7.3.6 ACPI 3.0a spec */
|
|
||||||
/* 8 bit write of value 0x06 to 0xCF9 in IO space */
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0x0;
|
|
||||||
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
fadt->ARM_boot_arch = 0; /* MUST be 0 ACPI 3.0 */
|
fadt->ARM_boot_arch = 0; /* MUST be 0 ACPI 3.0 */
|
||||||
fadt->FADT_MinorVersion = 0; /* MUST be 0 ACPI 3.0 */
|
fadt->FADT_MinorVersion = 0; /* MUST be 0 ACPI 3.0 */
|
||||||
|
|
||||||
|
@ -84,22 +84,10 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_S4_RTC_WAKE |
|
ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_32BIT_TIMER |
|
ACPI_FADT_32BIT_TIMER |
|
||||||
ACPI_FADT_RESET_REGISTER |
|
|
||||||
ACPI_FADT_PCI_EXPRESS_WAKE |
|
ACPI_FADT_PCI_EXPRESS_WAKE |
|
||||||
ACPI_FADT_S4_RTC_VALID |
|
ACPI_FADT_S4_RTC_VALID |
|
||||||
ACPI_FADT_REMOTE_POWER_ON;
|
ACPI_FADT_REMOTE_POWER_ON;
|
||||||
|
|
||||||
/* Format is from 5.2.3.1: Generic Address Structure */
|
|
||||||
/* reset_reg: see section 4.7.3.6 ACPI 3.0a spec */
|
|
||||||
/* 8 bit write of value 0x06 to 0xCF9 in IO space */
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0x0;
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
fadt->ARM_boot_arch = 0; /* MUST be 0 ACPI 3.0 */
|
fadt->ARM_boot_arch = 0; /* MUST be 0 ACPI 3.0 */
|
||||||
fadt->FADT_MinorVersion = 0; /* MUST be 0 ACPI 3.0 */
|
fadt->FADT_MinorVersion = 0; /* MUST be 0 ACPI 3.0 */
|
||||||
|
|
||||||
|
@ -58,24 +58,11 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_S4_RTC_WAKE |
|
ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_32BIT_TIMER |
|
ACPI_FADT_32BIT_TIMER |
|
||||||
ACPI_FADT_RESET_REGISTER |
|
|
||||||
ACPI_FADT_PCI_EXPRESS_WAKE |
|
ACPI_FADT_PCI_EXPRESS_WAKE |
|
||||||
ACPI_FADT_PLATFORM_CLOCK |
|
ACPI_FADT_PLATFORM_CLOCK |
|
||||||
ACPI_FADT_S4_RTC_VALID |
|
ACPI_FADT_S4_RTC_VALID |
|
||||||
ACPI_FADT_REMOTE_POWER_ON;
|
ACPI_FADT_REMOTE_POWER_ON;
|
||||||
|
|
||||||
/* Format is from 5.2.3.1: Generic Address Structure */
|
|
||||||
/* reset_reg: see section 4.7.3.6 ACPI 3.0a spec */
|
|
||||||
/* 8 bit write of value 0x06 to 0xCF9 in IO space */
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0x0;
|
|
||||||
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
fadt->ARM_boot_arch = 0; /* MUST be 0 ACPI 3.0 */
|
fadt->ARM_boot_arch = 0; /* MUST be 0 ACPI 3.0 */
|
||||||
fadt->FADT_MinorVersion = 0; /* MUST be 0 ACPI 3.0 */
|
fadt->FADT_MinorVersion = 0; /* MUST be 0 ACPI 3.0 */
|
||||||
|
|
||||||
|
@ -50,7 +50,6 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
fadt->flags |= ACPI_FADT_WBINVD |
|
fadt->flags |= ACPI_FADT_WBINVD |
|
||||||
ACPI_FADT_C1_SUPPORTED |
|
ACPI_FADT_C1_SUPPORTED |
|
||||||
ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_RESET_REGISTER |
|
|
||||||
ACPI_FADT_SEALED_CASE |
|
ACPI_FADT_SEALED_CASE |
|
||||||
ACPI_FADT_S4_RTC_WAKE |
|
ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_PLATFORM_CLOCK;
|
ACPI_FADT_PLATFORM_CLOCK;
|
||||||
@ -61,15 +60,6 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
fadt->flags |= ACPI_FADT_C2_MP_SUPPORTED;
|
fadt->flags |= ACPI_FADT_C2_MP_SUPPORTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
fadt->reset_reg.space_id = 1;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = 1;
|
fadt->x_pm1a_evt_blk.space_id = 1;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = 32;
|
fadt->x_pm1a_evt_blk.bit_width = 32;
|
||||||
fadt->x_pm1a_evt_blk.bit_offset = 0;
|
fadt->x_pm1a_evt_blk.bit_offset = 0;
|
||||||
|
@ -101,15 +101,7 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
* 18 FORCE_APIC_CLUSTER_MODEL
|
* 18 FORCE_APIC_CLUSTER_MODEL
|
||||||
* 19 FORCE_APIC_PHYSICAL_DESTINATION_MODE
|
* 19 FORCE_APIC_PHYSICAL_DESTINATION_MODE
|
||||||
*/
|
*/
|
||||||
fadt->flags |= 0xa5 | ACPI_FADT_RESET_REGISTER;
|
fadt->flags |= 0xa5;
|
||||||
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
fadt->reset_value = 0x06;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = 1;
|
fadt->x_pm1a_evt_blk.space_id = 1;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8;
|
||||||
|
@ -50,16 +50,7 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
|
|
||||||
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
||||||
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_C2_MP_SUPPORTED | ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_S4_RTC_WAKE | ACPI_FADT_RESET_REGISTER |
|
ACPI_FADT_S4_RTC_WAKE | ACPI_FADT_PLATFORM_CLOCK;
|
||||||
ACPI_FADT_PLATFORM_CLOCK;
|
|
||||||
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
fadt->reset_value = 0x06;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = 1;
|
fadt->x_pm1a_evt_blk.space_id = 1;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = 32;
|
fadt->x_pm1a_evt_blk.bit_width = 32;
|
||||||
|
@ -49,19 +49,10 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
fadt->iapc_boot_arch = ACPI_FADT_8042 | ACPI_FADT_LEGACY_DEVICES;
|
fadt->iapc_boot_arch = ACPI_FADT_8042 | ACPI_FADT_LEGACY_DEVICES;
|
||||||
fadt->flags |= (ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED
|
fadt->flags |= (ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED
|
||||||
| ACPI_FADT_SLEEP_BUTTON | ACPI_FADT_S4_RTC_WAKE
|
| ACPI_FADT_SLEEP_BUTTON | ACPI_FADT_S4_RTC_WAKE
|
||||||
| ACPI_FADT_PLATFORM_CLOCK | ACPI_FADT_RESET_REGISTER
|
| ACPI_FADT_PLATFORM_CLOCK | ACPI_FADT_C2_MP_SUPPORTED);
|
||||||
| ACPI_FADT_C2_MP_SUPPORTED);
|
|
||||||
if (chip->docking_supported)
|
if (chip->docking_supported)
|
||||||
fadt->flags |= ACPI_FADT_DOCKING_SUPPORTED;
|
fadt->flags |= ACPI_FADT_DOCKING_SUPPORTED;
|
||||||
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
fadt->reset_value = 0x06;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
|
fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = 32;
|
fadt->x_pm1a_evt_blk.bit_width = 32;
|
||||||
fadt->x_pm1a_evt_blk.bit_offset = 0;
|
fadt->x_pm1a_evt_blk.bit_offset = 0;
|
||||||
|
@ -42,16 +42,7 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
fadt->iapc_boot_arch = ACPI_FADT_LEGACY_FREE;
|
fadt->iapc_boot_arch = ACPI_FADT_LEGACY_FREE;
|
||||||
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED |
|
||||||
ACPI_FADT_SLEEP_BUTTON | ACPI_FADT_S4_RTC_WAKE |
|
ACPI_FADT_SLEEP_BUTTON | ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_DOCKING_SUPPORTED | ACPI_FADT_RESET_REGISTER |
|
ACPI_FADT_DOCKING_SUPPORTED | ACPI_FADT_PLATFORM_CLOCK;
|
||||||
ACPI_FADT_PLATFORM_CLOCK;
|
|
||||||
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
fadt->reset_value = 0x06;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
|
fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = 32;
|
fadt->x_pm1a_evt_blk.bit_width = 32;
|
||||||
|
@ -45,19 +45,10 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
fadt->iapc_boot_arch = ACPI_FADT_8042 | ACPI_FADT_LEGACY_DEVICES;
|
fadt->iapc_boot_arch = ACPI_FADT_8042 | ACPI_FADT_LEGACY_DEVICES;
|
||||||
fadt->flags |= (ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED
|
fadt->flags |= (ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED
|
||||||
| ACPI_FADT_SLEEP_BUTTON | ACPI_FADT_S4_RTC_WAKE
|
| ACPI_FADT_SLEEP_BUTTON | ACPI_FADT_S4_RTC_WAKE
|
||||||
| ACPI_FADT_PLATFORM_CLOCK | ACPI_FADT_RESET_REGISTER
|
| ACPI_FADT_PLATFORM_CLOCK | ACPI_FADT_C2_MP_SUPPORTED);
|
||||||
| ACPI_FADT_C2_MP_SUPPORTED);
|
|
||||||
if (chip->docking_supported)
|
if (chip->docking_supported)
|
||||||
fadt->flags |= ACPI_FADT_DOCKING_SUPPORTED;
|
fadt->flags |= ACPI_FADT_DOCKING_SUPPORTED;
|
||||||
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
fadt->reset_value = 0x06;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
|
fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = 32;
|
fadt->x_pm1a_evt_blk.bit_width = 32;
|
||||||
fadt->x_pm1a_evt_blk.bit_offset = 0;
|
fadt->x_pm1a_evt_blk.bit_offset = 0;
|
||||||
|
@ -50,7 +50,6 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
fadt->flags |= ACPI_FADT_WBINVD |
|
fadt->flags |= ACPI_FADT_WBINVD |
|
||||||
ACPI_FADT_C1_SUPPORTED |
|
ACPI_FADT_C1_SUPPORTED |
|
||||||
ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_RESET_REGISTER |
|
|
||||||
ACPI_FADT_S4_RTC_WAKE |
|
ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_PLATFORM_CLOCK;
|
ACPI_FADT_PLATFORM_CLOCK;
|
||||||
if (chip->docking_supported) {
|
if (chip->docking_supported) {
|
||||||
@ -60,15 +59,6 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
fadt->flags |= ACPI_FADT_C2_MP_SUPPORTED;
|
fadt->flags |= ACPI_FADT_C2_MP_SUPPORTED;
|
||||||
}
|
}
|
||||||
|
|
||||||
fadt->reset_reg.space_id = 1;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = 1;
|
fadt->x_pm1a_evt_blk.space_id = 1;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = 32;
|
fadt->x_pm1a_evt_blk.bit_width = 32;
|
||||||
fadt->x_pm1a_evt_blk.bit_offset = 0;
|
fadt->x_pm1a_evt_blk.bit_offset = 0;
|
||||||
|
@ -57,7 +57,6 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
ACPI_FADT_C1_SUPPORTED |
|
ACPI_FADT_C1_SUPPORTED |
|
||||||
ACPI_FADT_C2_MP_SUPPORTED |
|
ACPI_FADT_C2_MP_SUPPORTED |
|
||||||
ACPI_FADT_SLEEP_BUTTON |
|
ACPI_FADT_SLEEP_BUTTON |
|
||||||
ACPI_FADT_RESET_REGISTER |
|
|
||||||
ACPI_FADT_SEALED_CASE |
|
ACPI_FADT_SEALED_CASE |
|
||||||
ACPI_FADT_S4_RTC_WAKE |
|
ACPI_FADT_S4_RTC_WAKE |
|
||||||
ACPI_FADT_PLATFORM_CLOCK;
|
ACPI_FADT_PLATFORM_CLOCK;
|
||||||
@ -65,15 +64,6 @@ void acpi_fill_fadt(acpi_fadt_t *fadt)
|
|||||||
if (cfg->docking_supported)
|
if (cfg->docking_supported)
|
||||||
fadt->flags |= ACPI_FADT_DOCKING_SUPPORTED;
|
fadt->flags |= ACPI_FADT_DOCKING_SUPPORTED;
|
||||||
|
|
||||||
fadt->reset_reg.space_id = ACPI_ADDRESS_SPACE_IO;
|
|
||||||
fadt->reset_reg.bit_width = 8;
|
|
||||||
fadt->reset_reg.bit_offset = 0;
|
|
||||||
fadt->reset_reg.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS;
|
|
||||||
fadt->reset_reg.addrl = 0xcf9;
|
|
||||||
fadt->reset_reg.addrh = 0;
|
|
||||||
|
|
||||||
fadt->reset_value = 6;
|
|
||||||
|
|
||||||
fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
|
fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO;
|
||||||
fadt->x_pm1a_evt_blk.bit_width = 2 * 16;
|
fadt->x_pm1a_evt_blk.bit_width = 2 * 16;
|
||||||
fadt->x_pm1a_evt_blk.bit_offset = 0;
|
fadt->x_pm1a_evt_blk.bit_offset = 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user