mb/google/{poppy,eve,fizz}: Configure GPIOs in mainboard chip->init()
mainboard_silicon_init_params() is supposed to be used for only overriding any FSP params as per mainboard configuration. GPIOs should be configured by mainboard as part of its chip init(). This ensures proper ordering w.r.t. any common operations that the SoC code might want to perform e.g. snapshot ITSS polarities. This change moves the configuration of GPIOs from mainboard_silicon_init_params() to mainboard chip->init(). Change-Id: Ied0201b954894acd3503801e7739b91a2cc9b4a8 Signed-off-by: Furquan Shaikh <furquan@google.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/36268 Reviewed-by: Aaron Durbin <adurbin@chromium.org> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
80212aa104
commit
fb9f320d81
8 changed files with 70 additions and 102 deletions
|
@ -23,7 +23,6 @@ romstage-$(CONFIG_CHROMEOS) += chromeos.c
|
||||||
ramstage-$(CONFIG_CHROMEOS) += chromeos.c
|
ramstage-$(CONFIG_CHROMEOS) += chromeos.c
|
||||||
|
|
||||||
ramstage-y += mainboard.c
|
ramstage-y += mainboard.c
|
||||||
ramstage-y += ramstage.c
|
|
||||||
ramstage-$(CONFIG_EC_GOOGLE_CHROMEEC) += ec.c
|
ramstage-$(CONFIG_EC_GOOGLE_CHROMEEC) += ec.c
|
||||||
|
|
||||||
smm-y += smihandler.c
|
smm-y += smihandler.c
|
||||||
|
|
|
@ -21,6 +21,8 @@
|
||||||
#include <vendorcode/google/chromeos/chromeos.h>
|
#include <vendorcode/google/chromeos/chromeos.h>
|
||||||
#include <soc/nhlt.h>
|
#include <soc/nhlt.h>
|
||||||
|
|
||||||
|
#include "gpio.h"
|
||||||
|
|
||||||
#define SUBSYSTEM_ID 0x1AE0006B
|
#define SUBSYSTEM_ID 0x1AE0006B
|
||||||
|
|
||||||
static const char *oem_id_maxim = "GOOGLE";
|
static const char *oem_id_maxim = "GOOGLE";
|
||||||
|
@ -74,6 +76,12 @@ static void mainboard_enable(struct device *dev)
|
||||||
dev->ops->write_acpi_tables = mainboard_write_acpi_tables;
|
dev->ops->write_acpi_tables = mainboard_write_acpi_tables;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void mainboard_chip_init(void *chip_info)
|
||||||
|
{
|
||||||
|
gpio_configure_pads(gpio_table, ARRAY_SIZE(gpio_table));
|
||||||
|
}
|
||||||
|
|
||||||
struct chip_operations mainboard_ops = {
|
struct chip_operations mainboard_ops = {
|
||||||
|
.init = mainboard_chip_init,
|
||||||
.enable_dev = mainboard_enable,
|
.enable_dev = mainboard_enable,
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,23 +0,0 @@
|
||||||
/*
|
|
||||||
* This file is part of the coreboot project.
|
|
||||||
*
|
|
||||||
* Copyright (C) 2016 Google Inc.
|
|
||||||
* Copyright (C) 2016 Intel Corporation
|
|
||||||
*
|
|
||||||
* 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 <soc/ramstage.h>
|
|
||||||
#include "gpio.h"
|
|
||||||
|
|
||||||
void mainboard_silicon_init_params(FSP_SIL_UPD *params)
|
|
||||||
{
|
|
||||||
gpio_configure_pads(gpio_table, ARRAY_SIZE(gpio_table));
|
|
||||||
}
|
|
|
@ -23,7 +23,6 @@ romstage-$(CONFIG_CHROMEOS) += chromeos.c
|
||||||
ramstage-$(CONFIG_CHROMEOS) += chromeos.c
|
ramstage-$(CONFIG_CHROMEOS) += chromeos.c
|
||||||
ramstage-$(CONFIG_EC_GOOGLE_CHROMEEC) += ec.c
|
ramstage-$(CONFIG_EC_GOOGLE_CHROMEEC) += ec.c
|
||||||
ramstage-y += mainboard.c
|
ramstage-y += mainboard.c
|
||||||
ramstage-y += ramstage.c
|
|
||||||
|
|
||||||
smm-y += smihandler.c
|
smm-y += smihandler.c
|
||||||
|
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
#include <arch/acpi.h>
|
#include <arch/acpi.h>
|
||||||
#include <baseboard/variants.h>
|
#include <baseboard/variants.h>
|
||||||
#include <chip.h>
|
#include <chip.h>
|
||||||
|
#include <delay.h>
|
||||||
#include <device/device.h>
|
#include <device/device.h>
|
||||||
#include <ec/ec.h>
|
#include <ec/ec.h>
|
||||||
#include <ec/google/chromeec/ec.h>
|
#include <ec/google/chromeec/ec.h>
|
||||||
|
@ -26,8 +27,11 @@
|
||||||
#include <soc/pci_devs.h>
|
#include <soc/pci_devs.h>
|
||||||
#include <soc/nhlt.h>
|
#include <soc/nhlt.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <timer.h>
|
||||||
#include <vendorcode/google/chromeos/chromeos.h>
|
#include <vendorcode/google/chromeos/chromeos.h>
|
||||||
|
|
||||||
|
#include <variant/gpio.h>
|
||||||
|
|
||||||
#define FIZZ_SKU_ID_I7_U42 0x4
|
#define FIZZ_SKU_ID_I7_U42 0x4
|
||||||
#define FIZZ_SKU_ID_I5_U42 0x5
|
#define FIZZ_SKU_ID_I5_U42 0x5
|
||||||
#define FIZZ_SKU_ID_I3_U42 0x6
|
#define FIZZ_SKU_ID_I3_U42 0x6
|
||||||
|
@ -230,6 +234,50 @@ static void mainboard_enable(struct device *dev)
|
||||||
dev->ops->write_acpi_tables = mainboard_write_acpi_tables;
|
dev->ops->write_acpi_tables = mainboard_write_acpi_tables;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define GPIO_HDMI_HPD GPP_E13
|
||||||
|
#define GPIO_DP_HPD GPP_E14
|
||||||
|
|
||||||
|
/* TODO: This can be moved to common directory */
|
||||||
|
static void wait_for_hpd(gpio_t gpio, long timeout)
|
||||||
|
{
|
||||||
|
struct stopwatch sw;
|
||||||
|
|
||||||
|
printk(BIOS_INFO, "Waiting for HPD\n");
|
||||||
|
gpio_input(gpio);
|
||||||
|
|
||||||
|
stopwatch_init_msecs_expire(&sw, timeout);
|
||||||
|
while (!gpio_get(gpio)) {
|
||||||
|
if (stopwatch_expired(&sw)) {
|
||||||
|
printk(BIOS_WARNING,
|
||||||
|
"HPD not ready after %ldms. Abort.\n", timeout);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
mdelay(200);
|
||||||
|
}
|
||||||
|
printk(BIOS_INFO, "HPD ready after %lu ms\n",
|
||||||
|
stopwatch_duration_msecs(&sw));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void mainboard_chip_init(void *chip_info)
|
||||||
|
{
|
||||||
|
const struct pad_config *pads;
|
||||||
|
size_t num;
|
||||||
|
static const long display_timeout_ms = 3000;
|
||||||
|
|
||||||
|
/* This is reconfigured back to whatever FSP-S expects by
|
||||||
|
gpio_configure_pads. */
|
||||||
|
gpio_input(GPIO_HDMI_HPD);
|
||||||
|
if (display_init_required() && !gpio_get(GPIO_HDMI_HPD)) {
|
||||||
|
/* This has to be done before FSP-S runs. */
|
||||||
|
if (google_chromeec_wait_for_displayport(display_timeout_ms))
|
||||||
|
wait_for_hpd(GPIO_DP_HPD, display_timeout_ms);
|
||||||
|
}
|
||||||
|
|
||||||
|
pads = variant_gpio_table(&num);
|
||||||
|
gpio_configure_pads(pads, num);
|
||||||
|
}
|
||||||
|
|
||||||
struct chip_operations mainboard_ops = {
|
struct chip_operations mainboard_ops = {
|
||||||
|
.init = mainboard_chip_init,
|
||||||
.enable_dev = mainboard_enable,
|
.enable_dev = mainboard_enable,
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,69 +0,0 @@
|
||||||
/*
|
|
||||||
* This file is part of the coreboot project.
|
|
||||||
*
|
|
||||||
* Copyright (C) 2017 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 <baseboard/variants.h>
|
|
||||||
#include <bootmode.h>
|
|
||||||
#include <console/console.h>
|
|
||||||
#include <delay.h>
|
|
||||||
#include <ec/google/chromeec/ec.h>
|
|
||||||
#include <gpio.h>
|
|
||||||
#include <soc/gpio.h>
|
|
||||||
#include <soc/ramstage.h>
|
|
||||||
#include <timer.h>
|
|
||||||
|
|
||||||
#include <variant/gpio.h>
|
|
||||||
|
|
||||||
#define GPIO_HDMI_HPD GPP_E13
|
|
||||||
#define GPIO_DP_HPD GPP_E14
|
|
||||||
|
|
||||||
/* TODO: This can be moved to common directory */
|
|
||||||
static void wait_for_hpd(gpio_t gpio, long timeout)
|
|
||||||
{
|
|
||||||
struct stopwatch sw;
|
|
||||||
|
|
||||||
printk(BIOS_INFO, "Waiting for HPD\n");
|
|
||||||
gpio_input(gpio);
|
|
||||||
|
|
||||||
stopwatch_init_msecs_expire(&sw, timeout);
|
|
||||||
while (!gpio_get(gpio)) {
|
|
||||||
if (stopwatch_expired(&sw)) {
|
|
||||||
printk(BIOS_WARNING,
|
|
||||||
"HPD not ready after %ldms. Abort.\n", timeout);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
mdelay(200);
|
|
||||||
}
|
|
||||||
printk(BIOS_INFO, "HPD ready after %lu ms\n",
|
|
||||||
stopwatch_duration_msecs(&sw));
|
|
||||||
}
|
|
||||||
|
|
||||||
void mainboard_silicon_init_params(FSP_SIL_UPD *params)
|
|
||||||
{
|
|
||||||
const struct pad_config *pads;
|
|
||||||
size_t num;
|
|
||||||
static const long display_timeout_ms = 3000;
|
|
||||||
|
|
||||||
/* This is reconfigured back to whatever FSP-S expects by
|
|
||||||
gpio_configure_pads. */
|
|
||||||
gpio_input(GPIO_HDMI_HPD);
|
|
||||||
if (display_init_required() && !gpio_get(GPIO_HDMI_HPD)) {
|
|
||||||
/* This has to be done before FSP-S runs. */
|
|
||||||
if (google_chromeec_wait_for_displayport(display_timeout_ms))
|
|
||||||
wait_for_hpd(GPIO_DP_HPD, display_timeout_ms);
|
|
||||||
}
|
|
||||||
|
|
||||||
pads = variant_gpio_table(&num);
|
|
||||||
gpio_configure_pads(pads, num);
|
|
||||||
}
|
|
|
@ -21,6 +21,8 @@
|
||||||
#include <soc/nhlt.h>
|
#include <soc/nhlt.h>
|
||||||
#include <vendorcode/google/chromeos/chromeos.h>
|
#include <vendorcode/google/chromeos/chromeos.h>
|
||||||
|
|
||||||
|
#include <variant/gpio.h>
|
||||||
|
|
||||||
static void mainboard_init(struct device *dev)
|
static void mainboard_init(struct device *dev)
|
||||||
{
|
{
|
||||||
mainboard_ec_init();
|
mainboard_ec_init();
|
||||||
|
@ -62,6 +64,18 @@ static void mainboard_enable(struct device *dev)
|
||||||
dev->ops->write_acpi_tables = mainboard_write_acpi_tables;
|
dev->ops->write_acpi_tables = mainboard_write_acpi_tables;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void mainboard_chip_init(void *chip_info)
|
||||||
|
{
|
||||||
|
const struct pad_config *pads;
|
||||||
|
size_t num;
|
||||||
|
|
||||||
|
pads = variant_gpio_table(&num);
|
||||||
|
gpio_configure_pads(pads, num);
|
||||||
|
pads = variant_sku_gpio_table(&num);
|
||||||
|
gpio_configure_pads(pads, num);
|
||||||
|
}
|
||||||
|
|
||||||
struct chip_operations mainboard_ops = {
|
struct chip_operations mainboard_ops = {
|
||||||
|
.init = mainboard_chip_init,
|
||||||
.enable_dev = mainboard_enable,
|
.enable_dev = mainboard_enable,
|
||||||
};
|
};
|
||||||
|
|
|
@ -16,17 +16,9 @@
|
||||||
#include <baseboard/variants.h>
|
#include <baseboard/variants.h>
|
||||||
#include <soc/ramstage.h>
|
#include <soc/ramstage.h>
|
||||||
|
|
||||||
#include <variant/gpio.h>
|
|
||||||
|
|
||||||
void mainboard_silicon_init_params(FSP_SIL_UPD *params)
|
void mainboard_silicon_init_params(FSP_SIL_UPD *params)
|
||||||
{
|
{
|
||||||
const struct pad_config *pads;
|
|
||||||
size_t num;
|
|
||||||
variant_devtree_update();
|
variant_devtree_update();
|
||||||
pads = variant_gpio_table(&num);
|
|
||||||
gpio_configure_pads(pads, num);
|
|
||||||
pads = variant_sku_gpio_table(&num);
|
|
||||||
gpio_configure_pads(pads, num);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void __weak variant_devtree_update(void)
|
void __weak variant_devtree_update(void)
|
||||||
|
|
Loading…
Reference in a new issue