08eca5dcc3
There was the potential for misuse of the override early GPIO table, because if the override early GPIO table did not have a corresponding entry in the base table, it would not get overridden, and there was no way to know except manual inspection (this has already happened here), so now all hatch mainboards are required to explicitly list out all of their required early GPIOs. TEST=booted several hatch boards, verified that they can communicate with TPM and successfully train memory Change-Id: I0552b08a284fd6fb41a09fef431a0d006b0cf0bd Signed-off-by: Tim Wawrzynczak <twawrzynczak@chromium.org> Reviewed-on: https://review.coreboot.org/c/coreboot/+/34782 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Furquan Shaikh <furquan@google.com> Reviewed-by: Paul Fagerburg <pfagerburg@chromium.org>
32 lines
923 B
C
32 lines
923 B
C
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* Copyright 2018 Google LLC
|
|
*
|
|
* 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 <bootblock_common.h>
|
|
#include <soc/gpio.h>
|
|
|
|
static void early_config_gpio(void)
|
|
{
|
|
const struct pad_config *variant_early_table;
|
|
size_t variant_gpios;
|
|
|
|
variant_early_table = variant_early_gpio_table(&variant_gpios);
|
|
gpio_configure_pads(variant_early_table, variant_gpios);
|
|
}
|
|
|
|
void bootblock_mainboard_init(void)
|
|
{
|
|
early_config_gpio();
|
|
}
|