1222a73205
Add Initial pieces of code to support fsp2.0 in skylake keeping the fsp1.1 flow intact. The soc/romstage.h and soc/ramstage.h have a reference to fsp driver includes, so split these header files for each version of FSP driver. Add the below files, car_stage.S: Add romstage entry point (car_stage_entry). This calls into romstage_fsp20.c and aslo handles the car teardown. romstage_fsp20.c: Call fsp_memory_init() and also has the callback for filling memory init parameters. Also add monotonic_timer.c to verstage. With this patchset and relevant change in kunimitsu mainboard, we are able to boot to romstage. TEST= Build and Boot Kunimitsu with PLATFORM_USES_FSP1_1 Build and Boot Kunimitsu to romstage with PLATFORM_USES_FSP2_0 Change-Id: I4309c8d4369c84d2bd1b13e8ab7bfeaaec645520 Signed-off-by: Rizwan Qureshi <rizwan.qureshi@intel.com> Reviewed-on: https://review.coreboot.org/16267 Reviewed-by: Aaron Durbin <adurbin@chromium.org> Tested-by: build bot (Jenkins)
49 lines
1.5 KiB
C
49 lines
1.5 KiB
C
/*
|
|
* This file is part of the coreboot project.
|
|
*
|
|
* Copyright (C) 2016 Intel Corporation.
|
|
*
|
|
* 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.
|
|
*/
|
|
|
|
#include <console/console.h>
|
|
#include <soc/ramstage.h>
|
|
#include <fsp/gop.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
|
|
int init_igd_opregion(igd_opregion_t *opregion)
|
|
{
|
|
const optionrom_vbt_t *vbt;
|
|
uint32_t vbt_len;
|
|
|
|
memset(opregion, 0, sizeof(igd_opregion_t));
|
|
|
|
/* Read VBT table from flash */
|
|
vbt = fsp_get_vbt(&vbt_len);
|
|
if (!vbt)
|
|
die("vbt data not found");
|
|
|
|
memcpy(&opregion->header.signature, IGD_OPREGION_SIGNATURE,
|
|
sizeof(IGD_OPREGION_SIGNATURE) - 1);
|
|
memcpy(opregion->header.vbios_version, vbt->coreblock_biosbuild, sizeof(u32));
|
|
memcpy(opregion->vbt.gvd1, vbt, vbt->hdr_vbt_size <
|
|
sizeof(opregion->vbt.gvd1) ? vbt->hdr_vbt_size :
|
|
sizeof(opregion->vbt.gvd1));
|
|
|
|
/* Size, in KB, of the entire OpRegion structure (including header)*/
|
|
opregion->header.size = sizeof(igd_opregion_t) / KiB;
|
|
opregion->header.version = IGD_OPREGION_VERSION;
|
|
|
|
/* We just assume we're mobile for now */
|
|
opregion->header.mailboxes = MAILBOXES_MOBILE;
|
|
|
|
return 0;
|
|
}
|