/* SPDX-License-Identifier: GPL-2.0-only */ /* This file is part of the coreboot project. */ #include #include #include #include #include #include #include void bootblock_mainboard_early_init(void) { size_t num_gpios; const struct soc_amd_gpio *gpios; /* Enable the EC as soon as we have visibility */ mainboard_ec_init(); gpios = variant_wlan_rst_early_gpio_table(&num_gpios); program_gpios(gpios, num_gpios); gpios = variant_early_gpio_table(&num_gpios); program_gpios(gpios, num_gpios); } void bootblock_mainboard_init(void) { if (CONFIG(EM100)) { /* * We should be able to rely on defaults, but it seems safer * to explicitly set up these registers. */ sb_read_mode(SPI_READ_MODE_NOM); sb_set_spi100(SPI_SPEED_16M, /* Normal */ SPI_SPEED_16M, /* Fast */ SPI_SPEED_16M, /* AltIO */ SPI_SPEED_66M); /* TPM */ } else { /* * W25Q128FW Setup * Normal Read 40MHz * Fast Read 104MHz * Dual Read IO (1-2-2) */ sb_read_mode(SPI_READ_MODE_DUAL122); /* Set SPI speeds before verstage. Needed for TPM */ sb_set_spi100(SPI_SPEED_33M, /* Normal */ SPI_SPEED_66M, /* Fast */ SPI_SPEED_66M, /* AltIO */ SPI_SPEED_66M); /* TPM */ } /* Setup TPM decode before verstage */ lpc_tpm_decode_spi(); }