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