| /* SPDX-License-Identifier: GPL-2.0+ */ |
| /* |
| * Copyright 2022 NXP |
| */ |
| |
| #ifndef __ASM_ARCH_IMX9_REGS_H__ |
| #define __ASM_ARCH_IMX9_REGS_H__ |
| |
| #define ARCH_MXC |
| #define FEC_QUIRK_ENET_MAC |
| |
| #define IOMUXC_BASE_ADDR 0x443C0000UL |
| #define CCM_BASE_ADDR 0x44450000UL |
| #define CCM_CCGR_BASE_ADDR 0x44458000UL |
| #define SYSCNT_CTRL_BASE_ADDR 0x44290000 |
| |
| #define ANATOP_BASE_ADDR 0x44480000UL |
| |
| #define WDG3_BASE_ADDR 0x42490000UL |
| #define WDG4_BASE_ADDR 0x424a0000UL |
| #define WDG5_BASE_ADDR 0x424b0000UL |
| |
| #define FSB_BASE_ADDR 0x47510000UL |
| |
| #define ANATOP_BASE_ADDR 0x44480000UL |
| |
| #define BLK_CTRL_WAKEUPMIX_BASE_ADDR 0x42420000 |
| #define BLK_CTRL_S_ANOMIX_BASE_ADDR 0x444f0000 |
| |
| #define SRC_IPS_BASE_ADDR (0x44460000) |
| #define SRC_GLOBAL_RBASE (SRC_IPS_BASE_ADDR + 0x0000) |
| |
| #define SRC_DDR_RBASE (SRC_IPS_BASE_ADDR + 0x1000) |
| #define SRC_ML_RBASE (SRC_IPS_BASE_ADDR + 0x1800) |
| #define SRC_MEDIA_RBASE (SRC_IPS_BASE_ADDR + 0x2400) |
| #define SRC_M33P_RBASE (SRC_IPS_BASE_ADDR + 0x2800) |
| |
| #define SRC_MIX_SLICE_FUNC_STAT_PSW_STAT BIT(0) |
| #define SRC_MIX_SLICE_FUNC_STAT_RST_STAT BIT(2) |
| #define SRC_MIX_SLICE_FUNC_STAT_ISO_STAT BIT(4) |
| #define SRC_MIX_SLICE_FUNC_STAT_MEM_STAT BIT(12) |
| |
| #define IMG_CONTAINER_BASE (0x80000000UL) |
| |
| #define BCTRL_GPR_ENET_QOS_INTF_MODE_MASK GENMASK(3, 1) |
| #define BCTRL_GPR_ENET_QOS_INTF_SEL_MII (0x0 << 1) |
| #define BCTRL_GPR_ENET_QOS_INTF_SEL_RMII (0x4 << 1) |
| #define BCTRL_GPR_ENET_QOS_INTF_SEL_RGMII (0x1 << 1) |
| #define BCTRL_GPR_ENET_QOS_CLK_GEN_EN (0x1 << 0) |
| |
| #define MARKETING_GRADING_MASK GENMASK(5, 4) |
| #define SPEED_GRADING_MASK GENMASK(11, 6) |
| |
| #if !(defined(__KERNEL_STRICT_NAMES) || defined(__ASSEMBLY__)) |
| #include <asm/types.h> |
| #include <stdbool.h> |
| |
| struct mu_type { |
| u32 ver; |
| u32 par; |
| u32 cr; |
| u32 sr; |
| u32 reserved0[60]; |
| u32 fcr; |
| u32 fsr; |
| u32 reserved1[2]; |
| u32 gier; |
| u32 gcr; |
| u32 gsr; |
| u32 reserved2; |
| u32 tcr; |
| u32 tsr; |
| u32 rcr; |
| u32 rsr; |
| u32 reserved3[52]; |
| u32 tr[16]; |
| u32 reserved4[16]; |
| u32 rr[16]; |
| u32 reserved5[14]; |
| u32 mu_attr; |
| }; |
| |
| enum mix_power_domain { |
| MIX_PD_MEDIAMIX, |
| MIX_PD_MLMIX, |
| MIX_PD_DDRMIX, |
| }; |
| |
| enum src_mix_slice_id { |
| SRC_MIX_EDGELOCK = 0, |
| SRC_MIX_AONMIX = 1, |
| SRC_MIX_WAKEUPMIX = 2, |
| SRC_MIX_DDRMIX = 3, |
| SRC_MIX_DDRPHY = 4, |
| SRC_MIX_ML = 5, |
| SRC_MIX_NIC = 6, |
| SRC_MIX_HSIO = 7, |
| SRC_MIX_MEDIA = 8, |
| SRC_MIX_CM33 = 9, |
| SRC_MIX_CA55C0 = 10, |
| SRC_MIX_CA55C1 = 11, |
| SRC_MIX_CA55CLUSTER = 12, |
| }; |
| |
| enum src_mem_slice_id { |
| SRC_MEM_AONMIX = 0, |
| SRC_MEM_WAKEUPMIX = 1, |
| SRC_MEM_DDRMIX = 2, |
| SRC_MEM_DDRPHY = 3, |
| SRC_MEM_ML = 4, |
| SRC_MEM_NIC = 5, |
| SRC_MEM_OCRAM = 6, |
| SRC_MEM_HSIO = 7, |
| SRC_MEM_MEDIA = 8, |
| SRC_MEM_CA55C0 = 9, |
| SRC_MEM_CA55C1 = 10, |
| SRC_MEM_CA55CLUSTER = 11, |
| SRC_MEM_L3 = 12, |
| }; |
| |
| struct blk_ctrl_s_aonmix_regs { |
| u32 cm33_irq_mask[7]; |
| u32 initnsvtor; |
| u32 reserved1[8]; |
| u32 ca55_irq_mask[7]; |
| u32 initsvtor; |
| u32 m33_cfg; |
| u32 reserved2[11]; |
| u32 axbs_aon_ctrl; |
| u32 reserved3[27]; |
| u32 dap_access_stkybit; |
| u32 reserved4[3]; |
| u32 lp_handshake[2]; |
| u32 ca55_cpuwait; |
| u32 ca55_rvbaraddr0_l; |
| u32 ca55_rvbaraddr0_h; |
| u32 ca55_rvbaraddr1_l; |
| u32 ca55_rvbaraddr1_h; |
| u32 s401_irq_mask; |
| u32 s401_reset_req_mask; |
| u32 s401_halt_st; |
| u32 ca55_mode; |
| u32 nmi_mask; |
| u32 nmi_clr; |
| u32 wdog_any_mask; |
| u32 s4v1_ipi_noclk_ref1; |
| }; |
| |
| struct blk_ctrl_wakeupmix_regs { |
| u32 upper_addr; |
| u32 ipg_debug_cm33; |
| u32 reserved[2]; |
| u32 qch_dis; |
| u32 ssi; |
| u32 reserved1[1]; |
| u32 dexsc_err; |
| u32 mqs_setting; |
| u32 sai_clk_sel; |
| u32 eqos_gpr; |
| u32 enet_clk_sel; |
| u32 reserved2[1]; |
| u32 volt_detect; |
| u32 i3c2_wakeup; |
| u32 ipg_debug_ca55c0; |
| u32 ipg_debug_ca55c1; |
| u32 axi_attr_cfg; |
| u32 i3c2_sda_irq; |
| }; |
| |
| struct src_general_regs { |
| u32 reserved[1]; |
| u32 authen_ctrl; |
| u32 reserved1[2]; |
| u32 scr; |
| u32 srtmr; |
| u32 srmask; |
| u32 reserved2[1]; |
| u32 srmr[6]; |
| u32 reserved3[2]; |
| u32 sbmr[2]; |
| u32 reserved4[2]; |
| u32 srsr; |
| u32 gpr[19]; |
| u32 reserved5[24]; |
| u32 gpr20; |
| u32 cm_quiesce; |
| u32 cold_reset_ssar_ack_ctrl; |
| u32 sp_iso_ctrl; |
| u32 rom_lp_ctrl; |
| u32 a55_deny_stat; |
| }; |
| |
| struct src_mem_slice_regs { |
| u32 reserved[1]; |
| u32 mem_ctrl; |
| u32 memlp_ctrl_0; |
| u32 reserved1[1]; |
| u32 memlp_ctrl_1; |
| u32 memlp_ctrl_2; |
| u32 mem_stat; |
| }; |
| |
| struct src_mix_slice_regs { |
| u32 reserved[1]; |
| u32 authen_ctrl; |
| u32 reserved1[2]; |
| u32 lpm_setting[3]; |
| u32 reserved2[1]; |
| u32 slice_sw_ctrl; |
| u32 single_reset_sw_ctrl; |
| u32 reserved3[6]; |
| u32 a55_hdsk_ack_ctrl; |
| u32 a55_hdsk_ack_stat; |
| u32 reserved4[2]; |
| u32 ssar_ack_ctrl; |
| u32 ssar_ack_stat; |
| u32 reserved5[1]; |
| u32 iso_off_dly_por; |
| u32 iso_on_dly; |
| u32 iso_off_dly; |
| u32 psw_off_lf_dly; |
| u32 reserved6[1]; |
| u32 psw_off_hf_dly; |
| u32 psw_on_lf_dly; |
| u32 psw_on_hf_dly; |
| u32 reserved7[1]; |
| u32 psw_ack_ctrl[2]; |
| u32 psw_ack_stat; |
| u32 reserved8[1]; |
| u32 mtr_ack_ctrl; |
| u32 mtr_ack_stat; |
| u32 reserved9[2]; |
| u32 upi_stat[4]; |
| u32 fsm_stat; |
| u32 func_stat; |
| }; |
| #endif |
| |
| #endif |