--- /dev/null
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Copyright (C) 2025 Altera Corporation <www.altera.com>
+ */
+
+/*
+ * This driver supports the SOCFPGA System Manager Register block which
+ * aggregates different peripheral function into one area.
+ * On 64 bit ARM parts, the system manager only can be accessed during
+ * EL3 mode. At lower exception level a SMC call is required to perform
+ * the read and write operation.
+ */
+
+#define LOG_CATEGORY UCLASS_NOP
+
+#include <dm.h>
+#include <log.h>
+#include <misc.h>
+#include <asm/io.h>
+#include <asm/system.h>
+#include <asm/arch/altera-sysmgr.h>
+#include <asm/arch/smc_api.h>
+#include <linux/delay.h>
+#include <linux/err.h>
+#include <linux/intel-smc.h>
+
+static int altr_sysmgr_read_generic(struct udevice *dev, u32 *addr, u32 *value)
+{
+       u64 args[1];
+       u64 ret_arg;
+       int ret = 0;
+
+       debug("%s: %s(dev=%p, addr=0x%lx):\n", __func__,
+             dev->name, dev, (uintptr_t)addr);
+
+       if (current_el() == 3) {
+               ret_arg = readl((uintptr_t)addr);
+       } else {
+               if (!(IS_ENABLED(CONFIG_SPL_BUILD)) && IS_ENABLED(CONFIG_SPL_ATF)) {
+                       args[0] = (u64)(uintptr_t)addr;
+                       ret = invoke_smc(INTEL_SIP_SMC_REG_READ, args, 1, &ret_arg, 1);
+               } else {
+                       pr_err("%s Failed to read system manager at lower privilege and without BL31\n",
+                              dev->name);
+                       return -EPROTONOSUPPORT;
+               }
+       }
+
+       *value = (u32)ret_arg;
+       return ret;
+}
+
+static int altr_sysmgr_write_generic(struct udevice *dev, u32 *addr, u32 value)
+{
+       u64 args[2];
+       int ret = 0;
+
+       debug("%s: %s(dev=%p, addr=0x%lx, val=0x%x):\n", __func__,
+             dev->name, dev, (uintptr_t)addr, value);
+
+       if (current_el() == 3) {
+               writel(value, (uintptr_t)addr);
+       } else {
+               if (!(IS_ENABLED(CONFIG_SPL_BUILD)) && IS_ENABLED(CONFIG_SPL_ATF)) {
+                       args[0] = (u64)(uintptr_t)(addr);
+                       args[1] = value;
+                       ret = invoke_smc(INTEL_SIP_SMC_REG_WRITE, args, 2, NULL, 0);
+               } else {
+                       pr_err("%s Failed to write to system manager at lower privilege and without BL31\n",
+                              dev->name);
+                       return -EPROTONOSUPPORT;
+               }
+       }
+
+       return ret;
+}
+
+static int altr_sysmgr_probe(struct udevice *dev)
+{
+       fdt_addr_t addr;
+       struct altr_sysmgr_priv *altr_priv = dev_get_priv(dev);
+
+       debug("%s: %s(dev=%p):\n", __func__, dev->name, dev);
+       addr = dev_read_addr(dev);
+       if (addr == FDT_ADDR_T_NONE) {
+               pr_err("%s dev_read_addr() failed\n", dev->name);
+               return -ENODEV;
+       }
+
+       altr_priv->regs = (void __iomem *)addr;
+       return 0;
+}
+
+static const struct altr_sysmgr_ops sysmgr_ops = {
+       .read = altr_sysmgr_read_generic,
+       .write = altr_sysmgr_write_generic,
+};
+
+static const struct udevice_id altr_sysmgr_ids[] = {
+       { .compatible = "altr,sys-mgr-s10" },
+       { .compatible = "altr,sys-mgr" },
+       { },
+};
+
+U_BOOT_DRIVER(altr_sysmgr) = {
+       .name   = "altr_sysmgr",
+       .id     = UCLASS_NOP,
+       .of_match = altr_sysmgr_ids,
+       .probe  = altr_sysmgr_probe,
+       .ops    = &sysmgr_ops,
+       .priv_auto = sizeof(struct altr_sysmgr_priv),
+       .flags = DM_FLAG_PRE_RELOC,
+};
 
 /* SPDX-License-Identifier: GPL-2.0 */
 /*
  * Copyright (C) 2019-2021 Intel Corporation <www.intel.com>
+ * Copyright (C) 2025 Altera Corporation <www.altera.com>
  */
 
 #ifndef _SYSTEM_MANAGER_SOC64_H_
 void populate_sysmgr_fpgaintf_module(void);
 void populate_sysmgr_pinmux(void);
 
