[PATCH v2 00/26] SoCFPGA: Add Boot Support for Agilex 5 in U-Boot
alif.zakuan.yuslaimi at intel.com
alif.zakuan.yuslaimi at intel.com
Tue Feb 18 09:34:45 CET 2025
From: Alif Zakuan Yuslaimi <alif.zakuan.yuslaimi at intel.com>
This patch set introduces boot support for the Altera SoCFPGA Agilex 5 platform in U-Boot. The changes include:
1. Board-specific configurations and setup required to enable Agilex 5
operation in U-Boot.
2. Integration of cache coherency unit (CCU) initialization routine,
including CCU conguration in DT.
3. Clock, firewall (configured in DT), SMMU, low level initialization
specific to Agilex 5.
4. Integration of memory initialization routine, including DDR setup.
This patch set has been tested on Agilex 5 devkit with QSPI boot (UBI/UBIFS) and RAM boot (TFTP & ARM DS debugger).
History:
--------
[v1]: https://patchwork.ozlabs.org/project/uboot/cover/20240920070242.20884-1-tien.fong.chee@intel.com/
v1->v2:
--------
Patch 1
- Converted system manager base address probing from header file to DT
Patch 2
- Updated Agilex5 clock driver to probe base address from DT
Patch 3
- Use common ARMv8 linker script instead of SoC64 linker script
Patch 4
- Use common ARMv8 low level script instead of new Agilex5 low level script
Patch 8
- Add Linux lore link for XGMAC enablement in Agilex5 Linux DT
Patch 9
- Use common PSCI reset driver instead of new Agilex5 reset driver
Patch 12
- Simplify printout logic writing format
Patch 13
- Use env_set_ulong() instead of env_set
Patch 15
- Cast as uintptr_t instead of u64
Alif Zakuan Yuslaimi (14):
arm: socfpga: misc: Exclude Agilex5 from clock manager base address
retrieval
drivers: clk: agilex5: Configure intosc as boot_clk source
drivers: clk: agilex5: Replace status polling with wait_for_bit_le32()
drivers: clk: agilex5: Set PLL to asynchronous mode
arm: socfpga: agilex5: Add warm reset mask for Agilex5
arm: socfpga: Disable GIC for Agilex5
arch: arm: Enable PSCI reset driver for Agilex5
firmware: psci: Flush cache before warm reset
arm: socfpga: agilex5: Update CPU info
arm: socfpga: Export board ID as U-Boot environment
arm: socfpga: smc: Add memory coherency support to mailbox command
arm: armv8: Improve SPL data save and restore implementation
configs: socfpga: soc64: agilex5: Use common ARMv8 linker script
configs: socfpga: soc64: agilex5: Enable QSPI boot with UBI / UBIFS
Tien Fong Chee (11):
arm: socfpga: agilex5: Add new system manager base addresses
arm: socfpga: Add handoff data support for SoCFPGA Agilex5 device
arm: dts: agilex5: Add HPS cache coherency unit configuration settings
arm: dts: agilex5: Add firewall configure settings
arm: dts: agilex5: Enable XGMAC
arm: socfpga: agilex5: Enable cache flush for system memory cache in
CCU
arm: socfpga: agilex5: Add SMMU initialization
configs: agilex5: Add configuration for malloc pool
arm: socfpga: agilex5: Add SPL for Agilex5 SoCFPGA
configs: socfpga: soc64: agilex5: Enable XGMAC
arm: socfpga: soc64: Add support for board_boot_order()
Tingting Meng (1):
ddr: altera: Add DDR driver for Agilex5 series
MAINTAINERS | 2 +
arch/arm/Kconfig | 2 +-
arch/arm/cpu/armv8/spl_data.c | 13 +-
arch/arm/cpu/armv8/u-boot-spl.lds | 1 +
arch/arm/dts/socfpga_agilex5-u-boot.dtsi | 661 ++++++++++++++++
arch/arm/dts/socfpga_agilex5.dtsi | 8 +
.../arm/dts/socfpga_agilex5_socdk-u-boot.dtsi | 71 +-
arch/arm/mach-socfpga/Kconfig | 5 +-
arch/arm/mach-socfpga/Makefile | 8 +-
arch/arm/mach-socfpga/altera-sysmgr.c | 113 +++
arch/arm/mach-socfpga/board.c | 32 +-
arch/arm/mach-socfpga/ccu_ncore3.c | 64 ++
.../mach-socfpga/include/mach/altera-sysmgr.h | 16 +
arch/arm/mach-socfpga/include/mach/board.h | 11 +
arch/arm/mach-socfpga/include/mach/firewall.h | 21 +-
.../mach-socfpga/include/mach/handoff_soc64.h | 5 +-
arch/arm/mach-socfpga/include/mach/misc.h | 2 +
.../include/mach/reset_manager_soc64.h | 9 +-
.../include/mach/system_manager_soc64.h | 128 +--
arch/arm/mach-socfpga/misc.c | 70 +-
arch/arm/mach-socfpga/misc_soc64.c | 32 +-
arch/arm/mach-socfpga/smc_api.c | 12 +-
arch/arm/mach-socfpga/spl_agilex5.c | 110 +++
arch/arm/mach-socfpga/spl_soc64.c | 119 +++
arch/arm/mach-socfpga/wrap_handoff_soc64.c | 9 +-
board/intel/agilex5-socdk/Makefile | 7 +
board/intel/agilex5-socdk/socfpga.c | 12 +
configs/socfpga_agilex5_defconfig | 17 +-
drivers/clk/altera/clk-agilex5.c | 53 +-
drivers/ddr/altera/Makefile | 3 +-
drivers/ddr/altera/iossm_mailbox.c | 748 ++++++++++++++++++
drivers/ddr/altera/iossm_mailbox.h | 136 ++++
drivers/ddr/altera/sdram_agilex5.c | 420 ++++++++++
drivers/ddr/altera/sdram_soc64.c | 76 +-
drivers/ddr/altera/sdram_soc64.h | 10 +
drivers/firmware/psci.c | 1 +
include/configs/socfpga_soc64_common.h | 6 +
37 files changed, 2879 insertions(+), 134 deletions(-)
create mode 100644 arch/arm/mach-socfpga/altera-sysmgr.c
create mode 100644 arch/arm/mach-socfpga/ccu_ncore3.c
create mode 100644 arch/arm/mach-socfpga/include/mach/altera-sysmgr.h
create mode 100644 arch/arm/mach-socfpga/include/mach/board.h
create mode 100644 arch/arm/mach-socfpga/spl_agilex5.c
create mode 100644 board/intel/agilex5-socdk/Makefile
create mode 100644 board/intel/agilex5-socdk/socfpga.c
create mode 100644 drivers/ddr/altera/iossm_mailbox.c
create mode 100644 drivers/ddr/altera/iossm_mailbox.h
create mode 100644 drivers/ddr/altera/sdram_agilex5.c
--
2.25.1
More information about the U-Boot
mailing list