acpi/acpi_pm.c: refactor acpi_pm_state_for_* functions

Use just one function to get the chipset powerstate and add an argument
to specify the powerstate claimer {RTC,ELOG,WAKE} and adjust the
failure log accordingly.

TEST: compile tested and qemu emulation successfully run

Signed-off-by: Fabio Aiuto <fabioaiuto83@gmail.com>
Change-Id: I8addc0b05f9e360afc52091c4bb731341d7213cf
Reviewed-on: https://review.coreboot.org/c/coreboot/+/67618
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Felix Held <felix-coreboot@felixheld.de>
This commit is contained in:
Fabio Aiuto
2022-09-11 12:25:13 +02:00
committed by Felix Held
parent e6d6d3620e
commit fdcf698a89
21 changed files with 41 additions and 43 deletions

View File

@@ -2,10 +2,17 @@
#include <acpi/acpi.h>
#include <acpi/acpi_pm.h>
#include <assert.h>
#include <cbmem.h>
#include <console/console.h>
#include <smbios.h>
static const char *pm_fetch_failure_msg[PS_CLAIMER_MAX] = {
[PS_CLAIMER_ELOG] = "no event recorded in ELOG.",
[PS_CLAIMER_RTC] = "RTC init aborted.",
[PS_CLAIMER_WAKE] = "wake source unknown.",
};
void __weak mainboard_suspend_resume(void)
{
}
@@ -38,31 +45,16 @@ struct chipset_power_state *acpi_get_pm_state(void)
return acpi_pm_state;
}
int acpi_pm_state_for_elog(const struct chipset_power_state **ps)
int acpi_fetch_pm_state(const struct chipset_power_state **ps,
enum power_state_claimer ps_claimer)
{
assert(ps_claimer < PS_CLAIMER_MAX);
*ps = acpi_get_pm_state();
if (!*ps) {
printk(BIOS_ERR, "No CBMEM_ID_POWER_STATE entry, no event recorded in ELOG.\n");
return -1;
}
return 0;
}
int acpi_pm_state_for_rtc(const struct chipset_power_state **ps)
{
*ps = acpi_get_pm_state();
if (!*ps) {
printk(BIOS_ERR, "No CBMEM_ID_POWER_STATE entry, RTC init aborted.\n");
return -1;
}
return 0;
}
int acpi_pm_state_for_wake(const struct chipset_power_state **ps)
{
*ps = acpi_get_pm_state();
if (!*ps) {
printk(BIOS_ERR, "No CBMEM_ID_POWER_STATE entry, wake source unknown.\n");
printk(BIOS_ERR, "No CBMEM_ID_POWER_STATE entry, %s\n",
ps_claimer < PS_CLAIMER_MAX ?
pm_fetch_failure_msg[ps_claimer] : "unknown claimer.");
return -1;
}
return 0;