/* SPDX-License-Identifier: GPL-2.0-only */ /* This file is part of the coreboot project. */ #include #include #include #include #include #include #include #if CONFIG(FSP_CAR) #include const FSPT_UPD temp_ram_init_params = { .FspUpdHeader = { .Signature = 0x545F4450554C4643ULL, /* 'CFLUPD_T' */ .Revision = 1, .Reserved = {0}, }, .FsptCoreUpd = { /* * It is a requirement for firmware to have Firmware Interface Table * (FIT), which contains pointers to each microcode update. * The microcode update is loaded for all logical processors before * cpu reset vector. * * All SoC since Gen-4 has above mechanism in place to load microcode * even before hitting CPU reset vector. Hence skipping FSP-T loading * microcode after CPU reset by passing '0' value to * FSPT_UPD.MicrocodeRegionBase and FSPT_UPD.MicrocodeRegionSize. * * Note: CodeRegionSize must be smaller than or equal to 16MiB to not * overlap with LAPIC or the CAR area at 0xfef00000. */ .MicrocodeRegionBase = 0, .MicrocodeRegionSize = 0, .CodeRegionBase = (uint32_t)0x100000000ULL - CACHE_ROM_SIZE, .CodeRegionSize = (uint32_t)CACHE_ROM_SIZE, }, }; #endif asmlinkage void bootblock_c_entry(uint64_t base_timestamp) { /* Call lib/bootblock.c main */ bootblock_main_with_basetime(base_timestamp); } void bootblock_soc_early_init(void) { bootblock_systemagent_early_init(); bootblock_pch_early_init(); bootblock_cpu_init(); pch_early_iorange_init(); if (CONFIG(INTEL_LPSS_UART_FOR_CONSOLE)) uart_bootblock_init(); } void bootblock_soc_init(void) { /* * Clear the GPI interrupt status and enable registers. These * registers do not get reset to default state when booting from S5. */ gpi_clear_int_cfg(); report_platform_info(); bootblock_pch_init(); }