blob: 7756b04f923edf833864d0cd05ef598b6c0f994e [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0-or-later */
#include <bootblock_common.h>
#include <superio/ite/common/ite.h>
#include <superio/ite/it8786e/it8786e.h>
#define GPIO_DEV PNP_DEV(0x2e, IT8786E_GPIO)
#define SERIAL1_DEV PNP_DEV(0x2e, IT8786E_SP1)
#define SERIAL3_DEV PNP_DEV(0x2e, IT8786E_SP3)
#define SERIAL4_DEV PNP_DEV(0x2e, IT8786E_SP4)
#define SERIAL5_DEV PNP_DEV(0x2e, IT8786E_SP5)
#define SERIAL6_DEV PNP_DEV(0x2e, IT8786E_SP6)
void bootblock_mainboard_early_init(void)
{
ite_conf_clkin(GPIO_DEV, ITE_UART_CLK_PREDIVIDE_24);
ite_enable_3vsbsw(GPIO_DEV);
ite_kill_watchdog(GPIO_DEV);
ite_enable_serial(SERIAL1_DEV, CONFIG_TTYS0_BASE);
/*
* FIXME:
* IT8786E has 6 COM ports, COM1/3/5 have default IO base 0x3f8 and
* COM2/4/6 have 0x2f8. When enabling devices before setting resources
* from devicetree, the output on debugging COM1 becomes very slow due
* to the same IO bases for multiple COM ports. For now set different
* hardcoded IO bases for COM3/4/5/6 ports, they will be set later to
* desired values from devicetree. They can be also turned off.
*/
ite_enable_serial(SERIAL3_DEV, 0x3e8);
ite_enable_serial(SERIAL4_DEV, 0x2e8);
ite_enable_serial(SERIAL5_DEV, 0x2f0);
ite_enable_serial(SERIAL6_DEV, 0x2e0);
}