ChromeEC is getting ready to bump up the hostevents and wake masks to 64-bits. The current commands to program hostevents/wake masks will still operate on 32-bits only. A new EC host command will be added to handle 64-bit hostevents/wake masks. In order to prevent individual callers in coreboot from worrying about 32-bit/64-bit, the same API provided by google/chromeec will be updated to accept 64-bit parameters and return 64-bit values. Internally, host command handlers will take care of masking these parameters/return values to appropriate 32-bit/64-bit values. BUG=b:69329196 Change-Id: If59f3f2b1a2aa5ce95883df3e72efc4a32de1190 Signed-off-by: Furquan Shaikh <furquan@chromium.org> Reviewed-on: https://review.coreboot.org/22551 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Aaron Durbin <adurbin@chromium.org>
84 lines
2.4 KiB
C
84 lines
2.4 KiB
C
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* Copyright 2013 Google Inc.
|
|
*
|
|
* 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 <boot/coreboot_tables.h>
|
|
#include <console/console.h>
|
|
#include <ec/google/chromeec/ec.h>
|
|
#include <ec/google/chromeec/ec_commands.h>
|
|
#include <soc/cpu.h>
|
|
#include <soc/gpio.h>
|
|
#include <string.h>
|
|
#include <vendorcode/google/chromeos/chromeos.h>
|
|
#include <bootmode.h>
|
|
|
|
void fill_lb_gpios(struct lb_gpios *gpios)
|
|
{
|
|
int count = 0;
|
|
|
|
/* Write Protect: active low */
|
|
gpios->gpios[count].port = EXYNOS5_GPD1;
|
|
gpios->gpios[count].polarity = ACTIVE_LOW;
|
|
gpios->gpios[count].value = gpio_get_value(GPIO_D16); // WP_GPIO
|
|
strncpy((char *)gpios->gpios[count].name, "write protect",
|
|
GPIO_MAX_NAME_LENGTH);
|
|
count++;
|
|
|
|
/* Recovery: active low */
|
|
gpios->gpios[count].port = -1;
|
|
gpios->gpios[count].polarity = ACTIVE_HIGH;
|
|
gpios->gpios[count].value = get_recovery_mode_switch();
|
|
strncpy((char *)gpios->gpios[count].name, "recovery",
|
|
GPIO_MAX_NAME_LENGTH);
|
|
count++;
|
|
|
|
/* Lid: active high */
|
|
gpios->gpios[count].port = EXYNOS5_GPX3;
|
|
gpios->gpios[count].polarity = ACTIVE_HIGH;
|
|
gpios->gpios[count].value = gpio_get_value(GPIO_X35); // LID_GPIO
|
|
strncpy((char *)gpios->gpios[count].name, "lid", GPIO_MAX_NAME_LENGTH);
|
|
count++;
|
|
|
|
/* Power: virtual GPIO active low */
|
|
gpios->gpios[count].port = EXYNOS5_GPX1;
|
|
gpios->gpios[count].polarity = ACTIVE_LOW;
|
|
gpios->gpios[count].value =
|
|
gpio_get_value(GPIO_X13); // POWER_GPIO
|
|
strncpy((char *)gpios->gpios[count].name, "power",
|
|
GPIO_MAX_NAME_LENGTH);
|
|
count++;
|
|
|
|
gpios->size = sizeof(*gpios) + (count * sizeof(struct lb_gpio));
|
|
gpios->count = count;
|
|
|
|
printk(BIOS_ERR, "Added %d GPIOS size %d\n", count, gpios->size);
|
|
}
|
|
|
|
int get_recovery_mode_switch(void)
|
|
{
|
|
uint64_t ec_events;
|
|
|
|
/* The GPIO is active low. */
|
|
if (!gpio_get_value(GPIO_Y10)) // RECMODE_GPIO
|
|
return 1;
|
|
|
|
ec_events = google_chromeec_get_events_b();
|
|
return !!(ec_events &
|
|
EC_HOST_EVENT_MASK(EC_HOST_EVENT_KEYBOARD_RECOVERY));
|
|
}
|
|
|
|
int get_write_protect_state(void)
|
|
{
|
|
return !gpio_get_value(GPIO_D16);
|
|
}
|