blob: 5ce6b7bd0eaf42d220705cbddec841df8c921957 [file] [log] [blame]
Karthikeyan Ramasubramanian24295572021-03-25 18:07:12 -06001/* SPDX-License-Identifier: GPL-2.0-only */
2
3#include <amdblocks/acpimmio.h>
4#include <amdblocks/pmlib.h>
5#include <console/console.h>
6#include <types.h>
7
Felix Held43cd1c02021-04-13 20:07:26 +02008/* This register is a bit of an odd one. The configuration gets written into the lower nibble,
9 but ends up being copied to the upper nibble which gets initialized by this. */
Karthikeyan Ramasubramanian24295572021-03-25 18:07:12 -060010#define PM_RTC_SHADOW_REG 0x5b
Felix Held43cd1c02021-04-13 20:07:26 +020011#define PWR_PWRSTATE BIT(2) /* power state bit; needs to be written as 1 */
Karthikeyan Ramasubramanian24295572021-03-25 18:07:12 -060012#define PWR_FAIL_OFF 0x0 /* Always power off after power resumes */
13#define PWR_FAIL_ON 0x1 /* Always power on after power resumes */
14#define PWR_FAIL_PREV 0x3 /* Use previous setting after power resumes */
15
16void pm_set_power_failure_state(void)
17{
Felix Held43cd1c02021-04-13 20:07:26 +020018 uint8_t pwr_fail = PWR_PWRSTATE;
Karthikeyan Ramasubramanian24295572021-03-25 18:07:12 -060019
20 switch (CONFIG_MAINBOARD_POWER_FAILURE_STATE) {
21 case MAINBOARD_POWER_STATE_OFF:
22 printk(BIOS_INFO, "Set power off after power failure.\n");
23 pwr_fail |= PWR_FAIL_OFF;
24 break;
25 case MAINBOARD_POWER_STATE_ON:
26 printk(BIOS_INFO, "Set power on after power failure.\n");
27 pwr_fail |= PWR_FAIL_ON;
28 break;
29 case MAINBOARD_POWER_STATE_PREVIOUS:
30 printk(BIOS_INFO, "Keep power state after power failure.\n");
31 pwr_fail |= PWR_FAIL_PREV;
32 break;
33 default:
Julius Wernere9665952022-01-21 17:06:20 -080034 printk(BIOS_WARNING, "Unknown power-failure state: %d\n",
Karthikeyan Ramasubramanian24295572021-03-25 18:07:12 -060035 CONFIG_MAINBOARD_POWER_FAILURE_STATE);
36 pwr_fail |= PWR_FAIL_OFF;
37 break;
38 }
39
Felix Held43cd1c02021-04-13 20:07:26 +020040 pm_io_write8(PM_RTC_SHADOW_REG, pwr_fail);
Karthikeyan Ramasubramanian24295572021-03-25 18:07:12 -060041}