From 3b03206426f852c87b6e1132bd51a016e57fdf69 Mon Sep 17 00:00:00 2001 From: Furquan Shaikh Date: Wed, 10 Jun 2020 11:52:49 -0700 Subject: soc/amd/picasso: Add custom memlayout.ld file This change copies src/arch/x86/memlayout.ld file to src/soc/amd/picasso/ and sets MEMLAYOUT_LD_FILE config variable to point to this newly added file. Unused elements from the memlayout.ld file are dropped and path to early_dram.ld is updated to include the one from src/arch/x86. BUG=b:155322763 Signed-off-by: Furquan Shaikh Change-Id: I59bf5f93b712407ddcc9fb8a46167936c6c28a76 Reviewed-on: https://review.coreboot.org/c/coreboot/+/42261 Tested-by: build bot (Jenkins) Reviewed-by: Raul Rangel Reviewed-by: Aaron Durbin --- src/soc/amd/picasso/Kconfig | 4 ++++ src/soc/amd/picasso/memlayout.ld | 45 ++++++++++++++++++++++++++++++++++++++++ 2 files changed, 49 insertions(+) create mode 100644 src/soc/amd/picasso/memlayout.ld (limited to 'src') diff --git a/src/soc/amd/picasso/Kconfig b/src/soc/amd/picasso/Kconfig index 2bd9c0975c..dba4e2fa59 100644 --- a/src/soc/amd/picasso/Kconfig +++ b/src/soc/amd/picasso/Kconfig @@ -56,6 +56,10 @@ config CPU_SPECIFIC_OPTIONS select HAVE_CF9_RESET select SUPPORT_CPU_UCODE_IN_CBFS +config MEMLAYOUT_LD_FILE + string + default "src/soc/amd/picasso/memlayout.ld" + config PRERAM_CBMEM_CONSOLE_SIZE hex default 0x1600 diff --git a/src/soc/amd/picasso/memlayout.ld b/src/soc/amd/picasso/memlayout.ld new file mode 100644 index 0000000000..8b2390909e --- /dev/null +++ b/src/soc/amd/picasso/memlayout.ld @@ -0,0 +1,45 @@ +/* SPDX-License-Identifier: GPL-2.0-only */ + +#include +#include + +#define EARLY_MEMLAYOUT "src/arch/x86/early_ram.ld" + +SECTIONS +{ + /* + * It would be good to lay down RAMSTAGE, ROMSTAGE, etc consecutively + * like other architectures/chipsets it's not possible because of + * the linking games played during romstage creation by trying + * to find the final landing place in CBFS for XIP. Therefore, + * conditionalize with macros. + */ +#if ENV_RAMSTAGE + RAMSTAGE(CONFIG_RAMBASE, (CONFIG(RELOCATABLE_RAMSTAGE) ? 8M : + CONFIG_RAMTOP - CONFIG_RAMBASE)) + +#elif ENV_ROMSTAGE + /* The 1M size is not allocated. It's just for basic size checking. + * Link at 32MiB address and rely on cbfstool to relocate to XIP. */ + ROMSTAGE(CONFIG_ROMSTAGE_ADDR, 1M) + + #include EARLY_MEMLAYOUT +#elif ENV_SEPARATE_VERSTAGE + /* The 1M size is not allocated. It's just for basic size checking. + * Link at 32MiB address and rely on cbfstool to relocate to XIP. */ + VERSTAGE(CONFIG_VERSTAGE_ADDR, 1M) + + #include EARLY_MEMLAYOUT +#elif ENV_BOOTBLOCK + BOOTBLOCK(CONFIG_X86_RESET_VECTOR - CONFIG_C_ENV_BOOTBLOCK_SIZE + 0x10, + CONFIG_C_ENV_BOOTBLOCK_SIZE) + + #include EARLY_MEMLAYOUT +#endif +} + +#if ENV_BOOTBLOCK +/* Bootblock specific scripts which provide more SECTION directives. */ +#include +#include +#endif /* ENV_BOOTBLOCK */ -- cgit v1.2.3