-#define SYSMGR_SOC64_WDDBG                     0x08
-#define SYSMGR_SOC64_DMA                       0x20
-#define SYSMGR_SOC64_DMA_PERIPH                        0x24
-#define SYSMGR_SOC64_SDMMC                     0x28
-#define SYSMGR_SOC64_SDMMC_L3MASTER            0x2c
-#define SYSMGR_SOC64_EMAC_GLOBAL               0x40
-#define SYSMGR_SOC64_EMAC0                     0x44
-#define SYSMGR_SOC64_EMAC1                     0x48
-#define SYSMGR_SOC64_EMAC2                     0x4c
-#define SYSMGR_SOC64_EMAC0_ACE                 0x50
-#define SYSMGR_SOC64_EMAC1_ACE                 0x54
-#define SYSMGR_SOC64_EMAC2_ACE                 0x58
+#if IS_ENABLED(CONFIG_TARGET_SOCFPGA_AGILEX5)
+#define SYSMGR_SOC64_SILICONID_1               0x00
+#define SYSMGR_SOC64_SILICONID_2               0x04
+#define SYSMGR_SOC64_MPU_STATUS                        0x10
+#define SYSMGR_SOC64_COMBOPHY_DFISEL           0xfc
+#define SYSMGR_SOC64_COMBOPHY_DFISEL_SDMMC     0x1
+#define SYSMGR_SOC64_NANDGRP_L3MASTER          0x34
+#define SYSMGR_SOC64_USB0_L3MASTER             0x38
+#define SYSMGR_SOC64_USB1_L3MASTER             0x3c
+#define SYSMGR_SOC64_DMAC0_L3_MASTER           0x74
+#define SYSMGR_SOC64_ETR_L3_MASTER             0x78
+#define SYSMGR_SOC64_DMAC1_L3_MASTER           0x7C
+#define SYSMGR_SOC64_SEC_CTRL_SLT              0x80
+#define SYSMGR_SOC64_OSC_TRIM                  0x84
+#define SYSMGR_SOC64_DMAC0_CTRL_STATUS_REG     0x88
+#define SYSMGR_SOC64_DMAC1_CTRL_STATUS_REG     0x8C
+#define SYSMGR_SOC64_ECC_INTMASK_VALUE         0x90
+#define SYSMGR_SOC64_ECC_INTMASK_SET           0x94
+#define SYSMGR_SOC64_ECC_INTMASK_CLR           0x98
+#define SYSMGR_SOC64_ECC_INTMASK_SERR          0x9C
+#define SYSMGR_SOC64_ECC_INTMASK_DERR          0xA0
+#define SYSMGR_SOC64_MPFE_CONFIG               0x228
+#define SYSMGR_SOC64_BOOT_SCRATCH_POR0         0x258
+#define SYSMGR_SOC64_BOOT_SCRATCH_POR1         0x25C
+#define SYSMGR_SCRATCH_REG_0_QSPI_REFCLK_MASK          GENMASK(31, 0)
+#define ALT_SYSMGR_SCRATCH_REG_3_DDR_RESET_TYPE_MASK   GENMASK(31, 29)
+#define ALT_SYSMGR_SCRATCH_REG_3_DDR_RESET_TYPE_SHIFT  29
+#define ALT_SYSMGR_SCRATCH_REG_3_DDR_PORT_INFO_MASK    BIT(27)
+#define ALT_SYSMGR_SCRATCH_REG_3_DDR_EMIF_INFO_MASK    BIT(28)
+#define ALT_SYSMGR_SCRATCH_REG_3_DDR_PORT_EMIF_INFO_MASK       GENMASK(28, 27)
+#define ALT_SYSMGR_SCRATCH_REG_3_DDR_DBE_MASK  BIT(1)
+#define ALT_SYSMGR_SCRATCH_REG_3_OCRAM_DBE_MASK        BIT(0)
+#define ALT_SYSMGR_SCRATCH_REG_POR_0_DDR_PROGRESS_MASK BIT(0)
+#define ALT_SYSMGR_SCRATCH_REG_POR_1_REVA_WORKAROUND_USER_MODE_MASK    BIT(0)
+#define ALT_SYSMGR_SCRATCH_REG_POR_1_REVA_WORKAROUND_MASK      BIT(1)
+#else
 #define SYSMGR_SOC64_NAND_AXUSER               0x5c
