2016-09-16 23:15:14 +02:00
|
|
|
/*
|
|
|
|
* This file is part of the coreboot project.
|
|
|
|
*
|
|
|
|
* Copyright 2016 Google, Inc.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; version 2 of the License.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*/
|
|
|
|
|
2016-09-16 23:23:21 +02:00
|
|
|
#include <cbmem.h>
|
2016-09-16 23:15:14 +02:00
|
|
|
#include <console/console.h>
|
|
|
|
#include <main_decl.h>
|
|
|
|
#include <program_loading.h>
|
|
|
|
#include <soc/intel/common/util.h>
|
2016-10-18 20:35:15 +02:00
|
|
|
#include <fsp/util.h>
|
2016-09-16 23:15:14 +02:00
|
|
|
|
|
|
|
void main(void)
|
|
|
|
{
|
2016-10-18 20:35:15 +02:00
|
|
|
/* Call TempRamExit FSP API if enabled. */
|
|
|
|
if (IS_ENABLED(CONFIG_FSP_CAR))
|
|
|
|
fsp_temp_ram_exit();
|
|
|
|
|
2016-09-16 23:15:14 +02:00
|
|
|
console_init();
|
|
|
|
|
2016-09-16 23:23:21 +02:00
|
|
|
/* Recover cbmem so infrastruture using it is functional. */
|
|
|
|
cbmem_initialize();
|
|
|
|
|
2016-09-16 23:15:14 +02:00
|
|
|
/* Display the MTRRs */
|
|
|
|
if (IS_ENABLED(CONFIG_DISPLAY_MTRRS))
|
|
|
|
soc_display_mtrrs();
|
|
|
|
|
|
|
|
/* Load and run ramstage. */
|
|
|
|
run_ramstage();
|
|
|
|
}
|