blob: b8086a42abfe56f2eb7ab7f001248144e09dd44d [file] [log] [blame]
Angel Pons16f6aa82020-04-05 15:47:21 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Subrata Banik930c31c2019-11-01 18:12:58 +05302
3#include <bootblock_common.h>
Angel Pons5d98dab2021-02-19 22:01:55 +01004#include <intelblocks/fast_spi.h>
Subrata Banik930c31c2019-11-01 18:12:58 +05305#include <intelblocks/systemagent.h>
Tim Wawrzynczakbb50c672020-07-08 17:05:32 -06006#include <intelblocks/tco.h>
Subrata Banik930c31c2019-11-01 18:12:58 +05307#include <intelblocks/uart.h>
8#include <soc/bootblock.h>
Subrata Banik930c31c2019-11-01 18:12:58 +05309
10asmlinkage void bootblock_c_entry(uint64_t base_timestamp)
11{
12 /* Call lib/bootblock.c main */
13 bootblock_main_with_basetime(base_timestamp);
14}
15
16void bootblock_soc_early_init(void)
17{
18 bootblock_systemagent_early_init();
19 bootblock_pch_early_init();
Angel Pons5d98dab2021-02-19 22:01:55 +010020 fast_spi_cache_bios_region();
Subrata Banik930c31c2019-11-01 18:12:58 +053021 pch_early_iorange_init();
22 if (CONFIG(INTEL_LPSS_UART_FOR_CONSOLE))
23 uart_bootblock_init();
24}
25
26void bootblock_soc_init(void)
27{
28 report_platform_info();
Alexey Buyanov12016962020-07-28 19:59:45 -070029 bootblock_pch_init();
Tim Wawrzynczakbb50c672020-07-08 17:05:32 -060030
31 /* Programming TCO_BASE_ADDRESS and TCO Timer Halt */
32 tco_configure();
Subrata Banik930c31c2019-11-01 18:12:58 +053033}