2015-05-12 02:24:31 +02:00
|
|
|
/*
|
|
|
|
* This file is part of the coreboot project.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2013 Google Inc.
|
|
|
|
* 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/io.h>
|
|
|
|
#include <rules.h>
|
|
|
|
#include <soc/gpio.h>
|
|
|
|
#include <string.h>
|
|
|
|
#include <vendorcode/google/chromeos/chromeos.h>
|
|
|
|
|
|
|
|
/* The WP status pin lives on MF_ISH_GPIO_4 */
|
|
|
|
#define WP_STATUS_PAD_CFG0 0x4838
|
|
|
|
#define WP_STATUS_PAD_CFG1 0x483C
|
|
|
|
|
|
|
|
#if ENV_RAMSTAGE
|
|
|
|
#include <boot/coreboot_tables.h>
|
|
|
|
|
|
|
|
#define ACTIVE_LOW 0
|
|
|
|
#define ACTIVE_HIGH 1
|
|
|
|
|
|
|
|
void fill_lb_gpios(struct lb_gpios *gpios)
|
|
|
|
{
|
chromeos: Simplify fill_lb_gpios even further
A long time ago many Chrome OS boards had pages full of duplicated
boilerplate code for the fill_lb_gpios() function, and we spent a lot of
time bikeshedding a proper solution that passes a table of lb_gpio
structs which can be concisely written with a static struct initializer
in http://crosreview.com/234648. Unfortunately we never really finished
that patch and in the mean time a different solution using the
fill_lb_gpio() helper got standardized onto most boards.
Still, that solution is not quite as clean and concise as the one we had
already designed, and it also wasn't applied consistently to all recent
boards (causing more boards with bad code to get added afterwards). This
patch switches all boards newer than Link to the better solution and
also adds some nicer debug output for the GPIOs while I'm there.
If more boards need to be converted from fill_lb_gpio() to this model
later (e.g. from a branch), it's quite easy to do with:
s/fill_lb_gpio(gpio++,\n\?\s*\([^,]*\),\n\?\s*\([^,]*\),\n\?\s*\([^,]*\),\n\?\s*\([^,]*\));/\t{\1, \2, \4, \3},/
Based on a patch by Furquan Shaikh <furquan@google.com>.
BUG=None
BRANCH=None
TEST=Booted on Oak. Ran abuild -x.
Change-Id: I449974d1c75c8ed187f5e10935495b2f03725811
Signed-off-by: Julius Werner <jwerner@chromium.org>
Reviewed-on: https://review.coreboot.org/14226
Tested-by: build bot (Jenkins)
Reviewed-by: David Hendricks <dhendrix@chromium.org>
2016-04-01 02:27:05 +02:00
|
|
|
struct lb_gpio chromeos_gpios[] = {
|
|
|
|
{-1, ACTIVE_HIGH, get_write_protect_state(), "write protect"},
|
2016-07-25 22:02:36 +02:00
|
|
|
{-1, ACTIVE_HIGH, vboot_recovery_mode_enabled(), "recovery"},
|
chromeos: Simplify fill_lb_gpios even further
A long time ago many Chrome OS boards had pages full of duplicated
boilerplate code for the fill_lb_gpios() function, and we spent a lot of
time bikeshedding a proper solution that passes a table of lb_gpio
structs which can be concisely written with a static struct initializer
in http://crosreview.com/234648. Unfortunately we never really finished
that patch and in the mean time a different solution using the
fill_lb_gpio() helper got standardized onto most boards.
Still, that solution is not quite as clean and concise as the one we had
already designed, and it also wasn't applied consistently to all recent
boards (causing more boards with bad code to get added afterwards). This
patch switches all boards newer than Link to the better solution and
also adds some nicer debug output for the GPIOs while I'm there.
If more boards need to be converted from fill_lb_gpio() to this model
later (e.g. from a branch), it's quite easy to do with:
s/fill_lb_gpio(gpio++,\n\?\s*\([^,]*\),\n\?\s*\([^,]*\),\n\?\s*\([^,]*\),\n\?\s*\([^,]*\));/\t{\1, \2, \4, \3},/
Based on a patch by Furquan Shaikh <furquan@google.com>.
BUG=None
BRANCH=None
TEST=Booted on Oak. Ran abuild -x.
Change-Id: I449974d1c75c8ed187f5e10935495b2f03725811
Signed-off-by: Julius Werner <jwerner@chromium.org>
Reviewed-on: https://review.coreboot.org/14226
Tested-by: build bot (Jenkins)
Reviewed-by: David Hendricks <dhendrix@chromium.org>
2016-04-01 02:27:05 +02:00
|
|
|
{-1, ACTIVE_HIGH, get_developer_mode_switch(), "developer"},
|
|
|
|
{-1, ACTIVE_HIGH, get_lid_switch(), "lid"},
|
|
|
|
{-1, ACTIVE_HIGH, 0, "power"},
|
|
|
|
{-1, ACTIVE_HIGH, gfx_get_init_done(), "oprom"},
|
|
|
|
};
|
|
|
|
lb_add_gpios(gpios, chromeos_gpios, ARRAY_SIZE(chromeos_gpios));
|
2015-05-12 02:24:31 +02:00
|
|
|
}
|
|
|
|
#endif /* ENV_RAMSTAGE */
|
|
|
|
|
|
|
|
int get_write_protect_state(void)
|
|
|
|
{
|
|
|
|
/*
|
|
|
|
* The vboot loader queries this function in romstage. The GPIOs have
|
|
|
|
* not been set up yet as that configuration is done in ramstage.
|
|
|
|
* Configuring this GPIO as input so that there isn't any ambiguity
|
|
|
|
* in the reading.
|
|
|
|
*/
|
|
|
|
#if ENV_ROMSTAGE
|
|
|
|
write32((void *)(COMMUNITY_GPEAST_BASE + WP_STATUS_PAD_CFG0),
|
|
|
|
(PAD_PULL_UP_20K | PAD_GPIO_ENABLE | PAD_CONFIG0_GPI_DEFAULT));
|
|
|
|
write32((void *)(COMMUNITY_GPEAST_BASE + WP_STATUS_PAD_CFG1),
|
|
|
|
PAD_CONFIG1_DEFAULT0);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* WP is enabled when the pin is reading high. */
|
|
|
|
return (read32((void *)(COMMUNITY_GPEAST_BASE + WP_STATUS_PAD_CFG0))
|
|
|
|
& PAD_VAL_HIGH);
|
|
|
|
}
|
2016-07-26 04:31:41 +02:00
|
|
|
|
|
|
|
static const struct cros_gpio cros_gpios[] = {
|
|
|
|
CROS_GPIO_REC_AL(CROS_GPIO_VIRTUAL, CROS_GPIO_DEVICE_NAME),
|
|
|
|
CROS_GPIO_WP_AH(0x10013, CROS_GPIO_DEVICE_NAME),
|
|
|
|
};
|
|
|
|
|
|
|
|
void mainboard_chromeos_acpi_generate(void)
|
|
|
|
{
|
|
|
|
chromeos_acpi_gpio_generate(cros_gpios, ARRAY_SIZE(cros_gpios));
|
|
|
|
}
|