blob: f1b0b27d6ae9333717009ad475ad85a25223b7af (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
/* SPDX-License-Identifier: GPL-2.0-only */
#include <amdblocks/acpimmio.h>
#include <amdblocks/pmlib.h>
#include <console/console.h>
#include <types.h>
/* This register is a bit of an odd one. The configuration gets written into the lower nibble,
but ends up being copied to the upper nibble which gets initialized by this. */
#define PM_RTC_SHADOW_REG 0x5b
#define PWR_PWRSTATE BIT(2) /* power state bit; needs to be written as 1 */
#define PWR_FAIL_OFF 0x0 /* Always power off after power resumes */
#define PWR_FAIL_ON 0x1 /* Always power on after power resumes */
#define PWR_FAIL_PREV 0x3 /* Use previous setting after power resumes */
void pm_set_power_failure_state(void)
{
uint8_t pwr_fail = PWR_PWRSTATE;
switch (CONFIG_MAINBOARD_POWER_FAILURE_STATE) {
case MAINBOARD_POWER_STATE_OFF:
printk(BIOS_INFO, "Set power off after power failure.\n");
pwr_fail |= PWR_FAIL_OFF;
break;
case MAINBOARD_POWER_STATE_ON:
printk(BIOS_INFO, "Set power on after power failure.\n");
pwr_fail |= PWR_FAIL_ON;
break;
case MAINBOARD_POWER_STATE_PREVIOUS:
printk(BIOS_INFO, "Keep power state after power failure.\n");
pwr_fail |= PWR_FAIL_PREV;
break;
default:
printk(BIOS_WARNING, "WARNING: Unknown power-failure state: %d\n",
CONFIG_MAINBOARD_POWER_FAILURE_STATE);
pwr_fail |= PWR_FAIL_OFF;
break;
}
pm_io_write8(PM_RTC_SHADOW_REG, pwr_fail);
}
|