| /* SPDX-License-Identifier: GPL-2.0-only */ |
| |
| #include <bootblock_common.h> |
| #include <device/pnp_ops.h> |
| #include <mainboard/gpio.h> |
| #include <soc/gpio.h> |
| #include <superio/nuvoton/common/nuvoton.h> |
| #include <superio/nuvoton/nct6687d/nct6687d.h> |
| |
| #define SERIAL_DEV PNP_DEV(0x2e, NCT6687D_SP1) |
| #define POWER_DEV PNP_DEV(0x2e, NCT6687D_SLEEP_PWR) |
| |
| void bootblock_mainboard_early_init(void) |
| { |
| mainboard_configure_early_gpios(); |
| |
| /* Replicate vendor settings for multi-function pins in global config LDN */ |
| nuvoton_pnp_enter_conf_state(SERIAL_DEV); |
| pnp_write_config(SERIAL_DEV, 0x13, 0x0c); |
| pnp_write_config(SERIAL_DEV, 0x1d, 0x08); |
| pnp_write_config(SERIAL_DEV, 0x1f, 0xf0); |
| pnp_write_config(SERIAL_DEV, 0x22, 0xbc); |
| pnp_write_config(SERIAL_DEV, 0x23, 0xdf); |
| pnp_write_config(SERIAL_DEV, 0x24, 0x81); |
| pnp_write_config(SERIAL_DEV, 0x25, 0xff); |
| pnp_write_config(SERIAL_DEV, 0x29, 0x6d); |
| pnp_write_config(SERIAL_DEV, 0x2a, 0x8f); |
| |
| /* Configure pin for PECI */ |
| pnp_set_logical_device(POWER_DEV); |
| pnp_write_config(POWER_DEV, 0xf3, 0x0c); |
| |
| nuvoton_pnp_exit_conf_state(POWER_DEV); |
| |
| /* Enable serial */ |
| if (CONFIG(CONSOLE_SERIAL)) |
| nuvoton_enable_serial(SERIAL_DEV, CONFIG_TTYS0_BASE); |
| } |