[PATCH v3 1/2] common: board_f: change calculation of gd->mon_len to fix s5p4418 reloc
Stefan Bosch
stefan_b at posteo.net
Fri Jan 26 13:50:55 CET 2024
ARCH_NEXELL: Change calculation of monitor length (gd->mon_len) to fix
relocation at boards with s5p4418-SoC (ARCH_NEXELL). At s5p4418, _start
is after the header (NSIH). Therefore the monitor length has to be
calculated using __image_copy_start instead of _start in order the
whole monitor code is relocated.
Signed-off-by: Stefan Bosch <stefan_b at posteo.net>
---
Changes in v3:
- MICROBLAZE has not built anymore. Therefore do change calculation of
gd->mon_len for ARCH_NEXELL only. This makes sure that MICROBLAZE and
other ARM-boards are not affected.
Changes in v2:
- Cosmetic: Fix spelling mistake in commit message
common/board_f.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
diff --git a/common/board_f.c b/common/board_f.c
index d4d7d01f8f..73297fc1b2 100644
--- a/common/board_f.c
+++ b/common/board_f.c
@@ -282,7 +282,9 @@ static int init_func_i2c(void)
static int setup_mon_len(void)
{
-#if defined(__ARM__) || defined(__MICROBLAZE__)
+#if defined(CONFIG_ARCH_NEXELL)
+ gd->mon_len = (ulong)__bss_end - (ulong)__image_copy_start;
+#elif defined(__ARM__) || defined(__MICROBLAZE__)
gd->mon_len = (ulong)__bss_end - (ulong)_start;
#elif defined(CONFIG_SANDBOX) && !defined(__riscv)
gd->mon_len = (ulong)_end - (ulong)_init;
--
2.17.1
More information about the U-Boot
mailing list