The mainboard_smi_sleep() function takes ACPI sleep values of the form S3=3, S4=4, S5=5, etc. All the chipsets ensure that whatever hardware PM1 control register values are used the interface to the mainboard is the same. Move all the SMI handlers in the mainboard directory to not open code the literal values 3 and 5 for ACPI_S3 and ACPI_S5. There were a few notable exceptions where the code was attempting to use the hardware values and not the common translated values. The few users of SLEEP_STATE_X were updated to align with ACPI_SX as those defines are already equal. The removal of SLEEP_STATE_X defines is forthcoming in a subsequent patch. BUG=chrome-os-partner:54977 Change-Id: I76592c9107778cce5995e5af764760453f54dc50 Signed-off-by: Aaron Durbin <adurbin@chromium.org> Reviewed-on: https://review.coreboot.org/15664 Tested-by: build bot (Jenkins) Reviewed-by: Kyösti Mälkki <kyosti.malkki@gmail.com> Reviewed-by: Furquan Shaikh <furquan@google.com>
130 lines
3.0 KiB
C
130 lines
3.0 KiB
C
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* Copyright (C) 2008-2009 coresystems GmbH
|
|
* Copyright (C) 2015 Intel Corp.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; version 2 of the License.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*/
|
|
|
|
#include <arch/acpi.h>
|
|
#include <arch/io.h>
|
|
#include <console/console.h>
|
|
#include <cpu/x86/smm.h>
|
|
#include <elog.h>
|
|
#include <ec/google/chromeec/ec.h>
|
|
#include <soc/iomap.h>
|
|
#include <soc/nvs.h>
|
|
#include <soc/pm.h>
|
|
#include <soc/smm.h>
|
|
#include "ec.h"
|
|
#include "gpio.h"
|
|
|
|
int mainboard_io_trap_handler(int smif)
|
|
{
|
|
switch (smif) {
|
|
case 0x99:
|
|
printk(BIOS_DEBUG, "Sample\n");
|
|
smm_get_gnvs()->smif = 0;
|
|
break;
|
|
default:
|
|
return 0;
|
|
}
|
|
|
|
/* On success, the IO Trap Handler returns 0
|
|
* On failure, the IO Trap Handler returns a value != 0
|
|
*
|
|
* For now, we force the return value to 0 and log all traps to
|
|
* see what's going on.
|
|
*/
|
|
return 1;
|
|
}
|
|
|
|
static u8 mainboard_smi_ec(void)
|
|
{
|
|
u8 cmd = 0;
|
|
#if IS_ENABLED(CONFIG_EC_GOOGLE_CHROMEEC)
|
|
u32 pm1_cnt;
|
|
cmd = google_chromeec_get_event();
|
|
|
|
/* Log this event */
|
|
if (IS_ENABLED(CONFIG_ELOG_GSMI) && cmd)
|
|
elog_add_event_byte(ELOG_TYPE_EC_EVENT, cmd);
|
|
|
|
switch (cmd) {
|
|
case EC_HOST_EVENT_LID_CLOSED:
|
|
printk(BIOS_DEBUG, "LID CLOSED, SHUTDOWN\n");
|
|
|
|
/* Go to S5 */
|
|
pm1_cnt = inl(ACPI_BASE_ADDRESS + PM1_CNT);
|
|
pm1_cnt |= (0xf << 10);
|
|
outl(pm1_cnt, ACPI_BASE_ADDRESS + PM1_CNT);
|
|
break;
|
|
}
|
|
#endif
|
|
return cmd;
|
|
}
|
|
|
|
void mainboard_smi_gpi_handler(const struct gpi_status *sts)
|
|
{
|
|
if (gpi_status_get(sts, EC_SMI_GPI)) {
|
|
/* Process all pending events */
|
|
while (mainboard_smi_ec() != 0)
|
|
;
|
|
}
|
|
}
|
|
|
|
void mainboard_smi_sleep(u8 slp_typ)
|
|
{
|
|
#if IS_ENABLED(CONFIG_EC_GOOGLE_CHROMEEC)
|
|
switch (slp_typ) {
|
|
case ACPI_S3:
|
|
/* Enable wake events */
|
|
google_chromeec_set_wake_mask(MAINBOARD_EC_S3_WAKE_EVENTS);
|
|
break;
|
|
case ACPI_S5:
|
|
/* Enable wake events */
|
|
google_chromeec_set_wake_mask(MAINBOARD_EC_S5_WAKE_EVENTS);
|
|
break;
|
|
}
|
|
|
|
/* Disable SCI and SMI events */
|
|
google_chromeec_set_smi_mask(0);
|
|
google_chromeec_set_sci_mask(0);
|
|
|
|
/* Clear pending events that may trigger immediate wake */
|
|
while (google_chromeec_get_event() != 0)
|
|
;
|
|
#endif
|
|
}
|
|
|
|
int mainboard_smi_apmc(u8 apmc)
|
|
{
|
|
#if IS_ENABLED(CONFIG_EC_GOOGLE_CHROMEEC)
|
|
switch (apmc) {
|
|
case APM_CNT_ACPI_ENABLE:
|
|
google_chromeec_set_smi_mask(0);
|
|
/* Clear all pending events */
|
|
while (google_chromeec_get_event() != 0)
|
|
;
|
|
google_chromeec_set_sci_mask(MAINBOARD_EC_SCI_EVENTS);
|
|
break;
|
|
case APM_CNT_ACPI_DISABLE:
|
|
google_chromeec_set_sci_mask(0);
|
|
/* Clear all pending events */
|
|
while (google_chromeec_get_event() != 0)
|
|
;
|
|
google_chromeec_set_smi_mask(MAINBOARD_EC_SMI_EVENTS);
|
|
break;
|
|
}
|
|
#endif
|
|
return 0;
|
|
}
|