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 | /* |
Priyanka Jain | 2b36178 | 2017-04-27 15:08:06 +0530 | [diff] [blame] | 3 | * Copyright 2017 NXP |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 4 | * Copyright 2014-2015, Freescale Semiconductor |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 5 | */ |
| 6 | |
| 7 | #ifndef _FSL_LAYERSCAPE_CPU_H |
| 8 | #define _FSL_LAYERSCAPE_CPU_H |
| 9 | |
| 10 | static struct cpu_type cpu_type_list[] = { |
Prabhakar Kushwaha | ac7f242 | 2016-06-24 13:48:13 +0530 | [diff] [blame] | 11 | CPU_TYPE_ENTRY(LS2080A, LS2080A, 8), |
| 12 | CPU_TYPE_ENTRY(LS2085A, LS2085A, 8), |
| 13 | CPU_TYPE_ENTRY(LS2045A, LS2045A, 4), |
Priyanka Jain | 4a6f173 | 2016-11-17 12:29:55 +0530 | [diff] [blame] | 14 | CPU_TYPE_ENTRY(LS2088A, LS2088A, 8), |
| 15 | CPU_TYPE_ENTRY(LS2084A, LS2084A, 8), |
| 16 | CPU_TYPE_ENTRY(LS2048A, LS2048A, 4), |
| 17 | CPU_TYPE_ENTRY(LS2044A, LS2044A, 4), |
Priyanka Jain | 2b36178 | 2017-04-27 15:08:06 +0530 | [diff] [blame] | 18 | CPU_TYPE_ENTRY(LS2081A, LS2081A, 8), |
| 19 | CPU_TYPE_ENTRY(LS2041A, LS2041A, 4), |
Prabhakar Kushwaha | ac7f242 | 2016-06-24 13:48:13 +0530 | [diff] [blame] | 20 | CPU_TYPE_ENTRY(LS1043A, LS1043A, 4), |
| 21 | CPU_TYPE_ENTRY(LS1023A, LS1023A, 2), |
Mingkai Hu | cd54c0f | 2016-07-05 16:01:55 +0800 | [diff] [blame] | 22 | CPU_TYPE_ENTRY(LS1046A, LS1046A, 4), |
| 23 | CPU_TYPE_ENTRY(LS1026A, LS1026A, 2), |
Prabhakar Kushwaha | ac7f242 | 2016-06-24 13:48:13 +0530 | [diff] [blame] | 24 | CPU_TYPE_ENTRY(LS2040A, LS2040A, 4), |
| 25 | CPU_TYPE_ENTRY(LS1012A, LS1012A, 1), |
Ashish Kumar | b25faa2 | 2017-08-31 16:12:53 +0530 | [diff] [blame] | 26 | CPU_TYPE_ENTRY(LS1088A, LS1088A, 8), |
| 27 | CPU_TYPE_ENTRY(LS1084A, LS1084A, 8), |
| 28 | CPU_TYPE_ENTRY(LS1048A, LS1048A, 4), |
| 29 | CPU_TYPE_ENTRY(LS1044A, LS1044A, 4), |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 30 | }; |
| 31 | |
| 32 | #ifndef CONFIG_SYS_DCACHE_OFF |
| 33 | |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 34 | #ifdef CONFIG_FSL_LSCH3 |
| 35 | #define CONFIG_SYS_FSL_CCSR_BASE 0x00000000 |
| 36 | #define CONFIG_SYS_FSL_CCSR_SIZE 0x10000000 |
| 37 | #define CONFIG_SYS_FSL_QSPI_BASE1 0x20000000 |
| 38 | #define CONFIG_SYS_FSL_QSPI_SIZE1 0x10000000 |
| 39 | #define CONFIG_SYS_FSL_IFC_BASE1 0x30000000 |
| 40 | #define CONFIG_SYS_FSL_IFC_SIZE1 0x10000000 |
| 41 | #define CONFIG_SYS_FSL_IFC_SIZE1_1 0x400000 |
| 42 | #define CONFIG_SYS_FSL_DRAM_BASE1 0x80000000 |
| 43 | #define CONFIG_SYS_FSL_DRAM_SIZE1 0x80000000 |
| 44 | #define CONFIG_SYS_FSL_QSPI_BASE2 0x400000000 |
| 45 | #define CONFIG_SYS_FSL_QSPI_SIZE2 0x100000000 |
| 46 | #define CONFIG_SYS_FSL_IFC_BASE2 0x500000000 |
| 47 | #define CONFIG_SYS_FSL_IFC_SIZE2 0x100000000 |
| 48 | #define CONFIG_SYS_FSL_DCSR_BASE 0x700000000 |
| 49 | #define CONFIG_SYS_FSL_DCSR_SIZE 0x40000000 |
| 50 | #define CONFIG_SYS_FSL_MC_BASE 0x80c000000 |
| 51 | #define CONFIG_SYS_FSL_MC_SIZE 0x4000000 |
| 52 | #define CONFIG_SYS_FSL_NI_BASE 0x810000000 |
| 53 | #define CONFIG_SYS_FSL_NI_SIZE 0x8000000 |
| 54 | #define CONFIG_SYS_FSL_QBMAN_BASE 0x818000000 |
| 55 | #define CONFIG_SYS_FSL_QBMAN_SIZE 0x8000000 |
| 56 | #define CONFIG_SYS_FSL_QBMAN_SIZE_1 0x4000000 |
| 57 | #define CONFIG_SYS_PCIE1_PHYS_SIZE 0x200000000 |
| 58 | #define CONFIG_SYS_PCIE2_PHYS_SIZE 0x200000000 |
| 59 | #define CONFIG_SYS_PCIE3_PHYS_SIZE 0x200000000 |
| 60 | #define CONFIG_SYS_PCIE4_PHYS_SIZE 0x200000000 |
| 61 | #define CONFIG_SYS_FSL_WRIOP1_BASE 0x4300000000 |
| 62 | #define CONFIG_SYS_FSL_WRIOP1_SIZE 0x100000000 |
| 63 | #define CONFIG_SYS_FSL_AIOP1_BASE 0x4b00000000 |
| 64 | #define CONFIG_SYS_FSL_AIOP1_SIZE 0x100000000 |
| 65 | #define CONFIG_SYS_FSL_PEBUF_BASE 0x4c00000000 |
| 66 | #define CONFIG_SYS_FSL_PEBUF_SIZE 0x400000000 |
| 67 | #define CONFIG_SYS_FSL_DRAM_BASE2 0x8080000000 |
| 68 | #define CONFIG_SYS_FSL_DRAM_SIZE2 0x7F80000000 |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 69 | #elif defined(CONFIG_FSL_LSCH2) |
| 70 | #define CONFIG_SYS_FSL_BOOTROM_BASE 0x0 |
| 71 | #define CONFIG_SYS_FSL_BOOTROM_SIZE 0x1000000 |
| 72 | #define CONFIG_SYS_FSL_CCSR_BASE 0x1000000 |
| 73 | #define CONFIG_SYS_FSL_CCSR_SIZE 0xf000000 |
| 74 | #define CONFIG_SYS_FSL_DCSR_BASE 0x20000000 |
| 75 | #define CONFIG_SYS_FSL_DCSR_SIZE 0x4000000 |
| 76 | #define CONFIG_SYS_FSL_QSPI_BASE 0x40000000 |
| 77 | #define CONFIG_SYS_FSL_QSPI_SIZE 0x20000000 |
| 78 | #define CONFIG_SYS_FSL_IFC_BASE 0x60000000 |
| 79 | #define CONFIG_SYS_FSL_IFC_SIZE 0x20000000 |
| 80 | #define CONFIG_SYS_FSL_DRAM_BASE1 0x80000000 |
| 81 | #define CONFIG_SYS_FSL_DRAM_SIZE1 0x80000000 |
| 82 | #define CONFIG_SYS_FSL_QBMAN_BASE 0x500000000 |
| 83 | #define CONFIG_SYS_FSL_QBMAN_SIZE 0x10000000 |
| 84 | #define CONFIG_SYS_FSL_DRAM_BASE2 0x880000000 |
| 85 | #define CONFIG_SYS_FSL_DRAM_SIZE2 0x780000000 /* 30GB */ |
| 86 | #define CONFIG_SYS_PCIE1_PHYS_SIZE 0x800000000 |
| 87 | #define CONFIG_SYS_PCIE2_PHYS_SIZE 0x800000000 |
| 88 | #define CONFIG_SYS_PCIE3_PHYS_SIZE 0x800000000 |
| 89 | #define CONFIG_SYS_FSL_DRAM_BASE3 0x8800000000 |
| 90 | #define CONFIG_SYS_FSL_DRAM_SIZE3 0x7800000000 /* 480GB */ |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 91 | #endif |
| 92 | |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 93 | #define EARLY_PGTABLE_SIZE 0x5000 |
| 94 | static struct mm_region early_map[] = { |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 95 | #ifdef CONFIG_FSL_LSCH3 |
| 96 | { CONFIG_SYS_FSL_CCSR_BASE, CONFIG_SYS_FSL_CCSR_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 97 | CONFIG_SYS_FSL_CCSR_SIZE, |
| 98 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 99 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 100 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 101 | { CONFIG_SYS_FSL_OCRAM_BASE, CONFIG_SYS_FSL_OCRAM_BASE, |
Hou Zhiqiang | 3a109ef | 2016-12-16 17:15:45 +0800 | [diff] [blame] | 102 | SYS_FSL_OCRAM_SPACE_SIZE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 103 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | PTE_BLOCK_NON_SHARE |
| 104 | }, |
Yuan Yao | 331c87c | 2016-06-08 18:25:00 +0800 | [diff] [blame] | 105 | { CONFIG_SYS_FSL_QSPI_BASE1, CONFIG_SYS_FSL_QSPI_BASE1, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 106 | CONFIG_SYS_FSL_QSPI_SIZE1, |
| 107 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | PTE_BLOCK_NON_SHARE}, |
Sriram Dash | 36a4a34 | 2017-09-04 15:44:05 +0530 | [diff] [blame] | 108 | #ifdef CONFIG_FSL_IFC |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 109 | /* For IFC Region #1, only the first 4MB is cache-enabled */ |
| 110 | { CONFIG_SYS_FSL_IFC_BASE1, CONFIG_SYS_FSL_IFC_BASE1, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 111 | CONFIG_SYS_FSL_IFC_SIZE1_1, |
| 112 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | PTE_BLOCK_NON_SHARE |
| 113 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 114 | { CONFIG_SYS_FSL_IFC_BASE1 + CONFIG_SYS_FSL_IFC_SIZE1_1, |
| 115 | CONFIG_SYS_FSL_IFC_BASE1 + CONFIG_SYS_FSL_IFC_SIZE1_1, |
| 116 | CONFIG_SYS_FSL_IFC_SIZE1 - CONFIG_SYS_FSL_IFC_SIZE1_1, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 117 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_NON_SHARE |
| 118 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 119 | { CONFIG_SYS_FLASH_BASE, CONFIG_SYS_FSL_IFC_BASE1, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 120 | CONFIG_SYS_FSL_IFC_SIZE1, |
| 121 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_NON_SHARE |
| 122 | }, |
Sriram Dash | 36a4a34 | 2017-09-04 15:44:05 +0530 | [diff] [blame] | 123 | #endif |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 124 | { CONFIG_SYS_FSL_DRAM_BASE1, CONFIG_SYS_FSL_DRAM_BASE1, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 125 | CONFIG_SYS_FSL_DRAM_SIZE1, |
York Sun | 729f2d1 | 2017-03-06 09:02:34 -0800 | [diff] [blame] | 126 | #if defined(CONFIG_SPL) && !defined(CONFIG_SPL_BUILD) |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 127 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | |
York Sun | 729f2d1 | 2017-03-06 09:02:34 -0800 | [diff] [blame] | 128 | #else /* Start with nGnRnE and PXN and UXN to prevent speculative access */ |
| 129 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_PXN | PTE_BLOCK_UXN | |
| 130 | #endif |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 131 | PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS |
| 132 | }, |
Sriram Dash | 36a4a34 | 2017-09-04 15:44:05 +0530 | [diff] [blame] | 133 | #ifdef CONFIG_FSL_IFC |
York Sun | 97ceebd | 2015-11-25 14:56:40 -0800 | [diff] [blame] | 134 | /* Map IFC region #2 up to CONFIG_SYS_FLASH_BASE for NAND boot */ |
| 135 | { CONFIG_SYS_FSL_IFC_BASE2, CONFIG_SYS_FSL_IFC_BASE2, |
| 136 | CONFIG_SYS_FLASH_BASE - CONFIG_SYS_FSL_IFC_BASE2, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 137 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_NON_SHARE |
| 138 | }, |
Sriram Dash | 36a4a34 | 2017-09-04 15:44:05 +0530 | [diff] [blame] | 139 | #endif |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 140 | { CONFIG_SYS_FSL_DCSR_BASE, CONFIG_SYS_FSL_DCSR_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 141 | CONFIG_SYS_FSL_DCSR_SIZE, |
| 142 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 143 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 144 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 145 | { CONFIG_SYS_FSL_DRAM_BASE2, CONFIG_SYS_FSL_DRAM_BASE2, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 146 | CONFIG_SYS_FSL_DRAM_SIZE2, |
York Sun | 729f2d1 | 2017-03-06 09:02:34 -0800 | [diff] [blame] | 147 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_PXN | PTE_BLOCK_UXN | |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 148 | PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS |
| 149 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 150 | #elif defined(CONFIG_FSL_LSCH2) |
| 151 | { CONFIG_SYS_FSL_CCSR_BASE, CONFIG_SYS_FSL_CCSR_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 152 | CONFIG_SYS_FSL_CCSR_SIZE, |
| 153 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 154 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 155 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 156 | { CONFIG_SYS_FSL_OCRAM_BASE, CONFIG_SYS_FSL_OCRAM_BASE, |
Hou Zhiqiang | 3a109ef | 2016-12-16 17:15:45 +0800 | [diff] [blame] | 157 | SYS_FSL_OCRAM_SPACE_SIZE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 158 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | PTE_BLOCK_NON_SHARE |
| 159 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 160 | { CONFIG_SYS_FSL_DCSR_BASE, CONFIG_SYS_FSL_DCSR_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 161 | CONFIG_SYS_FSL_DCSR_SIZE, |
| 162 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 163 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 164 | }, |
Qianyu Gong | 138a36a | 2016-01-25 15:16:07 +0800 | [diff] [blame] | 165 | { CONFIG_SYS_FSL_QSPI_BASE, CONFIG_SYS_FSL_QSPI_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 166 | CONFIG_SYS_FSL_QSPI_SIZE, |
| 167 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_NON_SHARE |
| 168 | }, |
Sriram Dash | 36a4a34 | 2017-09-04 15:44:05 +0530 | [diff] [blame] | 169 | #ifdef CONFIG_FSL_IFC |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 170 | { CONFIG_SYS_FSL_IFC_BASE, CONFIG_SYS_FSL_IFC_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 171 | CONFIG_SYS_FSL_IFC_SIZE, |
| 172 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_NON_SHARE |
| 173 | }, |
Sriram Dash | 36a4a34 | 2017-09-04 15:44:05 +0530 | [diff] [blame] | 174 | #endif |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 175 | { CONFIG_SYS_FSL_DRAM_BASE1, CONFIG_SYS_FSL_DRAM_BASE1, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 176 | CONFIG_SYS_FSL_DRAM_SIZE1, |
York Sun | 729f2d1 | 2017-03-06 09:02:34 -0800 | [diff] [blame] | 177 | #if defined(CONFIG_SPL) && !defined(CONFIG_SPL_BUILD) |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 178 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | |
York Sun | 729f2d1 | 2017-03-06 09:02:34 -0800 | [diff] [blame] | 179 | #else /* Start with nGnRnE and PXN and UXN to prevent speculative access */ |
| 180 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_PXN | PTE_BLOCK_UXN | |
| 181 | #endif |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 182 | PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS |
| 183 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 184 | { CONFIG_SYS_FSL_DRAM_BASE2, CONFIG_SYS_FSL_DRAM_BASE2, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 185 | CONFIG_SYS_FSL_DRAM_SIZE2, |
York Sun | 729f2d1 | 2017-03-06 09:02:34 -0800 | [diff] [blame] | 186 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_PXN | PTE_BLOCK_UXN | |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 187 | PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS |
| 188 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 189 | #endif |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 190 | {}, /* list terminator */ |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 191 | }; |
| 192 | |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 193 | static struct mm_region final_map[] = { |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 194 | #ifdef CONFIG_FSL_LSCH3 |
| 195 | { CONFIG_SYS_FSL_CCSR_BASE, CONFIG_SYS_FSL_CCSR_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 196 | CONFIG_SYS_FSL_CCSR_SIZE, |
| 197 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 198 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 199 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 200 | { CONFIG_SYS_FSL_OCRAM_BASE, CONFIG_SYS_FSL_OCRAM_BASE, |
Hou Zhiqiang | 3a109ef | 2016-12-16 17:15:45 +0800 | [diff] [blame] | 201 | SYS_FSL_OCRAM_SPACE_SIZE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 202 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | PTE_BLOCK_NON_SHARE |
| 203 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 204 | { CONFIG_SYS_FSL_DRAM_BASE1, CONFIG_SYS_FSL_DRAM_BASE1, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 205 | CONFIG_SYS_FSL_DRAM_SIZE1, |
| 206 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | |
| 207 | PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS |
| 208 | }, |
Yuan Yao | 331c87c | 2016-06-08 18:25:00 +0800 | [diff] [blame] | 209 | { CONFIG_SYS_FSL_QSPI_BASE1, CONFIG_SYS_FSL_QSPI_BASE1, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 210 | CONFIG_SYS_FSL_QSPI_SIZE1, |
Suresh Gupta | 3483d36 | 2017-08-29 19:12:43 +0530 | [diff] [blame] | 211 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 212 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 213 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 214 | { CONFIG_SYS_FSL_QSPI_BASE2, CONFIG_SYS_FSL_QSPI_BASE2, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 215 | CONFIG_SYS_FSL_QSPI_SIZE2, |
| 216 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 217 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 218 | }, |
Sriram Dash | 36a4a34 | 2017-09-04 15:44:05 +0530 | [diff] [blame] | 219 | #ifdef CONFIG_FSL_IFC |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 220 | { CONFIG_SYS_FSL_IFC_BASE2, CONFIG_SYS_FSL_IFC_BASE2, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 221 | CONFIG_SYS_FSL_IFC_SIZE2, |
Suresh Gupta | 3483d36 | 2017-08-29 19:12:43 +0530 | [diff] [blame] | 222 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 223 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 224 | }, |
Sriram Dash | 36a4a34 | 2017-09-04 15:44:05 +0530 | [diff] [blame] | 225 | #endif |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 226 | { CONFIG_SYS_FSL_DCSR_BASE, CONFIG_SYS_FSL_DCSR_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 227 | CONFIG_SYS_FSL_DCSR_SIZE, |
| 228 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 229 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 230 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 231 | { CONFIG_SYS_FSL_MC_BASE, CONFIG_SYS_FSL_MC_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 232 | CONFIG_SYS_FSL_MC_SIZE, |
| 233 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 234 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 235 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 236 | { CONFIG_SYS_FSL_NI_BASE, CONFIG_SYS_FSL_NI_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 237 | CONFIG_SYS_FSL_NI_SIZE, |
| 238 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 239 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 240 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 241 | /* For QBMAN portal, only the first 64MB is cache-enabled */ |
| 242 | { CONFIG_SYS_FSL_QBMAN_BASE, CONFIG_SYS_FSL_QBMAN_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 243 | CONFIG_SYS_FSL_QBMAN_SIZE_1, |
| 244 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | |
| 245 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN | PTE_BLOCK_NS |
| 246 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 247 | { CONFIG_SYS_FSL_QBMAN_BASE + CONFIG_SYS_FSL_QBMAN_SIZE_1, |
| 248 | CONFIG_SYS_FSL_QBMAN_BASE + CONFIG_SYS_FSL_QBMAN_SIZE_1, |
| 249 | CONFIG_SYS_FSL_QBMAN_SIZE - CONFIG_SYS_FSL_QBMAN_SIZE_1, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 250 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 251 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 252 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 253 | { CONFIG_SYS_PCIE1_PHYS_ADDR, CONFIG_SYS_PCIE1_PHYS_ADDR, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 254 | CONFIG_SYS_PCIE1_PHYS_SIZE, |
| 255 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 256 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 257 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 258 | { CONFIG_SYS_PCIE2_PHYS_ADDR, CONFIG_SYS_PCIE2_PHYS_ADDR, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 259 | CONFIG_SYS_PCIE2_PHYS_SIZE, |
| 260 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 261 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 262 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 263 | { CONFIG_SYS_PCIE3_PHYS_ADDR, CONFIG_SYS_PCIE3_PHYS_ADDR, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 264 | CONFIG_SYS_PCIE3_PHYS_SIZE, |
| 265 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 266 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 267 | }, |
York Sun | 4ce6fbf | 2017-03-27 11:41:01 -0700 | [diff] [blame] | 268 | #ifdef CONFIG_ARCH_LS2080A |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 269 | { CONFIG_SYS_PCIE4_PHYS_ADDR, CONFIG_SYS_PCIE4_PHYS_ADDR, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 270 | CONFIG_SYS_PCIE4_PHYS_SIZE, |
| 271 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 272 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 273 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 274 | #endif |
| 275 | { CONFIG_SYS_FSL_WRIOP1_BASE, CONFIG_SYS_FSL_WRIOP1_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 276 | CONFIG_SYS_FSL_WRIOP1_SIZE, |
| 277 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 278 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 279 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 280 | { CONFIG_SYS_FSL_AIOP1_BASE, CONFIG_SYS_FSL_AIOP1_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 281 | CONFIG_SYS_FSL_AIOP1_SIZE, |
| 282 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 283 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 284 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 285 | { CONFIG_SYS_FSL_PEBUF_BASE, CONFIG_SYS_FSL_PEBUF_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 286 | CONFIG_SYS_FSL_PEBUF_SIZE, |
| 287 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 288 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 289 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 290 | { CONFIG_SYS_FSL_DRAM_BASE2, CONFIG_SYS_FSL_DRAM_BASE2, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 291 | CONFIG_SYS_FSL_DRAM_SIZE2, |
| 292 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | |
| 293 | PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS |
| 294 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 295 | #elif defined(CONFIG_FSL_LSCH2) |
| 296 | { CONFIG_SYS_FSL_BOOTROM_BASE, CONFIG_SYS_FSL_BOOTROM_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 297 | CONFIG_SYS_FSL_BOOTROM_SIZE, |
| 298 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 299 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 300 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 301 | { CONFIG_SYS_FSL_CCSR_BASE, CONFIG_SYS_FSL_CCSR_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 302 | CONFIG_SYS_FSL_CCSR_SIZE, |
| 303 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 304 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 305 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 306 | { CONFIG_SYS_FSL_OCRAM_BASE, CONFIG_SYS_FSL_OCRAM_BASE, |
Hou Zhiqiang | 3a109ef | 2016-12-16 17:15:45 +0800 | [diff] [blame] | 307 | SYS_FSL_OCRAM_SPACE_SIZE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 308 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | PTE_BLOCK_NON_SHARE |
| 309 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 310 | { CONFIG_SYS_FSL_DCSR_BASE, CONFIG_SYS_FSL_DCSR_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 311 | CONFIG_SYS_FSL_DCSR_SIZE, |
| 312 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 313 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 314 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 315 | { CONFIG_SYS_FSL_QSPI_BASE, CONFIG_SYS_FSL_QSPI_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 316 | CONFIG_SYS_FSL_QSPI_SIZE, |
| 317 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 318 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 319 | }, |
Sriram Dash | 36a4a34 | 2017-09-04 15:44:05 +0530 | [diff] [blame] | 320 | #ifdef CONFIG_FSL_IFC |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 321 | { CONFIG_SYS_FSL_IFC_BASE, CONFIG_SYS_FSL_IFC_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 322 | CONFIG_SYS_FSL_IFC_SIZE, |
| 323 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | PTE_BLOCK_NON_SHARE |
| 324 | }, |
Sriram Dash | 36a4a34 | 2017-09-04 15:44:05 +0530 | [diff] [blame] | 325 | #endif |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 326 | { CONFIG_SYS_FSL_DRAM_BASE1, CONFIG_SYS_FSL_DRAM_BASE1, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 327 | CONFIG_SYS_FSL_DRAM_SIZE1, |
| 328 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | |
| 329 | PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS |
| 330 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 331 | { CONFIG_SYS_FSL_QBMAN_BASE, CONFIG_SYS_FSL_QBMAN_BASE, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 332 | CONFIG_SYS_FSL_QBMAN_SIZE, |
| 333 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 334 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 335 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 336 | { CONFIG_SYS_FSL_DRAM_BASE2, CONFIG_SYS_FSL_DRAM_BASE2, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 337 | CONFIG_SYS_FSL_DRAM_SIZE2, |
| 338 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | |
| 339 | PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS |
| 340 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 341 | { CONFIG_SYS_PCIE1_PHYS_ADDR, CONFIG_SYS_PCIE1_PHYS_ADDR, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 342 | CONFIG_SYS_PCIE1_PHYS_SIZE, |
| 343 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 344 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 345 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 346 | { CONFIG_SYS_PCIE2_PHYS_ADDR, CONFIG_SYS_PCIE2_PHYS_ADDR, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 347 | CONFIG_SYS_PCIE2_PHYS_SIZE, |
| 348 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 349 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 350 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 351 | { CONFIG_SYS_PCIE3_PHYS_ADDR, CONFIG_SYS_PCIE3_PHYS_ADDR, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 352 | CONFIG_SYS_PCIE3_PHYS_SIZE, |
| 353 | PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) | |
| 354 | PTE_BLOCK_NON_SHARE | PTE_BLOCK_PXN | PTE_BLOCK_UXN |
| 355 | }, |
Mingkai Hu | e4e93ea | 2015-10-26 19:47:51 +0800 | [diff] [blame] | 356 | { CONFIG_SYS_FSL_DRAM_BASE3, CONFIG_SYS_FSL_DRAM_BASE3, |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 357 | CONFIG_SYS_FSL_DRAM_SIZE3, |
| 358 | PTE_BLOCK_MEMTYPE(MT_NORMAL) | |
| 359 | PTE_BLOCK_OUTER_SHARE | PTE_BLOCK_NS |
| 360 | }, |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 361 | #endif |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 362 | #ifdef CONFIG_SYS_MEM_RESERVE_SECURE |
| 363 | {}, /* space holder for secure mem */ |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 364 | #endif |
York Sun | 9da8f50 | 2016-06-24 16:46:23 -0700 | [diff] [blame] | 365 | {}, |
| 366 | }; |
| 367 | #endif /* !CONFIG_SYS_DCACHE_OFF */ |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 368 | |
| 369 | int fsl_qoriq_core_to_cluster(unsigned int core); |
| 370 | u32 cpu_mask(void); |
Simon Glass | 243182c | 2017-05-17 08:23:06 -0600 | [diff] [blame] | 371 | |
Mingkai Hu | 0e58b51 | 2015-10-26 19:47:50 +0800 | [diff] [blame] | 372 | #endif /* _FSL_LAYERSCAPE_CPU_H */ |