On 11/14/25 6:13 PM, Jan Kiszka wrote:
From: Jan Kiszka <[email protected]>

If U-Boot is located on MMC, SPL and U-Boot proper are glued together.
More precisely, SPL is stored 4 times. Take this and its padding into
account and adjust sector number via board_spl_mmc_get_uboot_raw_sector.
This allows loading from a partition, without the need to hard-code the
offset via SYS_MMCSD_RAW_MODE_U_BOOT_USE_SECTOR

Signed-off-by: Jan Kiszka <[email protected]>
---
  arch/arm/mach-socfpga/board.c | 9 +++++++++
  1 file changed, 9 insertions(+)

diff --git a/arch/arm/mach-socfpga/board.c b/arch/arm/mach-socfpga/board.c
index 28554b7a109..d756f7381fb 100644
--- a/arch/arm/mach-socfpga/board.c
+++ b/arch/arm/mach-socfpga/board.c
@@ -14,6 +14,7 @@
  #include <hang.h>
  #include <handoff.h>
  #include <image.h>
+#include <spl.h>
  #include <usb.h>
  #include <usb/dwc2_udc.h>
  #include <asm/global_data.h>
@@ -209,3 +210,11 @@ void lmb_arch_add_memory(void)
        }
  }
  #endif
+
+#ifdef CONFIG_SPL
+unsigned long board_spl_mmc_get_uboot_raw_sector(struct mmc *mmc,
+                                                unsigned long raw_sect)
+{
+       return (CONFIG_SPL_PAD_TO * 4) / 512 + raw_sect;
Please add a comment whether this is offset within a partition or within a raw block device.

Also, I see the long discussion thread, maybe it would be good to point out which commit exactly broken the DE0 board.

Reply via email to