-#define SYSMGR_SOC64_FPGAINTF_EN1              0x68
-#define SYSMGR_SOC64_FPGAINTF_EN2              0x6c
-#define SYSMGR_SOC64_FPGAINTF_EN3              0x70
 #define SYSMGR_SOC64_DMA_L3MASTER              0x74
 #if IS_ENABLED(CONFIG_TARGET_SOCFPGA_N5X)
 #define SYSMGR_SOC64_DDR_MODE                  0xb8
 #define SYSMGR_SOC64_HMC_CLK                   0xb4
 #define SYSMGR_SOC64_IO_PA_CTRL                        0xb8
 #endif
-#define SYSMGR_SOC64_NOC_TIMEOUT               0xc0
-#define SYSMGR_SOC64_NOC_IDLEREQ_SET           0xc4
-#define SYSMGR_SOC64_NOC_IDLEREQ_CLR           0xc8
-#define SYSMGR_SOC64_NOC_IDLEREQ_VAL           0xcc
-#define SYSMGR_SOC64_NOC_IDLEACK               0xd0
-#define SYSMGR_SOC64_NOC_IDLESTATUS            0xd4
-#define SYSMGR_SOC64_FPGA2SOC_CTRL             0xd8
-#define SYSMGR_SOC64_FPGA_CONFIG               0xdc
 #define SYSMGR_SOC64_IOCSRCLK_GATE             0xe0
 #define SYSMGR_SOC64_GPO                       0xe4
 #define SYSMGR_SOC64_GPI                       0xe8
 #define SYSMGR_SOC64_MPU                       0xf0
