diff options
author | Raul E Rangel <rrangel@chromium.org> | 2021-04-19 17:09:30 -0600 |
---|---|---|
committer | Raul Rangel <rrangel@chromium.org> | 2021-04-21 22:27:39 +0000 |
commit | a89a4ea8ea04aaf369cd99f487f3537fe9e46702 (patch) | |
tree | f020a986873b7b5617321d50219eac01d133408d | |
parent | e3f7645a8bb50b63200a14d79b3f4b8a94015691 (diff) | |
download | coreboot-a89a4ea8ea04aaf369cd99f487f3537fe9e46702.tar.xz |
soc/amd/{cezanne,common}/acpi: Add _OSC method
The linux kernel requires a valid _OSC method. Otherwise the _LPI table
is ignored.
See https://source.chromium.org/chromiumos/chromiumos/codesearch/+/main:src/third_party/kernel/v5.10/drivers/acpi/bus.c;l=324
Before this patch:
acpi_processor_get_lpi_info: LPI is not supported
After this patch:
acpi_processor_evaluate_lpi: ACPI: \_SB_.CP00: ACPI: Found 4 power states
BUG=b:178728116
TEST=Boot OS and verify _LPI table is parsed
Signed-off-by: Raul E Rangel <rrangel@chromium.org>
Change-Id: I44e554b9db6f70fdd1559105cdaee53aeb2bfbf5
Reviewed-on: https://review.coreboot.org/c/coreboot/+/52528
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Marshall Dawson <marshalldawson3rd@gmail.com>
-rw-r--r-- | src/soc/amd/cezanne/acpi/soc.asl | 2 | ||||
-rw-r--r-- | src/soc/amd/common/acpi/osc.asl | 22 |
2 files changed, 24 insertions, 0 deletions
diff --git a/src/soc/amd/cezanne/acpi/soc.asl b/src/soc/amd/cezanne/acpi/soc.asl index be511042e4..f7781dab2e 100644 --- a/src/soc/amd/cezanne/acpi/soc.asl +++ b/src/soc/amd/cezanne/acpi/soc.asl @@ -8,6 +8,8 @@ Scope(\_SB) { #include <soc/amd/common/acpi/gpio_bank_lib.asl> + #include <soc/amd/common/acpi/osc.asl> + #include "pci_int_defs.asl" #include "mmio.asl" diff --git a/src/soc/amd/common/acpi/osc.asl b/src/soc/amd/common/acpi/osc.asl new file mode 100644 index 0000000000..22175caa45 --- /dev/null +++ b/src/soc/amd/common/acpi/osc.asl @@ -0,0 +1,22 @@ +/* SPDX-License-Identifier: GPL-2.0-only */ + +#include <acpi/acpi_osc.h> + +/* + * Platform-Wide _OSC Operating System Capabilities + * + * Arg0: A Buffer containing a UUID + * Arg1: An Integer containing a Revision ID of the buffer format + * Arg2: An Integer containing a count of entries in Arg3 + * Arg3: A Buffer containing a list of DWORD capabilities + */ +Method (_OSC, 4, NotSerialized) { + CreateDWordField (Arg3, 0, CDW1) + If (Arg0 == ToUUID (OSC_SB_UUID)) { + /* Don't mask any capability bits off. */ + Return (Arg3) + } Else { + CDW1 |= OSC_CDW1_UNRECOGNIZED_UUID + Return (Arg3) + } +} |