summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/soc/amd/common/block/acpi/acpi.c7
-rw-r--r--src/soc/amd/common/block/include/amdblocks/acpi.h3
-rw-r--r--src/soc/amd/picasso/fch.c6
-rw-r--r--src/soc/amd/stoneyridge/southbridge.c6
4 files changed, 9 insertions, 13 deletions
diff --git a/src/soc/amd/common/block/acpi/acpi.c b/src/soc/amd/common/block/acpi/acpi.c
index 4ca6599536..572faa51a1 100644
--- a/src/soc/amd/common/block/acpi/acpi.c
+++ b/src/soc/amd/common/block/acpi/acpi.c
@@ -3,12 +3,14 @@
#include <amdblocks/acpimmio.h>
#include <amdblocks/acpi.h>
#include <acpi/acpi.h>
+#include <acpi/acpi_gnvs.h>
#include <bootmode.h>
#include <console/console.h>
#include <elog.h>
#include <halt.h>
#include <security/vboot/vboot_common.h>
#include <soc/southbridge.h>
+#include <soc/nvs.h>
void poweroff(void)
{
@@ -138,9 +140,12 @@ static int get_index_bit(uint32_t value, uint16_t limit)
return i;
}
-void acpi_fill_gnvs(struct global_nvs *gnvs, const struct acpi_pm_gpe_state *state)
+void pm_fill_gnvs(const struct acpi_pm_gpe_state *state)
{
int index;
+ struct global_nvs *gnvs = acpi_get_gnvs();
+ if (gnvs == NULL)
+ return;
index = get_index_bit(state->pm1_sts & state->pm1_en, PM1_LIMIT);
if (index < 0)
diff --git a/src/soc/amd/common/block/include/amdblocks/acpi.h b/src/soc/amd/common/block/include/amdblocks/acpi.h
index c6e242adaa..0512ad69ff 100644
--- a/src/soc/amd/common/block/include/amdblocks/acpi.h
+++ b/src/soc/amd/common/block/include/amdblocks/acpi.h
@@ -4,7 +4,6 @@
#define AMD_BLOCK_ACPI_H
#include <types.h>
-#include <soc/nvs.h>
/* ACPI MMIO registers 0xfed80800 */
#define MMIO_ACPI_PM1_STS 0x00
@@ -34,7 +33,7 @@ void acpi_pm_gpe_add_events_print_events(const struct acpi_pm_gpe_state *state);
/* Clear PM and GPE status registers. */
void acpi_clear_pm_gpe_status(void);
/* Fill GNVS object from PM GPE object. */
-void acpi_fill_gnvs(struct global_nvs *gnvs, const struct acpi_pm_gpe_state *state);
+void pm_fill_gnvs(const struct acpi_pm_gpe_state *state);
/*
* If a system reset is about to be requested, modify the PM1 register so it
diff --git a/src/soc/amd/picasso/fch.c b/src/soc/amd/picasso/fch.c
index 4c8c584cbf..7479a35cab 100644
--- a/src/soc/amd/picasso/fch.c
+++ b/src/soc/amd/picasso/fch.c
@@ -148,16 +148,12 @@ static void sb_init_acpi_ports(void)
static void set_nvs_sws(void *unused)
{
struct chipset_state *state;
- struct global_nvs *gnvs;
state = cbmem_find(CBMEM_ID_POWER_STATE);
if (state == NULL)
return;
- gnvs = acpi_get_gnvs();
- if (gnvs == NULL)
- return;
- acpi_fill_gnvs(gnvs, &state->gpe_state);
+ pm_fill_gnvs(&state->gpe_state);
}
BOOT_STATE_INIT_ENTRY(BS_OS_RESUME, BS_ON_ENTRY, set_nvs_sws, NULL);
diff --git a/src/soc/amd/stoneyridge/southbridge.c b/src/soc/amd/stoneyridge/southbridge.c
index 4436e0ebf0..3aecbb4758 100644
--- a/src/soc/amd/stoneyridge/southbridge.c
+++ b/src/soc/amd/stoneyridge/southbridge.c
@@ -404,16 +404,12 @@ static void sb_init_acpi_ports(void)
static void set_nvs_sws(void *unused)
{
struct acpi_pm_gpe_state *state;
- struct global_nvs *gnvs;
state = cbmem_find(CBMEM_ID_POWER_STATE);
if (state == NULL)
return;
- gnvs = acpi_get_gnvs();
- if (gnvs == NULL)
- return;
- acpi_fill_gnvs(gnvs, state);
+ pm_fill_gnvs(state);
}
BOOT_STATE_INIT_ENTRY(BS_OS_RESUME, BS_ON_ENTRY, set_nvs_sws, NULL);