[PATCH v4 1/3] arm: socfpga: Consolidate dram_bank_mmu_setup()
Chee, Tien Fong
tien.fong.chee at altera.com
Fri Jun 12 10:06:34 CEST 2026
On 9/6/2026 10:03 am, alif.zakuan.yuslaimi at altera.com wrote:
> From: Alif Zakuan Yuslaimi <alif.zakuan.yuslaimi at altera.com>
>
> Share dram_bank_mmu_setup() between Gen5 and Arria10 in misc.c. Before
> relocation, map OCRAM and DRAM write-through so SPL can run
> sdram_init_ecc_bits() with dcache; after relocation, use default DRAM
> cache attributes.
>
> Fixes: 503eea451903 ("arm: cp15: update DACR value to activate access
> control")
> Link: e26ecebc684b ("socfpga: arria10: Allow dcache_enable before
> relocation")
>
> Signed-off-by: Alif Zakuan Yuslaimi <alif.zakuan.yuslaimi at altera.com>
> ---
>
> Changes in v4:
> - Commit message clean up
>
> Changes in v3:
> - Removed 'select SPL_CACHE if SPL' Kconfig guard from this patch and
> applied this condition alongside SOCFPGA_ECC_SUPPORT on patch 3
>
> Changes in v2:
> - Shared dram_bank_mmu_setup() is set as optional via Kconfig and defaulted
> on only for the reference Arria10/CycloneV boards to avoid SPL overflows
> on size-limited Gen5 defconfigs.
>
> arch/arm/mach-socfpga/misc.c | 31 ++++++++++++++++++++++++++++
> arch/arm/mach-socfpga/misc_arria10.c | 26 -----------------------
> 2 files changed, 31 insertions(+), 26 deletions(-)
>
> diff --git a/arch/arm/mach-socfpga/misc.c b/arch/arm/mach-socfpga/misc.c
> index 1eef7893e54..80b054dcae9 100644
> --- a/arch/arm/mach-socfpga/misc.c
> +++ b/arch/arm/mach-socfpga/misc.c
> @@ -318,3 +318,34 @@ phys_addr_t socfpga_get_clkmgr_addr(void)
> {
> return socfpga_clkmgr_base;
> }
> +
> +#if IS_ENABLED(CONFIG_SYS_ARM_CACHE_CP15)
> +void dram_bank_mmu_setup(int bank)
> +{
> + struct bd_info *bd = gd->bd;
> + u32 start, size;
> + int i;
> +
> + /* If we're still in OCRAM, don't set the XN bit on it */
> + if (!(gd->flags & GD_FLG_RELOC)) {
> + set_section_dcache(CFG_SYS_INIT_RAM_ADDR >> MMU_SECTION_SHIFT,
> + DCACHE_WRITETHROUGH);
> +
> + /*
> + * The default implementation of this function allows the DRAM dcache
> + * to be enabled only after relocation. However, to speed up ECC
> + * initialization, we want to be able to enable DRAM dcache before
> + * relocation.
> + */
> + start = bd->bi_dram[bank].start >> MMU_SECTION_SHIFT;
> + size = bd->bi_dram[bank].size >> MMU_SECTION_SHIFT;
> + for (i = start; i < start + size; i++)
> + set_section_dcache(i, DCACHE_WRITETHROUGH);
> + } else {
> + start = bd->bi_dram[bank].start >> MMU_SECTION_SHIFT;
> + size = bd->bi_dram[bank].size >> MMU_SECTION_SHIFT;
> + for (i = start; i < start + size; i++)
> + set_section_dcache(i, DCACHE_DEFAULT_OPTION);
> + }
> +}
> +#endif
> diff --git a/arch/arm/mach-socfpga/misc_arria10.c b/arch/arm/mach-socfpga/misc_arria10.c
> index 7e0f3875b7c..635fc3568fb 100644
> --- a/arch/arm/mach-socfpga/misc_arria10.c
> +++ b/arch/arm/mach-socfpga/misc_arria10.c
> @@ -243,29 +243,3 @@ int qspi_flash_software_reset(void)
> return 0;
> }
> #endif
> -
> -void dram_bank_mmu_setup(int bank)
> -{
> - struct bd_info *bd = gd->bd;
> - u32 start, size;
> - int i;
> -
> - /* If we're still in OCRAM, don't set the XN bit on it */
> - if (!(gd->flags & GD_FLG_RELOC)) {
> - set_section_dcache(
> - CFG_SYS_INIT_RAM_ADDR >> MMU_SECTION_SHIFT,
> - DCACHE_WRITETHROUGH);
> - }
> -
> - /*
> - * The default implementation of this function allows the DRAM dcache
> - * to be enabled only after relocation. However, to speed up ECC
> - * initialization, we want to be able to enable DRAM dcache before
> - * relocation, so we don't check GD_FLG_RELOC (this assumes bd->bi_dram
> - * is set first).
> - */
> - start = bd->bi_dram[bank].start >> MMU_SECTION_SHIFT;
> - size = bd->bi_dram[bank].size >> MMU_SECTION_SHIFT;
> - for (i = start; i < start + size; i++)
> - set_section_dcache(i, DCACHE_DEFAULT_OPTION);
> -}
Reviewed-by: Tien Fong Chee <tien.fong.chee at altera.com>
Best regards,
Tien Fong
More information about the U-Boot
mailing list