Tom Rini | 10e4779 | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 2 | /* |
| 3 | * LayerScape Internal Memory Map |
| 4 | * |
Meenakshi Aggarwal | ccb5d5d | 2020-10-29 19:16:16 +0530 | [diff] [blame] | 5 | * Copyright 2017-2020 NXP |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 6 | * Copyright 2014 Freescale Semiconductor, Inc. |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 7 | */ |
| 8 | |
| 9 | #ifndef __ARCH_FSL_LSCH3_IMMAP_H_ |
| 10 | #define __ARCH_FSL_LSCH3_IMMAP_H_ |
| 11 | |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 12 | #define CONFIG_SYS_FSL_DDR_ADDR (CONFIG_SYS_IMMR + 0x00080000) |
| 13 | #define CONFIG_SYS_FSL_DDR2_ADDR (CONFIG_SYS_IMMR + 0x00090000) |
| 14 | #define CONFIG_SYS_FSL_DDR3_ADDR 0x08210000 |
| 15 | #define CONFIG_SYS_FSL_GUTS_ADDR (CONFIG_SYS_IMMR + 0x00E00000) |
| 16 | #define CONFIG_SYS_FSL_PMU_ADDR (CONFIG_SYS_IMMR + 0x00E30000) |
Meenakshi Aggarwal | ccb5d5d | 2020-10-29 19:16:16 +0530 | [diff] [blame] | 17 | #if defined(CONFIG_ARCH_LX2160A) || defined(CONFIG_ARCH_LX2162A) |
Priyanka Jain | ef76b2e | 2018-10-29 09:17:09 +0000 | [diff] [blame] | 18 | #define CONFIG_SYS_FSL_RST_ADDR (CONFIG_SYS_IMMR + 0x00e88180) |
| 19 | #else |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 20 | #define CONFIG_SYS_FSL_RST_ADDR (CONFIG_SYS_IMMR + 0x00E60000) |
Priyanka Jain | ef76b2e | 2018-10-29 09:17:09 +0000 | [diff] [blame] | 21 | #endif |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 22 | #define CONFIG_SYS_FSL_CH3_CLK_GRPA_ADDR (CONFIG_SYS_IMMR + 0x00300000) |
| 23 | #define CONFIG_SYS_FSL_CH3_CLK_GRPB_ADDR (CONFIG_SYS_IMMR + 0x00310000) |
| 24 | #define CONFIG_SYS_FSL_CH3_CLK_CTRL_ADDR (CONFIG_SYS_IMMR + 0x00370000) |
Kuldeep Singh | 204a725 | 2019-11-21 17:15:16 +0530 | [diff] [blame] | 25 | #ifndef CONFIG_NXP_LSCH3_2 |
Yuan Yao | 52ae4fd | 2016-12-01 10:13:52 +0800 | [diff] [blame] | 26 | #define SYS_FSL_QSPI_ADDR (CONFIG_SYS_IMMR + 0x010c0000) |
Kuldeep Singh | 204a725 | 2019-11-21 17:15:16 +0530 | [diff] [blame] | 27 | #else |
| 28 | #define SYS_NXP_FSPI_ADDR (CONFIG_SYS_IMMR + 0x010c0000) |
| 29 | #define SYS_NXP_FSPI_LUTKEY_BASE_ADDR 0x18 |
| 30 | #define SYS_NXP_FSPI_LUT_BASE_ADDR 0x200 |
| 31 | #endif |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 32 | #define CONFIG_SYS_FSL_ESDHC_ADDR (CONFIG_SYS_IMMR + 0x01140000) |
Laurentiu Tudor | e29ca39 | 2019-07-30 17:29:56 +0300 | [diff] [blame] | 33 | #define FSL_ESDHC1_BASE_ADDR CONFIG_SYS_FSL_ESDHC_ADDR |
| 34 | #define FSL_ESDHC2_BASE_ADDR (CONFIG_SYS_IMMR + 0x01150000) |
Priyanka Jain | 88c2566 | 2018-10-29 09:11:29 +0000 | [diff] [blame] | 35 | #ifndef CONFIG_NXP_LSCH3_2 |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 36 | #define CONFIG_SYS_IFC_ADDR (CONFIG_SYS_IMMR + 0x01240000) |
Priyanka Jain | 88c2566 | 2018-10-29 09:11:29 +0000 | [diff] [blame] | 37 | #endif |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 38 | #define CONFIG_SYS_NS16550_COM1 (CONFIG_SYS_IMMR + 0x011C0500) |
| 39 | #define CONFIG_SYS_NS16550_COM2 (CONFIG_SYS_IMMR + 0x011C0600) |
Priyanka Jain | 3d31ec7 | 2016-11-17 12:29:52 +0530 | [diff] [blame] | 40 | #define SYS_FSL_LS2080A_LS2085A_TIMER_ADDR 0x023d0000 |
| 41 | #define CONFIG_SYS_FSL_TIMER_ADDR 0x023e0000 |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 42 | #define CONFIG_SYS_FSL_PMU_CLTBENR (CONFIG_SYS_FSL_PMU_ADDR + \ |
| 43 | 0x18A0) |
Yunhui Cui | 3dfb82a | 2016-06-08 10:31:42 +0800 | [diff] [blame] | 44 | #define FSL_PMU_PCTBENR_OFFSET (CONFIG_SYS_FSL_PMU_ADDR + 0x8A0) |
Priyanka Jain | 96b001f | 2016-11-17 12:29:51 +0530 | [diff] [blame] | 45 | #define FSL_LSCH3_SVR (CONFIG_SYS_FSL_GUTS_ADDR + 0xA4) |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 46 | |
| 47 | #define CONFIG_SYS_FSL_WRIOP1_ADDR (CONFIG_SYS_IMMR + 0x7B80000) |
| 48 | #define CONFIG_SYS_FSL_WRIOP1_MDIO1 (CONFIG_SYS_FSL_WRIOP1_ADDR + 0x16000) |
| 49 | #define CONFIG_SYS_FSL_WRIOP1_MDIO2 (CONFIG_SYS_FSL_WRIOP1_ADDR + 0x17000) |
| 50 | #define CONFIG_SYS_FSL_LSCH3_SERDES_ADDR (CONFIG_SYS_IMMR + 0xEA0000) |
| 51 | |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 52 | #define CONFIG_SYS_FSL_DCSR_DDR_ADDR 0x70012c000ULL |
| 53 | #define CONFIG_SYS_FSL_DCSR_DDR2_ADDR 0x70012d000ULL |
| 54 | #define CONFIG_SYS_FSL_DCSR_DDR3_ADDR 0x700132000ULL |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 55 | |
| 56 | #define I2C1_BASE_ADDR (CONFIG_SYS_IMMR + 0x01000000) |
| 57 | #define I2C2_BASE_ADDR (CONFIG_SYS_IMMR + 0x01010000) |
| 58 | #define I2C3_BASE_ADDR (CONFIG_SYS_IMMR + 0x01020000) |
| 59 | #define I2C4_BASE_ADDR (CONFIG_SYS_IMMR + 0x01030000) |
Priyanka Jain | 88c2566 | 2018-10-29 09:11:29 +0000 | [diff] [blame] | 60 | #ifdef CONFIG_NXP_LSCH3_2 |
| 61 | #define I2C5_BASE_ADDR (CONFIG_SYS_IMMR + 0x01040000) |
| 62 | #define I2C6_BASE_ADDR (CONFIG_SYS_IMMR + 0x01050000) |
| 63 | #define I2C7_BASE_ADDR (CONFIG_SYS_IMMR + 0x01060000) |
| 64 | #define I2C8_BASE_ADDR (CONFIG_SYS_IMMR + 0x01070000) |
| 65 | #endif |
Priyanka Jain | d158718 | 2017-04-25 10:12:31 +0530 | [diff] [blame] | 66 | #define GPIO4_BASE_ADDR (CONFIG_SYS_IMMR + 0x01330000) |
| 67 | #define GPIO4_GPDIR_ADDR (GPIO4_BASE_ADDR + 0x0) |
| 68 | #define GPIO4_GPDAT_ADDR (GPIO4_BASE_ADDR + 0x8) |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 69 | |
Rajesh Bhagat | 386f2e4 | 2016-06-07 18:59:34 +0530 | [diff] [blame] | 70 | #define CONFIG_SYS_XHCI_USB1_ADDR (CONFIG_SYS_IMMR + 0x02100000) |
| 71 | #define CONFIG_SYS_XHCI_USB2_ADDR (CONFIG_SYS_IMMR + 0x02110000) |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 72 | |
| 73 | /* TZ Address Space Controller Definitions */ |
| 74 | #define TZASC1_BASE 0x01100000 /* as per CCSR map. */ |
| 75 | #define TZASC2_BASE 0x01110000 /* as per CCSR map. */ |
| 76 | #define TZASC3_BASE 0x01120000 /* as per CCSR map. */ |
| 77 | #define TZASC4_BASE 0x01130000 /* as per CCSR map. */ |
| 78 | #define TZASC_BUILD_CONFIG_REG(x) ((TZASC1_BASE + (x * 0x10000))) |
| 79 | #define TZASC_ACTION_REG(x) ((TZASC1_BASE + (x * 0x10000)) + 0x004) |
| 80 | #define TZASC_GATE_KEEPER(x) ((TZASC1_BASE + (x * 0x10000)) + 0x008) |
| 81 | #define TZASC_REGION_BASE_LOW_0(x) ((TZASC1_BASE + (x * 0x10000)) + 0x100) |
| 82 | #define TZASC_REGION_BASE_HIGH_0(x) ((TZASC1_BASE + (x * 0x10000)) + 0x104) |
| 83 | #define TZASC_REGION_TOP_LOW_0(x) ((TZASC1_BASE + (x * 0x10000)) + 0x108) |
| 84 | #define TZASC_REGION_TOP_HIGH_0(x) ((TZASC1_BASE + (x * 0x10000)) + 0x10C) |
| 85 | #define TZASC_REGION_ATTRIBUTES_0(x) ((TZASC1_BASE + (x * 0x10000)) + 0x110) |
| 86 | #define TZASC_REGION_ID_ACCESS_0(x) ((TZASC1_BASE + (x * 0x10000)) + 0x114) |
| 87 | |
Laurentiu Tudor | e29ca39 | 2019-07-30 17:29:56 +0300 | [diff] [blame] | 88 | /* EDMA */ |
| 89 | #define EDMA_BASE_ADDR (CONFIG_SYS_IMMR + 0x012c0000) |
| 90 | |
Tang Yuantian | 57894be | 2015-12-09 15:32:18 +0800 | [diff] [blame] | 91 | /* SATA */ |
| 92 | #define AHCI_BASE_ADDR1 (CONFIG_SYS_IMMR + 0x02200000) |
| 93 | #define AHCI_BASE_ADDR2 (CONFIG_SYS_IMMR + 0x02210000) |
Laurentiu Tudor | 1585835 | 2019-10-18 09:01:54 +0000 | [diff] [blame] | 94 | #define AHCI_BASE_ADDR3 (CONFIG_SYS_IMMR + 0x02220000) |
| 95 | #define AHCI_BASE_ADDR4 (CONFIG_SYS_IMMR + 0x02230000) |
Tang Yuantian | 57894be | 2015-12-09 15:32:18 +0800 | [diff] [blame] | 96 | |
Laurentiu Tudor | e29ca39 | 2019-07-30 17:29:56 +0300 | [diff] [blame] | 97 | /* QDMA */ |
| 98 | #define QDMA_BASE_ADDR (CONFIG_SYS_IMMR + 0x07380000) |
| 99 | #define QMAN_CQSIDR_REG 0x20a80 |
| 100 | |
| 101 | /* DISPLAY */ |
| 102 | #define DISPLAY_BASE_ADDR (CONFIG_SYS_IMMR + 0x0e080000) |
| 103 | |
| 104 | /* GPU */ |
| 105 | #define GPU_BASE_ADDR (CONFIG_SYS_IMMR + 0x0e0c0000) |
| 106 | |
Saksham Jain | 62888be | 2016-03-23 16:24:32 +0530 | [diff] [blame] | 107 | /* SFP */ |
| 108 | #define CONFIG_SYS_SFP_ADDR (CONFIG_SYS_IMMR + 0x00e80200) |
| 109 | |
Saksham Jain | 6ae7f58 | 2016-03-23 16:24:33 +0530 | [diff] [blame] | 110 | /* SEC */ |
Alex Porosanu | 177fca8 | 2016-04-29 15:17:58 +0300 | [diff] [blame] | 111 | #define CONFIG_SYS_FSL_SEC_OFFSET 0x07000000ull |
| 112 | #define CONFIG_SYS_FSL_JR0_OFFSET 0x07010000ull |
Laurentiu Tudor | 32f4c16 | 2019-07-30 17:29:55 +0300 | [diff] [blame] | 113 | #define FSL_SEC_JR0_OFFSET CONFIG_SYS_FSL_JR0_OFFSET |
| 114 | #define FSL_SEC_JR1_OFFSET 0x07020000ull |
| 115 | #define FSL_SEC_JR2_OFFSET 0x07030000ull |
| 116 | #define FSL_SEC_JR3_OFFSET 0x07040000ull |
Alex Porosanu | 177fca8 | 2016-04-29 15:17:58 +0300 | [diff] [blame] | 117 | #define CONFIG_SYS_FSL_SEC_ADDR \ |
| 118 | (CONFIG_SYS_IMMR + CONFIG_SYS_FSL_SEC_OFFSET) |
| 119 | #define CONFIG_SYS_FSL_JR0_ADDR \ |
| 120 | (CONFIG_SYS_IMMR + CONFIG_SYS_FSL_JR0_OFFSET) |
Laurentiu Tudor | 32f4c16 | 2019-07-30 17:29:55 +0300 | [diff] [blame] | 121 | #define FSL_SEC_JR0_BASE_ADDR (CONFIG_SYS_IMMR + FSL_SEC_JR0_OFFSET) |
| 122 | #define FSL_SEC_JR1_BASE_ADDR (CONFIG_SYS_IMMR + FSL_SEC_JR1_OFFSET) |
| 123 | #define FSL_SEC_JR2_BASE_ADDR (CONFIG_SYS_IMMR + FSL_SEC_JR2_OFFSET) |
| 124 | #define FSL_SEC_JR3_BASE_ADDR (CONFIG_SYS_IMMR + FSL_SEC_JR3_OFFSET) |
Saksham Jain | 6ae7f58 | 2016-03-23 16:24:33 +0530 | [diff] [blame] | 125 | |
Rajesh Bhagat | 583da8b | 2018-11-05 18:01:42 +0000 | [diff] [blame] | 126 | #ifdef CONFIG_TFABOOT |
Priyanka Jain | 88c2566 | 2018-10-29 09:11:29 +0000 | [diff] [blame] | 127 | #ifdef CONFIG_NXP_LSCH3_2 |
Rajesh Bhagat | 583da8b | 2018-11-05 18:01:42 +0000 | [diff] [blame] | 128 | /* RCW_SRC field in Power-On Reset Control Register 1 */ |
| 129 | #define RCW_SRC_MASK 0x07800000 |
| 130 | #define RCW_SRC_BIT 23 |
| 131 | |
| 132 | /* CFG_RCW_SRC[3:0] */ |
| 133 | #define RCW_SRC_TYPE_MASK 0x8 |
| 134 | #define RCW_SRC_ADDR_OFFSET_8MB 0x800000 |
| 135 | |
| 136 | /* RCW SRC HARDCODED */ |
| 137 | #define RCW_SRC_HARDCODED_VAL 0x0 /* 0x00 - 0x07 */ |
| 138 | |
| 139 | #define RCW_SRC_SDHC1_VAL 0x8 /* 0x8 */ |
| 140 | #define RCW_SRC_SDHC2_VAL 0x9 /* 0x9 */ |
| 141 | #define RCW_SRC_I2C1_VAL 0xa /* 0xa */ |
| 142 | #define RCW_SRC_RESERVED_UART_VAL 0xb /* 0xb */ |
| 143 | #define RCW_SRC_FLEXSPI_NAND2K_VAL 0xc /* 0xc */ |
| 144 | #define RCW_SRC_FLEXSPI_NAND4K_VAL 0xd /* 0xd */ |
| 145 | #define RCW_SRC_RESERVED_1_VAL 0xe /* 0xe */ |
| 146 | #define RCW_SRC_FLEXSPI_NOR_24B 0xf /* 0xf */ |
| 147 | #else |
| 148 | #define RCW_SRC_MASK (0xFF800000) |
| 149 | #define RCW_SRC_BIT 23 |
| 150 | /* CFG_RCW_SRC[6:0] */ |
| 151 | #define RCW_SRC_TYPE_MASK (0x70) |
| 152 | |
| 153 | /* RCW SRC HARDCODED */ |
| 154 | #define RCW_SRC_HARDCODED_VAL (0x10) /* 0x10 - 0x1f */ |
| 155 | /* Hardcoded will also have CFG_RCW_SRC[7] as 1. 0x90 - 0x9f */ |
| 156 | |
| 157 | /* RCW SRC NOR */ |
| 158 | #define RCW_SRC_NOR_VAL (0x20) |
| 159 | #define NOR_TYPE_MASK (0x10) |
| 160 | #define NOR_16B_VAL (0x0) /* 0x20 - 0x2f */ |
| 161 | #define NOR_32B_VAL (0x10) /* 0x30 - 0x3f */ |
| 162 | |
| 163 | /* RCW SRC Serial Flash |
| 164 | * 1. SERIAL NOR (QSPI) |
| 165 | * 2. OTHERS (SD/MMC, SPI, I2C1 |
| 166 | */ |
| 167 | #define RCW_SRC_SERIAL_MASK (0x7F) |
| 168 | #define RCW_SRC_QSPI_VAL (0x62) /* 0x62 */ |
| 169 | #define RCW_SRC_SD_CARD_VAL (0x40) /* 0x40 */ |
| 170 | #define RCW_SRC_EMMC_VAL (0x41) /* 0x41 */ |
| 171 | #define RCW_SRC_I2C1_VAL (0x49) /* 0x49 */ |
| 172 | #endif |
| 173 | #endif |
| 174 | |
Saksham Jain | 6ae7f58 | 2016-03-23 16:24:33 +0530 | [diff] [blame] | 175 | /* Security Monitor */ |
| 176 | #define CONFIG_SYS_SEC_MON_ADDR (CONFIG_SYS_IMMR + 0x00e90000) |
| 177 | |
Saksham Jain | 5d8ffe1 | 2016-03-23 16:24:40 +0530 | [diff] [blame] | 178 | /* MMU 500 */ |
| 179 | #define SMMU_SCR0 (SMMU_BASE + 0x0) |
| 180 | #define SMMU_SCR1 (SMMU_BASE + 0x4) |
| 181 | #define SMMU_SCR2 (SMMU_BASE + 0x8) |
| 182 | #define SMMU_SACR (SMMU_BASE + 0x10) |
| 183 | #define SMMU_IDR0 (SMMU_BASE + 0x20) |
| 184 | #define SMMU_IDR1 (SMMU_BASE + 0x24) |
| 185 | |
| 186 | #define SMMU_NSCR0 (SMMU_BASE + 0x400) |
| 187 | #define SMMU_NSCR2 (SMMU_BASE + 0x408) |
| 188 | #define SMMU_NSACR (SMMU_BASE + 0x410) |
| 189 | |
| 190 | #define SCR0_CLIENTPD_MASK 0x00000001 |
| 191 | #define SCR0_USFCFG_MASK 0x00000400 |
| 192 | |
Saksham Jain | 6ae7f58 | 2016-03-23 16:24:33 +0530 | [diff] [blame] | 193 | |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 194 | /* PCIe */ |
| 195 | #define CONFIG_SYS_PCIE1_ADDR (CONFIG_SYS_IMMR + 0x2400000) |
| 196 | #define CONFIG_SYS_PCIE2_ADDR (CONFIG_SYS_IMMR + 0x2500000) |
| 197 | #define CONFIG_SYS_PCIE3_ADDR (CONFIG_SYS_IMMR + 0x2600000) |
| 198 | #define CONFIG_SYS_PCIE4_ADDR (CONFIG_SYS_IMMR + 0x2700000) |
Meenakshi Aggarwal | ccb5d5d | 2020-10-29 19:16:16 +0530 | [diff] [blame] | 199 | #if defined(CONFIG_ARCH_LX2160A) || defined(CONFIG_ARCH_LX2162A) |
Hou Zhiqiang | d08f970 | 2019-04-08 10:15:41 +0000 | [diff] [blame] | 200 | #define SYS_PCIE5_ADDR (CONFIG_SYS_IMMR + 0x2800000) |
| 201 | #define SYS_PCIE6_ADDR (CONFIG_SYS_IMMR + 0x2900000) |
| 202 | #endif |
| 203 | |
Meenakshi Aggarwal | ccb5d5d | 2020-10-29 19:16:16 +0530 | [diff] [blame] | 204 | #if defined(CONFIG_ARCH_LX2160A) || defined(CONFIG_ARCH_LX2162A) |
Hou Zhiqiang | d08f970 | 2019-04-08 10:15:41 +0000 | [diff] [blame] | 205 | #define CONFIG_SYS_PCIE1_PHYS_ADDR 0x8000000000ULL |
| 206 | #define CONFIG_SYS_PCIE2_PHYS_ADDR 0x8800000000ULL |
| 207 | #define CONFIG_SYS_PCIE3_PHYS_ADDR 0x9000000000ULL |
| 208 | #define CONFIG_SYS_PCIE4_PHYS_ADDR 0x9800000000ULL |
| 209 | #define SYS_PCIE5_PHYS_ADDR 0xa000000000ULL |
| 210 | #define SYS_PCIE6_PHYS_ADDR 0xa800000000ULL |
| 211 | #elif CONFIG_ARCH_LS1088A |
Hou Zhiqiang | 1914312 | 2017-09-04 10:47:52 +0800 | [diff] [blame] | 212 | #define CONFIG_SYS_PCIE1_PHYS_ADDR 0x2000000000ULL |
| 213 | #define CONFIG_SYS_PCIE2_PHYS_ADDR 0x2800000000ULL |
| 214 | #define CONFIG_SYS_PCIE3_PHYS_ADDR 0x3000000000ULL |
Yuantian Tang | 4aefa16 | 2019-04-10 16:43:33 +0800 | [diff] [blame] | 215 | #elif CONFIG_ARCH_LS1028A |
| 216 | #define CONFIG_SYS_PCIE1_PHYS_ADDR 0x8000000000ULL |
| 217 | #define CONFIG_SYS_PCIE2_PHYS_ADDR 0x8800000000ULL |
Alex Marginean | 0d5ed8f | 2019-06-07 17:03:07 +0300 | [diff] [blame] | 218 | #define CONFIG_SYS_PCIE3_PHYS_ADDR 0x01f0000000ULL |
| 219 | /* this is used by integrated PCI on LS1028, includes ECAM and register space */ |
| 220 | #define CONFIG_SYS_PCIE3_PHYS_SIZE 0x0010000000ULL |
Hou Zhiqiang | 1914312 | 2017-09-04 10:47:52 +0800 | [diff] [blame] | 221 | #else |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 222 | #define CONFIG_SYS_PCIE1_PHYS_ADDR 0x1000000000ULL |
| 223 | #define CONFIG_SYS_PCIE2_PHYS_ADDR 0x1200000000ULL |
| 224 | #define CONFIG_SYS_PCIE3_PHYS_ADDR 0x1400000000ULL |
| 225 | #define CONFIG_SYS_PCIE4_PHYS_ADDR 0x1600000000ULL |
Hou Zhiqiang | 1914312 | 2017-09-04 10:47:52 +0800 | [diff] [blame] | 226 | #endif |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 227 | |
| 228 | /* Device Configuration */ |
| 229 | #define DCFG_BASE 0x01e00000 |
| 230 | #define DCFG_PORSR1 0x000 |
| 231 | #define DCFG_PORSR1_RCW_SRC 0xff800000 |
Michael Walle | 98fbb56 | 2022-05-30 23:02:05 +0200 | [diff] [blame] | 232 | #define DCFG_PORSR1_RCW_SRC_SDHC1 0x04000000 |
| 233 | #define DCFG_PORSR1_RCW_SRC_SDHC2 0x04800000 |
| 234 | #define DCFG_PORSR1_RCW_SRC_I2C 0x05000000 |
| 235 | #define DCFG_PORSR1_RCW_SRC_FSPI_NOR 0x07800000 |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 236 | #define DCFG_PORSR1_RCW_SRC_NOR 0x12f00000 |
Yinbo Zhu | 96cd3d4 | 2020-04-14 17:24:48 +0800 | [diff] [blame] | 237 | #define DCFG_RCWSR12 0x12c |
| 238 | #define DCFG_RCWSR12_SDHC_SHIFT 24 |
| 239 | #define DCFG_RCWSR12_SDHC_MASK 0x7 |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 240 | #define DCFG_RCWSR13 0x130 |
Yinbo Zhu | 96cd3d4 | 2020-04-14 17:24:48 +0800 | [diff] [blame] | 241 | #define DCFG_RCWSR13_SDHC_SHIFT 3 |
| 242 | #define DCFG_RCWSR13_SDHC_MASK 0x7 |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 243 | #define DCFG_RCWSR13_DSPI (0 << 8) |
Yuan Yao | 86f42d7 | 2016-06-08 18:24:57 +0800 | [diff] [blame] | 244 | #define DCFG_RCWSR15 0x138 |
| 245 | #define DCFG_RCWSR15_IFCGRPABASE_QSPI 0x3 |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 246 | |
| 247 | #define DCFG_DCSR_BASE 0X700100000ULL |
| 248 | #define DCFG_DCSR_PORCR1 0x000 |
| 249 | |
Shaohui Xie | 8c7ce82 | 2016-01-28 15:38:15 +0800 | [diff] [blame] | 250 | /* Interrupt Sampling Control */ |
| 251 | #define ISC_BASE 0x01F70000 |
| 252 | #define IRQCR_OFFSET 0x14 |
| 253 | |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 254 | /* Supplemental Configuration */ |
| 255 | #define SCFG_BASE 0x01fc0000 |
| 256 | #define SCFG_USB3PRM1CR 0x000 |
Sriram Dash | 0182095 | 2016-06-13 09:58:36 +0530 | [diff] [blame] | 257 | #define SCFG_USB3PRM1CR_INIT 0x27672b2a |
Ran Wang | b358b7b | 2017-09-04 18:46:48 +0800 | [diff] [blame] | 258 | #define SCFG_USB_TXVREFTUNE 0x9 |
Ran Wang | 9e8fabc | 2017-09-04 18:46:49 +0800 | [diff] [blame] | 259 | #define SCFG_USB_SQRXTUNE_MASK 0x7 |
Yuan Yao | 2ec8584 | 2016-06-08 18:24:52 +0800 | [diff] [blame] | 260 | #define SCFG_QSPICLKCTLR 0x10 |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 261 | |
Ran Wang | 3ba6948 | 2017-09-04 18:46:51 +0800 | [diff] [blame] | 262 | #define DCSR_BASE 0x700000000ULL |
| 263 | #define DCSR_USB_PHY1 0x4600000 |
| 264 | #define DCSR_USB_PHY2 0x4610000 |
| 265 | #define DCSR_USB_PHY_RX_OVRD_IN_HI 0x200C |
| 266 | #define USB_PHY_RX_EQ_VAL_1 0x0000 |
| 267 | #define USB_PHY_RX_EQ_VAL_2 0x0080 |
Ran Wang | d0270dc | 2019-11-26 11:40:40 +0800 | [diff] [blame] | 268 | #if defined(CONFIG_ARCH_LS2080A) || defined(CONFIG_ARCH_LS1088A) || \ |
| 269 | defined(CONFIG_ARCH_LS1028A) |
Ran Wang | 3ba6948 | 2017-09-04 18:46:51 +0800 | [diff] [blame] | 270 | #define USB_PHY_RX_EQ_VAL_3 0x0380 |
| 271 | #define USB_PHY_RX_EQ_VAL_4 0x0b80 |
Meenakshi Aggarwal | ccb5d5d | 2020-10-29 19:16:16 +0530 | [diff] [blame] | 272 | #elif defined(CONFIG_ARCH_LX2160A) || defined(CONFIG_ARCH_LX2162A) |
Ran Wang | d0270dc | 2019-11-26 11:40:40 +0800 | [diff] [blame] | 273 | #define USB_PHY_RX_EQ_VAL_3 0x0080 |
| 274 | #define USB_PHY_RX_EQ_VAL_4 0x0880 |
| 275 | #endif |
Ran Wang | e118acb | 2019-05-14 17:34:56 +0800 | [diff] [blame] | 276 | #define DCSR_USB_IOCR1 0x108004 |
| 277 | #define DCSR_USB_PCSTXSWINGFULL 0x71 |
Ran Wang | 3ba6948 | 2017-09-04 18:46:51 +0800 | [diff] [blame] | 278 | |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 279 | #define TP_ITYP_AV 0x00000001 /* Initiator available */ |
| 280 | #define TP_ITYP_TYPE(x) (((x) & 0x6) >> 1) /* Initiator Type */ |
| 281 | #define TP_ITYP_TYPE_ARM 0x0 |
| 282 | #define TP_ITYP_TYPE_PPC 0x1 /* PowerPC */ |
| 283 | #define TP_ITYP_TYPE_OTHER 0x2 /* StarCore DSP */ |
| 284 | #define TP_ITYP_TYPE_HA 0x3 /* HW Accelerator */ |
| 285 | #define TP_ITYP_THDS(x) (((x) & 0x18) >> 3) /* # threads */ |
| 286 | #define TP_ITYP_VER(x) (((x) & 0xe0) >> 5) /* Initiator Version */ |
| 287 | #define TY_ITYP_VER_A7 0x1 |
| 288 | #define TY_ITYP_VER_A53 0x2 |
| 289 | #define TY_ITYP_VER_A57 0x3 |
Alison Wang | 7980839 | 2016-07-05 16:01:52 +0800 | [diff] [blame] | 290 | #define TY_ITYP_VER_A72 0x4 |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 291 | |
| 292 | #define TP_CLUSTER_EOC 0x80000000 /* end of clusters */ |
| 293 | #define TP_CLUSTER_INIT_MASK 0x0000003f /* initiator mask */ |
| 294 | #define TP_INIT_PER_CLUSTER 4 |
| 295 | /* This is chassis generation 3 */ |
Priyanka Jain | 96b001f | 2016-11-17 12:29:51 +0530 | [diff] [blame] | 296 | #ifndef __ASSEMBLY__ |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 297 | struct sys_info { |
| 298 | unsigned long freq_processor[CONFIG_MAX_CPUS]; |
Hou Zhiqiang | 3a76dd5 | 2017-01-10 16:44:16 +0800 | [diff] [blame] | 299 | /* frequency of platform PLL */ |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 300 | unsigned long freq_systembus; |
| 301 | unsigned long freq_ddrbus; |
Yinbo Zhu | 3761ffc | 2019-07-16 15:09:06 +0800 | [diff] [blame] | 302 | unsigned long freq_cga_m2; |
Prabhakar Kushwaha | 122bcfd | 2015-11-09 16:42:07 +0530 | [diff] [blame] | 303 | #ifdef CONFIG_SYS_FSL_HAS_DP_DDR |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 304 | unsigned long freq_ddrbus2; |
Prabhakar Kushwaha | 122bcfd | 2015-11-09 16:42:07 +0530 | [diff] [blame] | 305 | #endif |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 306 | unsigned long freq_localbus; |
| 307 | unsigned long freq_qe; |
| 308 | #ifdef CONFIG_SYS_DPAA_FMAN |
| 309 | unsigned long freq_fman[CONFIG_SYS_NUM_FMAN]; |
| 310 | #endif |
| 311 | #ifdef CONFIG_SYS_DPAA_QBMAN |
| 312 | unsigned long freq_qman; |
| 313 | #endif |
| 314 | #ifdef CONFIG_SYS_DPAA_PME |
| 315 | unsigned long freq_pme; |
| 316 | #endif |
| 317 | }; |
| 318 | |
| 319 | /* Global Utilities Block */ |
| 320 | struct ccsr_gur { |
| 321 | u32 porsr1; /* POR status 1 */ |
| 322 | u32 porsr2; /* POR status 2 */ |
| 323 | u8 res_008[0x20-0x8]; |
| 324 | u32 gpporcr1; /* General-purpose POR configuration */ |
| 325 | u32 gpporcr2; /* General-purpose POR configuration 2 */ |
Priyanka Jain | 1b4b760 | 2017-01-19 11:12:26 +0530 | [diff] [blame] | 326 | u32 gpporcr3; |
| 327 | u32 gpporcr4; |
| 328 | u8 res_030[0x60-0x30]; |
Rai Harninder | 6aa1f3b | 2016-03-23 17:04:38 +0530 | [diff] [blame] | 329 | #define FSL_CHASSIS3_DCFG_FUSESR_VID_MASK 0x1F |
Rai Harninder | 6aa1f3b | 2016-03-23 17:04:38 +0530 | [diff] [blame] | 330 | #define FSL_CHASSIS3_DCFG_FUSESR_ALTVID_MASK 0x1F |
Rajesh Bhagat | 170eecf | 2018-01-17 16:13:05 +0530 | [diff] [blame] | 331 | #if defined(CONFIG_ARCH_LS1088A) |
| 332 | #define FSL_CHASSIS3_DCFG_FUSESR_VID_SHIFT 25 |
| 333 | #define FSL_CHASSIS3_DCFG_FUSESR_ALTVID_SHIFT 20 |
| 334 | #else |
| 335 | #define FSL_CHASSIS3_DCFG_FUSESR_VID_SHIFT 2 |
| 336 | #define FSL_CHASSIS3_DCFG_FUSESR_ALTVID_SHIFT 7 |
| 337 | #endif |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 338 | u32 dcfg_fusesr; /* Fuse status register */ |
Priyanka Jain | 1b4b760 | 2017-01-19 11:12:26 +0530 | [diff] [blame] | 339 | u8 res_064[0x70-0x64]; |
| 340 | u32 devdisr; /* Device disable control 1 */ |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 341 | u32 devdisr2; /* Device disable control 2 */ |
| 342 | u32 devdisr3; /* Device disable control 3 */ |
| 343 | u32 devdisr4; /* Device disable control 4 */ |
| 344 | u32 devdisr5; /* Device disable control 5 */ |
| 345 | u32 devdisr6; /* Device disable control 6 */ |
Priyanka Jain | 1b4b760 | 2017-01-19 11:12:26 +0530 | [diff] [blame] | 346 | u8 res_088[0x94-0x88]; |
| 347 | u32 coredisr; /* Device disable control 7 */ |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 348 | #define FSL_CHASSIS3_DEVDISR2_DPMAC1 0x00000001 |
| 349 | #define FSL_CHASSIS3_DEVDISR2_DPMAC2 0x00000002 |
| 350 | #define FSL_CHASSIS3_DEVDISR2_DPMAC3 0x00000004 |
| 351 | #define FSL_CHASSIS3_DEVDISR2_DPMAC4 0x00000008 |
| 352 | #define FSL_CHASSIS3_DEVDISR2_DPMAC5 0x00000010 |
| 353 | #define FSL_CHASSIS3_DEVDISR2_DPMAC6 0x00000020 |
| 354 | #define FSL_CHASSIS3_DEVDISR2_DPMAC7 0x00000040 |
| 355 | #define FSL_CHASSIS3_DEVDISR2_DPMAC8 0x00000080 |
| 356 | #define FSL_CHASSIS3_DEVDISR2_DPMAC9 0x00000100 |
| 357 | #define FSL_CHASSIS3_DEVDISR2_DPMAC10 0x00000200 |
| 358 | #define FSL_CHASSIS3_DEVDISR2_DPMAC11 0x00000400 |
| 359 | #define FSL_CHASSIS3_DEVDISR2_DPMAC12 0x00000800 |
| 360 | #define FSL_CHASSIS3_DEVDISR2_DPMAC13 0x00001000 |
| 361 | #define FSL_CHASSIS3_DEVDISR2_DPMAC14 0x00002000 |
| 362 | #define FSL_CHASSIS3_DEVDISR2_DPMAC15 0x00004000 |
| 363 | #define FSL_CHASSIS3_DEVDISR2_DPMAC16 0x00008000 |
| 364 | #define FSL_CHASSIS3_DEVDISR2_DPMAC17 0x00010000 |
| 365 | #define FSL_CHASSIS3_DEVDISR2_DPMAC18 0x00020000 |
| 366 | #define FSL_CHASSIS3_DEVDISR2_DPMAC19 0x00040000 |
| 367 | #define FSL_CHASSIS3_DEVDISR2_DPMAC20 0x00080000 |
| 368 | #define FSL_CHASSIS3_DEVDISR2_DPMAC21 0x00100000 |
| 369 | #define FSL_CHASSIS3_DEVDISR2_DPMAC22 0x00200000 |
| 370 | #define FSL_CHASSIS3_DEVDISR2_DPMAC23 0x00400000 |
| 371 | #define FSL_CHASSIS3_DEVDISR2_DPMAC24 0x00800000 |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 372 | u8 res_098[0xa0-0x98]; |
| 373 | u32 pvr; /* Processor version */ |
| 374 | u32 svr; /* System version */ |
Priyanka Jain | 1b4b760 | 2017-01-19 11:12:26 +0530 | [diff] [blame] | 375 | u8 res_0a8[0x100-0xa8]; |
| 376 | u32 rcwsr[30]; /* Reset control word status */ |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 377 | |
| 378 | #define FSL_CHASSIS3_RCWSR0_SYS_PLL_RAT_SHIFT 2 |
| 379 | #define FSL_CHASSIS3_RCWSR0_SYS_PLL_RAT_MASK 0x1f |
| 380 | #define FSL_CHASSIS3_RCWSR0_MEM_PLL_RAT_SHIFT 10 |
| 381 | #define FSL_CHASSIS3_RCWSR0_MEM_PLL_RAT_MASK 0x3f |
| 382 | #define FSL_CHASSIS3_RCWSR0_MEM2_PLL_RAT_SHIFT 18 |
| 383 | #define FSL_CHASSIS3_RCWSR0_MEM2_PLL_RAT_MASK 0x3f |
Prabhakar Kushwaha | 57f7f2ed | 2017-02-15 20:40:35 +0530 | [diff] [blame] | 384 | |
| 385 | #if defined(CONFIG_ARCH_LS2080A) |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 386 | #define FSL_CHASSIS3_RCWSR28_SRDS1_PRTCL_MASK 0x00FF0000 |
| 387 | #define FSL_CHASSIS3_RCWSR28_SRDS1_PRTCL_SHIFT 16 |
| 388 | #define FSL_CHASSIS3_RCWSR28_SRDS2_PRTCL_MASK 0xFF000000 |
| 389 | #define FSL_CHASSIS3_RCWSR28_SRDS2_PRTCL_SHIFT 24 |
Prabhakar Kushwaha | 57f7f2ed | 2017-02-15 20:40:35 +0530 | [diff] [blame] | 390 | #define FSL_CHASSIS3_SRDS1_PRTCL_MASK FSL_CHASSIS3_RCWSR28_SRDS1_PRTCL_MASK |
| 391 | #define FSL_CHASSIS3_SRDS1_PRTCL_SHIFT FSL_CHASSIS3_RCWSR28_SRDS1_PRTCL_SHIFT |
| 392 | #define FSL_CHASSIS3_SRDS2_PRTCL_MASK FSL_CHASSIS3_RCWSR28_SRDS2_PRTCL_MASK |
| 393 | #define FSL_CHASSIS3_SRDS2_PRTCL_SHIFT FSL_CHASSIS3_RCWSR28_SRDS2_PRTCL_SHIFT |
Priyanka Jain | ef76b2e | 2018-10-29 09:17:09 +0000 | [diff] [blame] | 394 | #define FSL_CHASSIS3_SRDS1_REGSR 29 |
| 395 | #define FSL_CHASSIS3_SRDS2_REGSR 29 |
Meenakshi Aggarwal | ccb5d5d | 2020-10-29 19:16:16 +0530 | [diff] [blame] | 396 | #elif defined(CONFIG_ARCH_LX2160A) || defined(CONFIG_ARCH_LX2162A) |
Priyanka Jain | ef76b2e | 2018-10-29 09:17:09 +0000 | [diff] [blame] | 397 | #define FSL_CHASSIS3_EC1_REGSR 27 |
| 398 | #define FSL_CHASSIS3_EC2_REGSR 27 |
| 399 | #define FSL_CHASSIS3_EC1_REGSR_PRTCL_MASK 0x00000003 |
| 400 | #define FSL_CHASSIS3_EC1_REGSR_PRTCL_SHIFT 0 |
Razvan Ionut Cirjan | 912f2d8 | 2020-10-23 16:20:38 +0530 | [diff] [blame] | 401 | #define FSL_CHASSIS3_EC2_REGSR_PRTCL_MASK 0x0000000C |
Priyanka Jain | ef76b2e | 2018-10-29 09:17:09 +0000 | [diff] [blame] | 402 | #define FSL_CHASSIS3_EC2_REGSR_PRTCL_SHIFT 2 |
| 403 | #define FSL_CHASSIS3_RCWSR28_SRDS1_PRTCL_MASK 0x001F0000 |
| 404 | #define FSL_CHASSIS3_RCWSR28_SRDS1_PRTCL_SHIFT 16 |
| 405 | #define FSL_CHASSIS3_RCWSR28_SRDS2_PRTCL_MASK 0x03E00000 |
| 406 | #define FSL_CHASSIS3_RCWSR28_SRDS2_PRTCL_SHIFT 21 |
| 407 | #define FSL_CHASSIS3_RCWSR28_SRDS3_PRTCL_MASK 0x7C000000 |
| 408 | #define FSL_CHASSIS3_RCWSR28_SRDS3_PRTCL_SHIFT 26 |
| 409 | #define FSL_CHASSIS3_SRDS1_PRTCL_MASK FSL_CHASSIS3_RCWSR28_SRDS1_PRTCL_MASK |
| 410 | #define FSL_CHASSIS3_SRDS1_PRTCL_SHIFT FSL_CHASSIS3_RCWSR28_SRDS1_PRTCL_SHIFT |
| 411 | #define FSL_CHASSIS3_SRDS2_PRTCL_MASK FSL_CHASSIS3_RCWSR28_SRDS2_PRTCL_MASK |
| 412 | #define FSL_CHASSIS3_SRDS2_PRTCL_SHIFT FSL_CHASSIS3_RCWSR28_SRDS2_PRTCL_SHIFT |
| 413 | #define FSL_CHASSIS3_SRDS3_PRTCL_MASK FSL_CHASSIS3_RCWSR28_SRDS3_PRTCL_MASK |
| 414 | #define FSL_CHASSIS3_SRDS3_PRTCL_SHIFT FSL_CHASSIS3_RCWSR28_SRDS3_PRTCL_SHIFT |
Prabhakar Kushwaha | 57f7f2ed | 2017-02-15 20:40:35 +0530 | [diff] [blame] | 415 | #define FSL_CHASSIS3_SRDS1_REGSR 29 |
| 416 | #define FSL_CHASSIS3_SRDS2_REGSR 29 |
Priyanka Jain | ef76b2e | 2018-10-29 09:17:09 +0000 | [diff] [blame] | 417 | #define FSL_CHASSIS3_SRDS3_REGSR 29 |
Pankaj Bansal | 338baa3 | 2019-02-08 10:29:58 +0000 | [diff] [blame] | 418 | #define FSL_CHASSIS3_RCWSR12_REGSR 12 |
| 419 | #define FSL_CHASSIS3_RCWSR13_REGSR 13 |
| 420 | #define FSL_CHASSIS3_SDHC1_BASE_PMUX_MASK 0x07000000 |
| 421 | #define FSL_CHASSIS3_SDHC1_BASE_PMUX_SHIFT 24 |
| 422 | #define FSL_CHASSIS3_SDHC2_BASE_PMUX_MASK 0x00000038 |
| 423 | #define FSL_CHASSIS3_SDHC2_BASE_PMUX_SHIFT 3 |
| 424 | #define FSL_CHASSIS3_IIC5_PMUX_MASK 0x00000E00 |
| 425 | #define FSL_CHASSIS3_IIC5_PMUX_SHIFT 9 |
Ashish Kumar | b25faa2 | 2017-08-31 16:12:53 +0530 | [diff] [blame] | 426 | #elif defined(CONFIG_ARCH_LS1088A) |
Ashish Kumar | ec455e2 | 2017-08-31 16:37:31 +0530 | [diff] [blame] | 427 | #define FSL_CHASSIS3_EC1_REGSR 26 |
| 428 | #define FSL_CHASSIS3_EC2_REGSR 26 |
| 429 | #define FSL_CHASSIS3_RCWSR25_EC1_PRTCL_MASK 0x00000007 |
| 430 | #define FSL_CHASSIS3_RCWSR25_EC1_PRTCL_SHIFT 0 |
| 431 | #define FSL_CHASSIS3_RCWSR25_EC2_PRTCL_MASK 0x00000038 |
| 432 | #define FSL_CHASSIS3_RCWSR25_EC2_PRTCL_SHIFT 3 |
Ashish Kumar | b25faa2 | 2017-08-31 16:12:53 +0530 | [diff] [blame] | 433 | #define FSL_CHASSIS3_RCWSR29_SRDS1_PRTCL_MASK 0xFFFF0000 |
| 434 | #define FSL_CHASSIS3_RCWSR29_SRDS1_PRTCL_SHIFT 16 |
| 435 | #define FSL_CHASSIS3_RCWSR30_SRDS2_PRTCL_MASK 0x0000FFFF |
| 436 | #define FSL_CHASSIS3_RCWSR30_SRDS2_PRTCL_SHIFT 0 |
| 437 | #define FSL_CHASSIS3_SRDS1_PRTCL_MASK FSL_CHASSIS3_RCWSR29_SRDS1_PRTCL_MASK |
| 438 | #define FSL_CHASSIS3_SRDS1_PRTCL_SHIFT FSL_CHASSIS3_RCWSR29_SRDS1_PRTCL_SHIFT |
| 439 | #define FSL_CHASSIS3_SRDS2_PRTCL_MASK FSL_CHASSIS3_RCWSR30_SRDS2_PRTCL_MASK |
| 440 | #define FSL_CHASSIS3_SRDS2_PRTCL_SHIFT FSL_CHASSIS3_RCWSR30_SRDS2_PRTCL_SHIFT |
| 441 | #define FSL_CHASSIS3_SRDS1_REGSR 29 |
| 442 | #define FSL_CHASSIS3_SRDS2_REGSR 30 |
Yuantian Tang | 4aefa16 | 2019-04-10 16:43:33 +0800 | [diff] [blame] | 443 | #elif defined(CONFIG_ARCH_LS1028A) |
| 444 | #define FSL_CHASSIS3_RCWSR29_SRDS1_PRTCL_MASK 0xFFFF0000 |
| 445 | #define FSL_CHASSIS3_RCWSR29_SRDS1_PRTCL_SHIFT 16 |
| 446 | #define FSL_CHASSIS3_SRDS1_PRTCL_MASK FSL_CHASSIS3_RCWSR29_SRDS1_PRTCL_MASK |
| 447 | #define FSL_CHASSIS3_SRDS1_PRTCL_SHIFT FSL_CHASSIS3_RCWSR29_SRDS1_PRTCL_SHIFT |
| 448 | #define FSL_CHASSIS3_SRDS1_REGSR 29 |
Prabhakar Kushwaha | 57f7f2ed | 2017-02-15 20:40:35 +0530 | [diff] [blame] | 449 | #endif |
Saksham Jain | 6ae7f58 | 2016-03-23 16:24:33 +0530 | [diff] [blame] | 450 | #define RCW_SB_EN_REG_INDEX 9 |
| 451 | #define RCW_SB_EN_MASK 0x00000400 |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 452 | |
Priyanka Jain | 1b4b760 | 2017-01-19 11:12:26 +0530 | [diff] [blame] | 453 | u8 res_178[0x200-0x178]; |
| 454 | u32 scratchrw[16]; /* Scratch Read/Write */ |
| 455 | u8 res_240[0x300-0x240]; |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 456 | u32 scratchw1r[4]; /* Scratch Read (Write once) */ |
| 457 | u8 res_310[0x400-0x310]; |
| 458 | u32 bootlocptrl; /* Boot location pointer low-order addr */ |
| 459 | u32 bootlocptrh; /* Boot location pointer high-order addr */ |
Priyanka Jain | 1b4b760 | 2017-01-19 11:12:26 +0530 | [diff] [blame] | 460 | u8 res_408[0x520-0x408]; |
| 461 | u32 usb1_amqr; |
| 462 | u32 usb2_amqr; |
| 463 | u8 res_528[0x530-0x528]; /* add more registers when needed */ |
| 464 | u32 sdmm1_amqr; |
Laurentiu Tudor | 01dc547 | 2019-07-30 17:29:59 +0300 | [diff] [blame] | 465 | u32 sdmm2_amqr; |
| 466 | u8 res_538[0x550 - 0x538]; /* add more registers when needed */ |
Priyanka Jain | 1b4b760 | 2017-01-19 11:12:26 +0530 | [diff] [blame] | 467 | u32 sata1_amqr; |
| 468 | u32 sata2_amqr; |
Laurentiu Tudor | 7085d07 | 2019-10-18 09:01:55 +0000 | [diff] [blame] | 469 | u32 sata3_amqr; |
| 470 | u32 sata4_amqr; |
| 471 | u8 res_560[0x570 - 0x560]; /* add more registers when needed */ |
Priyanka Jain | 1b4b760 | 2017-01-19 11:12:26 +0530 | [diff] [blame] | 472 | u32 misc1_amqr; |
| 473 | u8 res_574[0x590-0x574]; /* add more registers when needed */ |
| 474 | u32 spare1_amqr; |
| 475 | u32 spare2_amqr; |
Laurentiu Tudor | 01dc547 | 2019-07-30 17:29:59 +0300 | [diff] [blame] | 476 | u32 spare3_amqr; |
| 477 | u8 res_59c[0x620 - 0x59c]; /* add more registers when needed */ |
Priyanka Jain | 1b4b760 | 2017-01-19 11:12:26 +0530 | [diff] [blame] | 478 | u32 gencr[7]; /* General Control Registers */ |
| 479 | u8 res_63c[0x640-0x63c]; /* add more registers when needed */ |
| 480 | u32 cgensr1; /* Core General Status Register */ |
| 481 | u8 res_644[0x660-0x644]; /* add more registers when needed */ |
| 482 | u32 cgencr1; /* Core General Control Register */ |
| 483 | u8 res_664[0x740-0x664]; /* add more registers when needed */ |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 484 | u32 tp_ityp[64]; /* Topology Initiator Type Register */ |
| 485 | struct { |
| 486 | u32 upper; |
| 487 | u32 lower; |
Priyanka Jain | 1b4b760 | 2017-01-19 11:12:26 +0530 | [diff] [blame] | 488 | } tp_cluster[4]; /* Core cluster n Topology Register */ |
| 489 | u8 res_864[0x920-0x864]; /* add more registers when needed */ |
| 490 | u32 ioqoscr[8]; /*I/O Quality of Services Register */ |
| 491 | u32 uccr; |
| 492 | u8 res_944[0x960-0x944]; /* add more registers when needed */ |
| 493 | u32 ftmcr; |
| 494 | u8 res_964[0x990-0x964]; /* add more registers when needed */ |
| 495 | u32 coredisablesr; |
| 496 | u8 res_994[0xa00-0x994]; /* add more registers when needed */ |
| 497 | u32 sdbgcr; /*Secure Debug Confifuration Register */ |
| 498 | u8 res_a04[0xbf8-0xa04]; /* add more registers when needed */ |
| 499 | u32 ipbrr1; |
| 500 | u32 ipbrr2; |
| 501 | u8 res_858[0x1000-0xc00]; |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 502 | }; |
| 503 | |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 504 | struct ccsr_clk_cluster_group { |
| 505 | struct { |
| 506 | u8 res_00[0x10]; |
| 507 | u32 csr; |
| 508 | u8 res_14[0x20-0x14]; |
| 509 | } hwncsr[3]; |
| 510 | u8 res_60[0x80-0x60]; |
| 511 | struct { |
| 512 | u32 gsr; |
| 513 | u8 res_84[0xa0-0x84]; |
| 514 | } pllngsr[3]; |
| 515 | u8 res_e0[0x100-0xe0]; |
| 516 | }; |
| 517 | |
| 518 | struct ccsr_clk_ctrl { |
| 519 | struct { |
| 520 | u32 csr; /* core cluster n clock control status */ |
| 521 | u8 res_04[0x20-0x04]; |
| 522 | } clkcncsr[8]; |
| 523 | }; |
| 524 | |
| 525 | struct ccsr_reset { |
| 526 | u32 rstcr; /* 0x000 */ |
| 527 | u32 rstcrsp; /* 0x004 */ |
| 528 | u8 res_008[0x10-0x08]; /* 0x008 */ |
| 529 | u32 rstrqmr1; /* 0x010 */ |
| 530 | u32 rstrqmr2; /* 0x014 */ |
| 531 | u32 rstrqsr1; /* 0x018 */ |
| 532 | u32 rstrqsr2; /* 0x01c */ |
| 533 | u32 rstrqwdtmrl; /* 0x020 */ |
| 534 | u32 rstrqwdtmru; /* 0x024 */ |
| 535 | u8 res_028[0x30-0x28]; /* 0x028 */ |
| 536 | u32 rstrqwdtsrl; /* 0x030 */ |
| 537 | u32 rstrqwdtsru; /* 0x034 */ |
| 538 | u8 res_038[0x60-0x38]; /* 0x038 */ |
| 539 | u32 brrl; /* 0x060 */ |
| 540 | u32 brru; /* 0x064 */ |
| 541 | u8 res_068[0x80-0x68]; /* 0x068 */ |
| 542 | u32 pirset; /* 0x080 */ |
| 543 | u32 pirclr; /* 0x084 */ |
| 544 | u8 res_088[0x90-0x88]; /* 0x088 */ |
| 545 | u32 brcorenbr; /* 0x090 */ |
| 546 | u8 res_094[0x100-0x94]; /* 0x094 */ |
| 547 | u32 rcw_reqr; /* 0x100 */ |
| 548 | u32 rcw_completion; /* 0x104 */ |
| 549 | u8 res_108[0x110-0x108]; /* 0x108 */ |
| 550 | u32 pbi_reqr; /* 0x110 */ |
| 551 | u32 pbi_completion; /* 0x114 */ |
| 552 | u8 res_118[0xa00-0x118]; /* 0x118 */ |
| 553 | u32 qmbm_warmrst; /* 0xa00 */ |
| 554 | u32 soc_warmrst; /* 0xa04 */ |
| 555 | u8 res_a08[0xbf8-0xa08]; /* 0xa08 */ |
| 556 | u32 ip_rev1; /* 0xbf8 */ |
| 557 | u32 ip_rev2; /* 0xbfc */ |
| 558 | }; |
Sriram Dash | 9282d26 | 2016-06-13 09:58:32 +0530 | [diff] [blame] | 559 | |
Rajesh Bhagat | 814e077 | 2018-01-17 16:13:00 +0530 | [diff] [blame] | 560 | struct ccsr_serdes { |
| 561 | struct { |
| 562 | u32 rstctl; /* Reset Control Register */ |
| 563 | u32 pllcr0; /* PLL Control Register 0 */ |
| 564 | u32 pllcr1; /* PLL Control Register 1 */ |
| 565 | u32 pllcr2; /* PLL Control Register 2 */ |
| 566 | u32 pllcr3; /* PLL Control Register 3 */ |
| 567 | u32 pllcr4; /* PLL Control Register 4 */ |
| 568 | u32 pllcr5; /* PLL Control Register 5 */ |
| 569 | u8 res[0x20 - 0x1c]; |
| 570 | } bank[2]; |
| 571 | u8 res1[0x90 - 0x40]; |
| 572 | u32 srdstcalcr; /* TX Calibration Control */ |
| 573 | u32 srdstcalcr1; /* TX Calibration Control1 */ |
| 574 | u8 res2[0xa0 - 0x98]; |
| 575 | u32 srdsrcalcr; /* RX Calibration Control */ |
| 576 | u32 srdsrcalcr1; /* RX Calibration Control1 */ |
| 577 | u8 res3[0xb0 - 0xa8]; |
| 578 | u32 srdsgr0; /* General Register 0 */ |
| 579 | u8 res4[0x800 - 0xb4]; |
| 580 | struct serdes_lane { |
| 581 | u32 gcr0; /* General Control Register 0 */ |
| 582 | u32 gcr1; /* General Control Register 1 */ |
| 583 | u32 gcr2; /* General Control Register 2 */ |
| 584 | u32 ssc0; /* Speed Switch Control 0 */ |
| 585 | u32 rec0; /* Receive Equalization Control 0 */ |
| 586 | u32 rec1; /* Receive Equalization Control 1 */ |
| 587 | u32 tec0; /* Transmit Equalization Control 0 */ |
| 588 | u32 ssc1; /* Speed Switch Control 1 */ |
| 589 | u8 res1[0x840 - 0x820]; |
| 590 | } lane[8]; |
| 591 | u8 res5[0x19fc - 0xa00]; |
| 592 | }; |
| 593 | |
Biwen Li | db5d53b | 2021-02-05 19:01:47 +0800 | [diff] [blame] | 594 | struct ccsr_gpio { |
| 595 | u32 gpdir; |
| 596 | u32 gpodr; |
| 597 | u32 gpdat; |
| 598 | u32 gpier; |
| 599 | u32 gpimr; |
| 600 | u32 gpicr; |
| 601 | u32 gpibe; |
| 602 | }; |
| 603 | |
Simon Glass | 559f1a8 | 2020-05-10 11:40:12 -0600 | [diff] [blame] | 604 | #endif /*__ASSEMBLY__ */ |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 605 | #endif /* __ARCH_FSL_LSCH3_IMMAP_H_ */ |