google/chromeec: Add common infrastructure for boot-mode switches
Instead of defining the same functions for reading/clearing boot-mode switches from EC in every mainboard, add a common infrastructure to enable common functions for handling boot-mode switches if GOOGLE_CHROMEEC is being used. Only boards that were not moved to this new infrastructure are those that do not use GOOGLE_CHROMEEC or which rely on some mainboard specific mechanism for reading boot-mode switches. BUG=None BRANCH=None TEST=abuild compiles all boards successfully with and without ChromeOS option. Change-Id: I267aadea9e616464563df04b51a668b877f0d578 Signed-off-by: Furquan Shaikh <furquan@chromium.org> Reviewed-on: https://review.coreboot.org/17449 Tested-by: build bot (Jenkins) Reviewed-by: Julius Werner <jwerner@chromium.org>
This commit is contained in:
committed by
Furquan Shaikh
parent
f8a274acf5
commit
cd2afc0df0
@@ -15,12 +15,6 @@
|
||||
*/
|
||||
|
||||
#include <arch/io.h>
|
||||
#include <device/device.h>
|
||||
#include <device/pci.h>
|
||||
#if IS_ENABLED(CONFIG_EC_GOOGLE_CHROMEEC)
|
||||
#include "ec.h"
|
||||
#include <ec/google/chromeec/ec.h>
|
||||
#endif
|
||||
#include <rules.h>
|
||||
#include <soc/gpio.h>
|
||||
#include <string.h>
|
||||
@@ -50,60 +44,6 @@ void fill_lb_gpios(struct lb_gpios *gpios)
|
||||
}
|
||||
#endif /* ENV_RAMSTAGE */
|
||||
|
||||
int get_lid_switch(void)
|
||||
{
|
||||
#if IS_ENABLED(CONFIG_EC_GOOGLE_CHROMEEC)
|
||||
u8 ec_switches;
|
||||
|
||||
mec_io_bytes(0, EC_LPC_ADDR_MEMMAP + EC_MEMMAP_SWITCHES, 1,
|
||||
&ec_switches, NULL);
|
||||
return !!(ec_switches & EC_SWITCH_LID_OPEN);
|
||||
#else
|
||||
/* Default to force open. */
|
||||
return 1;
|
||||
#endif
|
||||
}
|
||||
|
||||
int get_developer_mode_switch(void)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
int get_recovery_mode_switch(void)
|
||||
{
|
||||
#if IS_ENABLED(CONFIG_EC_GOOGLE_CHROMEEC)
|
||||
u8 ec_switches;
|
||||
u32 ec_events;
|
||||
|
||||
mec_io_bytes(0, EC_LPC_ADDR_MEMMAP + EC_MEMMAP_SWITCHES, 1,
|
||||
&ec_switches, NULL);
|
||||
|
||||
/* If a switch is set, we don't need to look at events. */
|
||||
if (ec_switches & (EC_SWITCH_DEDICATED_RECOVERY))
|
||||
return 1;
|
||||
|
||||
/* Else check if the EC has posted the keyboard recovery event. */
|
||||
ec_events = google_chromeec_get_events_b();
|
||||
|
||||
return !!(ec_events &
|
||||
EC_HOST_EVENT_MASK(EC_HOST_EVENT_KEYBOARD_RECOVERY));
|
||||
#else
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
int clear_recovery_mode_switch(void)
|
||||
{
|
||||
#if IS_ENABLED(CONFIG_EC_GOOGLE_CHROMEEC)
|
||||
const uint32_t kb_rec_mask =
|
||||
EC_HOST_EVENT_MASK(EC_HOST_EVENT_KEYBOARD_RECOVERY);
|
||||
/* Unconditionally clear the EC recovery request. */
|
||||
return google_chromeec_clear_events_b(kb_rec_mask);
|
||||
#else
|
||||
return 0;
|
||||
#endif
|
||||
}
|
||||
|
||||
int get_write_protect_state(void)
|
||||
{
|
||||
/*
|
||||
|
Reference in New Issue
Block a user