blob: 0add4535b27cc58984c00643473f3c13295f028b [file] [log] [blame]
Angel Pons08b52802020-04-05 13:22:20 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Hannah Williams5e83e8b2018-02-09 18:35:17 -08002
3#include <baseboard/variants.h>
4#include <bootblock_common.h>
5#include <ec/ec.h>
6#include <intelblocks/lpc_lib.h>
7#include <soc/gpio.h>
8
9void bootblock_mainboard_init(void)
10{
Marco Chen8a6174d2019-07-15 08:50:35 +080011 const struct pad_config *pads, *override_pads;
12 size_t num, override_num;
Hannah Williams5e83e8b2018-02-09 18:35:17 -080013
Hannah Williamscf458302018-01-09 18:23:40 -080014 lpc_configure_pads();
Furquan Shaikh4dc66462018-07-27 14:14:27 -070015
16 /*
17 * Perform EC init before configuring GPIOs. This is because variant
18 * might talk to the EC to get board id and hence it will require EC
19 * init to have already performed.
20 */
21 mainboard_ec_init();
22
Hannah Williams5e83e8b2018-02-09 18:35:17 -080023 pads = variant_early_gpio_table(&num);
Marco Chen8a6174d2019-07-15 08:50:35 +080024 override_pads = variant_early_override_gpio_table(&override_num);
25 gpio_configure_pads_with_override(pads, num,
26 override_pads, override_num);
Hannah Williams5e83e8b2018-02-09 18:35:17 -080027}