drivers/intel/fsp2_0: Add logo support
Add support for the FSP feature to display the logo. BUG=N/A TEST=tested on facebook monolith Change-Id: Iaaffd2be567861371bbe908c1ef9d7dde483a945 Signed-off-by: Wim Vervoorn <wvervoorn@eltan.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/37515 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Patrick Rudolph <siro@das-labor.org> Reviewed-by: Frans Hendriks <fhendriks@eltan.com> Reviewed-by: Angel Pons <th3fanbus@gmail.com>
This commit is contained in:
parent
2ab4f4b2c5
commit
cbc878d2a2
5 changed files with 64 additions and 0 deletions
|
@ -156,6 +156,20 @@ config FSP_PEIM_TO_PEIM_INTERFACE
|
|||
is limited till EFI_PEI_MP_SERVICE_PPI and this option might be
|
||||
useful to add further PPI if required.
|
||||
|
||||
config FSP2_0_DISPLAY_LOGO
|
||||
bool "Enable logo"
|
||||
default n
|
||||
depends on HAVE_FSP_GOP
|
||||
help
|
||||
Uses the FSP to display the boot logo. This method supports a
|
||||
BMP file only. The uncompressed size can be up to 1 MB. The logo can be compressed
|
||||
using LZMA.
|
||||
|
||||
config FSP2_0_LOGO_FILE_NAME
|
||||
string "Logo file"
|
||||
depends on FSP2_0_DISPLAY_LOGO
|
||||
default "3rdparty/blobs/mainboard/$(MAINBOARDDIR)/logo.bmp"
|
||||
|
||||
if FSP_PEIM_TO_PEIM_INTERFACE
|
||||
source "src/drivers/intel/fsp2_0/ppi/Kconfig"
|
||||
endif
|
||||
|
|
|
@ -30,6 +30,7 @@ ramstage-y += hand_off_block.c
|
|||
ramstage-$(CONFIG_DISPLAY_FSP_HEADER) += header_display.c
|
||||
ramstage-$(CONFIG_DISPLAY_HOBS) += hob_display.c
|
||||
ramstage-$(CONFIG_VERIFY_HOBS) += hob_verify.c
|
||||
ramstage-$(CONFIG_FSP2_0_DISPLAY_LOGO) += logo.c
|
||||
ramstage-y += notify.c
|
||||
ramstage-y += silicon_init.c
|
||||
ramstage-$(CONFIG_DISPLAY_UPD_DATA) += upd_display.c
|
||||
|
@ -78,6 +79,12 @@ $(obj)/Fsp_T.fd: $(call strip_quotes,$(CONFIG_FSP_FD_PATH)) $(obj)/Fsp_M.fd
|
|||
true
|
||||
endif
|
||||
|
||||
# Add logo to the cbfs image
|
||||
cbfs-files-$(CONFIG_FSP2_0_DISPLAY_LOGO) += logo.bmp
|
||||
logo.bmp-file := $(call strip_quotes,$(CONFIG_FSP2_0_LOGO_FILE_NAME))
|
||||
logo.bmp-type := raw
|
||||
logo.bmp-compression := LZMA
|
||||
|
||||
ifneq ($(call strip_quotes,$(CONFIG_FSP_HEADER_PATH)),)
|
||||
CPPFLAGS_common+=-I$(CONFIG_FSP_HEADER_PATH)
|
||||
endif
|
||||
|
|
|
@ -69,6 +69,9 @@ void platform_fsp_silicon_init_params_cb(FSPS_UPD *supd);
|
|||
uint8_t fsp_memory_mainboard_version(void);
|
||||
uint8_t fsp_memory_soc_version(void);
|
||||
|
||||
/* Load logo to be displayed by FSP */
|
||||
void load_logo(FSPS_UPD *supd);
|
||||
|
||||
/* Callback after processing FSP notify */
|
||||
void platform_fsp_notify_status(enum fsp_notify_phase phase);
|
||||
|
||||
|
|
27
src/drivers/intel/fsp2_0/logo.c
Normal file
27
src/drivers/intel/fsp2_0/logo.c
Normal file
|
@ -0,0 +1,27 @@
|
|||
/*
|
||||
* This file is part of the coreboot project.
|
||||
*
|
||||
* 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 <soc/ramstage.h>
|
||||
#include <console/console.h>
|
||||
#include <fsp/api.h>
|
||||
#include <include/cbfs.h>
|
||||
|
||||
void load_logo(FSPS_UPD *supd)
|
||||
{
|
||||
FSP_S_CONFIG *params = &supd->FspsConfig;
|
||||
|
||||
params->LogoSize = cbfs_boot_load_file("logo.bmp", (void *)params->LogoPtr,
|
||||
params->LogoSize, CBFS_TYPE_RAW);
|
||||
if (!params->LogoSize)
|
||||
params->LogoPtr = 0;
|
||||
}
|
|
@ -34,6 +34,7 @@ static void do_silicon_init(struct fsp_header *hdr)
|
|||
fsp_silicon_init_fn silicon_init;
|
||||
uint32_t status;
|
||||
uint8_t postcode;
|
||||
const struct cbmem_entry *logo_entry;
|
||||
|
||||
supd = (FSPS_UPD *) (hdr->cfg_region_offset + hdr->image_base);
|
||||
|
||||
|
@ -56,6 +57,15 @@ static void do_silicon_init(struct fsp_header *hdr)
|
|||
/* Give SoC/mainboard a chance to populate entries */
|
||||
platform_fsp_silicon_init_params_cb(upd);
|
||||
|
||||
#if (CONFIG(HAVE_FSP_GOP))
|
||||
if (CONFIG(FSP2_0_DISPLAY_LOGO)) {
|
||||
upd->FspsConfig.LogoSize = 1 * MiB;
|
||||
logo_entry = cbmem_entry_add(CBMEM_ID_FSP_LOGO, upd->FspsConfig.LogoSize);
|
||||
upd->FspsConfig.LogoPtr = (UINT32)cbmem_entry_start(logo_entry);
|
||||
load_logo(upd);
|
||||
}
|
||||
#endif
|
||||
|
||||
/* Call SiliconInit */
|
||||
silicon_init = (void *) (hdr->image_base +
|
||||
hdr->silicon_init_entry_offset);
|
||||
|
@ -67,6 +77,9 @@ static void do_silicon_init(struct fsp_header *hdr)
|
|||
timestamp_add_now(TS_FSP_SILICON_INIT_END);
|
||||
post_code(POST_FSP_SILICON_EXIT);
|
||||
|
||||
if (CONFIG(FSP2_0_DISPLAY_LOGO))
|
||||
cbmem_entry_remove(logo_entry);
|
||||
|
||||
fsp_debug_after_silicon_init(status);
|
||||
|
||||
/* Handle any errors returned by FspSiliconInit */
|
||||
|
|
Loading…
Reference in a new issue