-/*
- * Bits[31:28] reserved for N5X DDR retention, bits[27:0] reserved for SOC 64-bit
- * storing qspi ref clock (kHz)
- */
-#define SYSMGR_SOC64_BOOT_SCRATCH_COLD0                0x200
-/* store osc1 clock freq */
-#define SYSMGR_SOC64_BOOT_SCRATCH_COLD1                0x204
-/* store fpga clock freq */
-#define SYSMGR_SOC64_BOOT_SCRATCH_COLD2                0x208
-/* reserved for customer use */
-#define SYSMGR_SOC64_BOOT_SCRATCH_COLD3                0x20c
-/* store PSCI_CPU_ON value */
-#define SYSMGR_SOC64_BOOT_SCRATCH_COLD4                0x210
-/* store PSCI_CPU_ON value */
-#define SYSMGR_SOC64_BOOT_SCRATCH_COLD5                0x214
-/* store VBAR_EL3 value */
-#define SYSMGR_SOC64_BOOT_SCRATCH_COLD6                0x218
-/* store VBAR_EL3 value */
-#define SYSMGR_SOC64_BOOT_SCRATCH_COLD7                0x21c
-#define SYSMGR_SOC64_BOOT_SCRATCH_COLD8                0x220
-#define SYSMGR_SOC64_BOOT_SCRATCH_COLD9                0x224
+#define SYSMGR_SCRATCH_REG_0_QSPI_REFCLK_MASK  GENMASK(27, 0)
+#endif /*CONFIG_TARGET_SOCFPGA_AGILEX5*/
+
+#define SYSMGR_SOC64_DMA                       0x20
+#define SYSMGR_SOC64_DMA_PERIPH                        0x24
+#define SYSMGR_SOC64_WDDBG                     0x08
+#define SYSMGR_SOC64_SDMMC                     0x28
+#define SYSMGR_SOC64_SDMMC_L3MASTER            0x2C
+#define SYSMGR_SOC64_FPGAINTF_EN1              0x68
+#define SYSMGR_SOC64_FPGAINTF_EN2              0x6C
+#define SYSMGR_SOC64_FPGAINTF_EN3              0x70
+#define SYSMGR_SOC64_NOC_TIMEOUT               0xC0
+#define SYSMGR_SOC64_NOC_IDLEREQ_SET           0xC4
+#define SYSMGR_SOC64_NOC_IDLEREQ_CLR           0xC8
+#define SYSMGR_SOC64_NOC_IDLEREQ_VAL           0xCC
+#define SYSMGR_SOC64_NOC_IDLEACK               0xd0
+#define SYSMGR_SOC64_NOC_IDLESTATUS            0xD4
+#define SYSMGR_SOC64_FPGA2SOC_CTRL             0xD8
+#define SYSMGR_SOC64_FPGA_CONFIG               0xDC
+
+#define SYSMGR_SOC64_TSN_GLOBAL                        0x40
+#define SYSMGR_SOC64_TSN_0                     0x44
+#define SYSMGR_SOC64_TSN_1                     0x48
+#define SYSMGR_SOC64_TSN_2                     0x4C
+#define SYSMGR_SOC64_TSN_0_ACE                 0x50
+#define SYSMGR_SOC64_TSN_1_ACE                 0x54
+#define SYSMGR_SOC64_TSN_2_ACE                 0x58
+#define SYSMGR_SOC64_EMAC_GLOBAL       SYSMGR_SOC64_TSN_GLOBAL
+#define SYSMGR_SOC64_EMAC0             SYSMGR_SOC64_TSN_0
+#define SYSMGR_SOC64_EMAC1             SYSMGR_SOC64_TSN_1
+#define SYSMGR_SOC64_EMAC2             SYSMGR_SOC64_TSN_2
+#define SYSMGR_SOC64_EMAC0_ACE         SYSMGR_SOC64_TSN_0_ACE
+#define SYSMGR_SOC64_EMAC1_ACE         SYSMGR_SOC64_TSN_1_ACE
+#define SYSMGR_SOC64_EMAC2_ACE         SYSMGR_SOC64_TSN_2_ACE
+
+#define SYSMGR_SOC64_BOOT_SCRATCH_COLD0        0x200
+#define SYSMGR_SOC64_BOOT_SCRATCH_COLD1        0x204
+#define SYSMGR_SOC64_BOOT_SCRATCH_COLD2        0x208
+#define SYSMGR_SOC64_BOOT_SCRATCH_COLD3        0x20C
+#define SYSMGR_SOC64_BOOT_SCRATCH_COLD4        0x210
+#define SYSMGR_SOC64_BOOT_SCRATCH_COLD5        0x214
+#define SYSMGR_SOC64_BOOT_SCRATCH_COLD6        0x218
+#define SYSMGR_SOC64_BOOT_SCRATCH_COLD7        0x21C
+#define SYSMGR_SOC64_BOOT_SCRATCH_COLD8        0x220
+#define SYSMGR_SOC64_BOOT_SCRATCH_COLD9        0x224
+
 #define SYSMGR_SOC64_PINSEL0                   0x1000
 #define SYSMGR_SOC64_IOCTRL0                   0x1130
 #define SYSMGR_SOC64_EMAC0_USEFPGA             0x1300
  * Bits[31:28] reserved for DM DDR retention, bits[27:0] reserved for SOC 64-bit
  * storing qspi ref clock (kHz)
  */
-#define SYSMGR_SCRATCH_REG_0_QSPI_REFCLK_MASK          GENMASK(27, 0)
 #define ALT_SYSMGR_SCRATCH_REG_0_DDR_RETENTION_MASK    BIT(31)
 #define ALT_SYSMGR_SCRATCH_REG_0_DDR_SHA_MASK          BIT(30)
 #define ALT_SYSMGR_SCRATCH_REG_0_DDR_RESET_TYPE_MASK   (BIT(29) | BIT(28))