[dc0a7df] | 1 | /** |
---|
| 2 | * @file |
---|
| 3 | * |
---|
| 4 | * @ingroup QorIQ |
---|
| 5 | * |
---|
| 6 | * @brief QorIQ Configuration, Control and Status Registers. |
---|
| 7 | */ |
---|
| 8 | |
---|
| 9 | /* |
---|
[f2e6c3e] | 10 | * Copyright (c) 2010-2015 embedded brains GmbH. All rights reserved. |
---|
[dc0a7df] | 11 | * |
---|
| 12 | * embedded brains GmbH |
---|
[f2e6c3e] | 13 | * Dornierstr. 4 |
---|
[dc0a7df] | 14 | * 82178 Puchheim |
---|
| 15 | * Germany |
---|
| 16 | * <rtems@embedded-brains.de> |
---|
| 17 | * |
---|
| 18 | * The license and distribution terms for this file may be |
---|
| 19 | * found in the file LICENSE in this distribution or at |
---|
[c499856] | 20 | * http://www.rtems.org/license/LICENSE. |
---|
[dc0a7df] | 21 | */ |
---|
| 22 | |
---|
| 23 | #ifndef LIBBSP_POWERPC_QORIQ_QORIQ_H |
---|
| 24 | #define LIBBSP_POWERPC_QORIQ_QORIQ_H |
---|
| 25 | |
---|
[f2e6c3e] | 26 | #include <bsp.h> |
---|
[dc0a7df] | 27 | #include <bsp/tsec.h> |
---|
| 28 | #include <bsp/utility.h> |
---|
| 29 | |
---|
| 30 | #ifdef __cplusplus |
---|
| 31 | extern "C" { |
---|
| 32 | #endif /* __cplusplus */ |
---|
| 33 | |
---|
| 34 | #define QORIQ_FILL(a, b, s) uint8_t reserved_ ## b [b - a - sizeof(s)] |
---|
| 35 | #define QORIQ_RESERVE(a, b) uint8_t reserved_ ## b [b - a] |
---|
| 36 | |
---|
[f2e6c3e] | 37 | typedef struct { |
---|
| 38 | uint32_t reg; |
---|
| 39 | QORIQ_FILL(0x00000, 0x00010, uint32_t); |
---|
| 40 | } qoriq_pic_reg; |
---|
| 41 | |
---|
| 42 | typedef struct { |
---|
| 43 | uint32_t ccr; |
---|
| 44 | QORIQ_FILL(0x00000, 0x00010, uint32_t); |
---|
| 45 | uint32_t bcr; |
---|
| 46 | QORIQ_FILL(0x00010, 0x00020, uint32_t); |
---|
| 47 | uint32_t vpr; |
---|
| 48 | QORIQ_FILL(0x00020, 0x00030, uint32_t); |
---|
| 49 | uint32_t dr; |
---|
| 50 | QORIQ_FILL(0x00030, 0x00040, uint32_t); |
---|
| 51 | } qoriq_pic_global_timer; |
---|
| 52 | |
---|
| 53 | #define GTCCR_TOG BSP_BBIT32(0) |
---|
| 54 | #define GTCCR_COUNT_GET(reg) BSP_BFLD32GET(reg, 1, 31) |
---|
| 55 | |
---|
| 56 | #define GTBCR_CI BSP_BBIT32(0) |
---|
| 57 | #define GTBCR_COUNT(val) BSP_BFLD32(val, 1, 31) |
---|
| 58 | #define GTBCR_COUNT_GET(reg) BSP_BFLD32GET(reg, 1, 31) |
---|
| 59 | #define GTBCR_COUNT_SET(reg, val) BSP_BFLD32SET(reg, val, 1, 31) |
---|
| 60 | |
---|
| 61 | typedef struct { |
---|
| 62 | uint32_t misc; |
---|
| 63 | QORIQ_FILL(0x00000, 0x00010, uint32_t); |
---|
| 64 | uint32_t internal [2]; |
---|
| 65 | QORIQ_FILL(0x00010, 0x00020, uint32_t [2]); |
---|
| 66 | } qoriq_pic_bit_field; |
---|
| 67 | |
---|
| 68 | typedef struct { |
---|
| 69 | uint32_t vpr; |
---|
| 70 | QORIQ_FILL(0x00000, 0x00010, uint32_t); |
---|
| 71 | uint32_t dr; |
---|
| 72 | QORIQ_FILL(0x00010, 0x00020, uint32_t); |
---|
| 73 | } qoriq_pic_src_cfg; |
---|
| 74 | |
---|
| 75 | typedef struct { |
---|
| 76 | QORIQ_RESERVE(0x00000, 0x00040); |
---|
| 77 | qoriq_pic_reg ipidr [4]; |
---|
| 78 | uint32_t ctpr; |
---|
| 79 | QORIQ_FILL(0x00080, 0x00090, uint32_t); |
---|
| 80 | uint32_t whoami; |
---|
| 81 | QORIQ_FILL(0x00090, 0x000a0, uint32_t); |
---|
| 82 | uint32_t iack; |
---|
| 83 | QORIQ_FILL(0x000a0, 0x000b0, uint32_t); |
---|
| 84 | uint32_t eoi; |
---|
| 85 | QORIQ_FILL(0x000b0, 0x01000, uint32_t); |
---|
| 86 | } qoriq_pic_per_cpu; |
---|
| 87 | |
---|
| 88 | typedef struct { |
---|
| 89 | uint32_t brr1; |
---|
| 90 | QORIQ_FILL(0x00000, 0x00010, uint32_t); |
---|
| 91 | uint32_t brr2; |
---|
| 92 | QORIQ_FILL(0x00010, 0x00040, uint32_t); |
---|
| 93 | qoriq_pic_reg ipidr [4]; |
---|
| 94 | uint32_t ctpr; |
---|
| 95 | QORIQ_FILL(0x00080, 0x00090, uint32_t); |
---|
| 96 | uint32_t whoami; |
---|
| 97 | QORIQ_FILL(0x00090, 0x000a0, uint32_t); |
---|
| 98 | uint32_t iack; |
---|
| 99 | QORIQ_FILL(0x000a0, 0x000b0, uint32_t); |
---|
| 100 | uint32_t eoi; |
---|
| 101 | QORIQ_FILL(0x000b0, 0x01000, uint32_t); |
---|
| 102 | uint32_t frr; |
---|
| 103 | QORIQ_FILL(0x01000, 0x01020, uint32_t); |
---|
| 104 | uint32_t gcr; |
---|
| 105 | QORIQ_FILL(0x01020, 0x01080, uint32_t); |
---|
| 106 | uint32_t vir; |
---|
| 107 | QORIQ_FILL(0x01080, 0x01090, uint32_t); |
---|
| 108 | uint32_t pir; |
---|
| 109 | QORIQ_FILL(0x01090, 0x010a0, uint32_t); |
---|
| 110 | qoriq_pic_reg ipivpr [4]; |
---|
| 111 | uint32_t svr; |
---|
| 112 | QORIQ_FILL(0x010e0, 0x010f0, uint32_t); |
---|
| 113 | uint32_t tfrra; |
---|
| 114 | QORIQ_FILL(0x010f0, 0x01100, uint32_t); |
---|
| 115 | qoriq_pic_global_timer gta [4]; |
---|
| 116 | QORIQ_RESERVE(0x01200, 0x01300); |
---|
| 117 | uint32_t tcra; |
---|
| 118 | QORIQ_FILL(0x01300, 0x01308, uint32_t); |
---|
| 119 | uint32_t erqsr; |
---|
| 120 | QORIQ_FILL(0x01308, 0x01310, uint32_t); |
---|
| 121 | qoriq_pic_bit_field irqsr; |
---|
| 122 | qoriq_pic_bit_field cisr; |
---|
| 123 | qoriq_pic_bit_field pm [4]; |
---|
| 124 | QORIQ_RESERVE(0x013d0, 0x01400); |
---|
| 125 | qoriq_pic_reg msgr03 [4]; |
---|
| 126 | QORIQ_RESERVE(0x01440, 0x01500); |
---|
| 127 | uint32_t mer03; |
---|
| 128 | QORIQ_FILL(0x01500, 0x01510, uint32_t); |
---|
| 129 | uint32_t msr03; |
---|
| 130 | QORIQ_FILL(0x01510, 0x01600, uint32_t); |
---|
| 131 | qoriq_pic_reg msir [8]; |
---|
| 132 | QORIQ_RESERVE(0x01680, 0x01720); |
---|
| 133 | uint32_t msisr; |
---|
| 134 | QORIQ_FILL(0x01720, 0x01740, uint32_t); |
---|
| 135 | uint32_t msiir; |
---|
| 136 | QORIQ_FILL(0x01740, 0x020f0, uint32_t); |
---|
| 137 | uint32_t tfrrb; |
---|
| 138 | QORIQ_FILL(0x020f0, 0x02100, uint32_t); |
---|
| 139 | qoriq_pic_global_timer gtb [4]; |
---|
| 140 | QORIQ_RESERVE(0x02200, 0x02300); |
---|
| 141 | uint32_t tcrb; |
---|
| 142 | QORIQ_FILL(0x02300, 0x02400, uint32_t); |
---|
| 143 | qoriq_pic_reg msgr47 [4]; |
---|
| 144 | QORIQ_RESERVE(0x02440, 0x02500); |
---|
| 145 | uint32_t mer47; |
---|
| 146 | QORIQ_FILL(0x02500, 0x02510, uint32_t); |
---|
| 147 | uint32_t msr47; |
---|
| 148 | QORIQ_FILL(0x02510, 0x10000, uint32_t); |
---|
| 149 | qoriq_pic_src_cfg ei [12]; |
---|
| 150 | QORIQ_RESERVE(0x10180, 0x10200); |
---|
[d65ed62] | 151 | qoriq_pic_src_cfg ii_0 [160]; |
---|
[f2e6c3e] | 152 | qoriq_pic_src_cfg mi [8]; |
---|
| 153 | QORIQ_RESERVE(0x11700, 0x11c00); |
---|
| 154 | qoriq_pic_src_cfg msi [8]; |
---|
[d65ed62] | 155 | QORIQ_RESERVE(0x11d00, 0x13000); |
---|
| 156 | qoriq_pic_src_cfg ii_1 [96]; |
---|
| 157 | QORIQ_RESERVE(0x13c00, 0x20000); |
---|
[f2e6c3e] | 158 | qoriq_pic_per_cpu per_cpu [2]; |
---|
| 159 | } qoriq_pic; |
---|
| 160 | |
---|
| 161 | #define GTTCR_ROVR(val) BSP_BFLD32(val, 5, 7) |
---|
| 162 | #define GTTCR_ROVR_GET(reg) BSP_BFLD32GET(reg, 5, 7) |
---|
| 163 | #define GTTCR_ROVR_SET(reg, val) BSP_BFLD32SET(reg, val, 5, 7) |
---|
| 164 | #define GTTCR_RTM BSP_BBIT32(15) |
---|
| 165 | #define GTTCR_CLKR(val) BSP_BFLD32(val, 22, 23) |
---|
| 166 | #define GTTCR_CLKR_GET(reg) BSP_BFLD32GET(reg, 22, 23) |
---|
| 167 | #define GTTCR_CLKR_SET(reg, val) BSP_BFLD32SET(reg, val, 22, 23) |
---|
| 168 | #define GTTCR_CASC(val) BSP_BFLD32(val, 29, 31) |
---|
| 169 | #define GTTCR_CASC_GET(reg) BSP_BFLD32GET(reg, 29, 31) |
---|
| 170 | #define GTTCR_CASC_SET(reg, val) BSP_BFLD32SET(reg, val, 29, 31) |
---|
| 171 | |
---|
| 172 | typedef struct { |
---|
| 173 | } qoriq_uart; |
---|
| 174 | |
---|
[8e10f62] | 175 | typedef struct { |
---|
| 176 | QORIQ_RESERVE(0x000, 0x100); |
---|
| 177 | uint16_t caplength; |
---|
| 178 | uint16_t hciversion; |
---|
| 179 | uint32_t hcsparams; |
---|
| 180 | uint32_t hccparams; |
---|
| 181 | QORIQ_RESERVE(0x10c, 0x120); |
---|
| 182 | uint32_t dciversion; |
---|
| 183 | uint32_t dccparams; |
---|
| 184 | QORIQ_RESERVE(0x128, 0x140); |
---|
| 185 | uint32_t usbcmd; |
---|
| 186 | uint32_t usbsts; |
---|
| 187 | uint32_t usbintr; |
---|
| 188 | uint32_t frindex; |
---|
| 189 | QORIQ_RESERVE(0x150, 0x154); |
---|
| 190 | union { |
---|
| 191 | uint32_t periodiclistbase; |
---|
| 192 | uint32_t deviceaddr; |
---|
| 193 | } perbase_devaddr; |
---|
| 194 | union { |
---|
| 195 | uint32_t asynclistaddr; |
---|
| 196 | uint32_t addr; |
---|
| 197 | } async_addr; |
---|
| 198 | QORIQ_RESERVE(0x15c, 0x160); |
---|
| 199 | uint32_t burstsize; |
---|
| 200 | uint32_t txfilltuning; |
---|
| 201 | QORIQ_RESERVE(0x168, 0x170); |
---|
| 202 | uint32_t viewport; |
---|
| 203 | QORIQ_RESERVE(0x174, 0x180); |
---|
| 204 | uint32_t configflag; |
---|
| 205 | uint32_t portsc1; |
---|
| 206 | QORIQ_RESERVE(0x188, 0x1a8); |
---|
| 207 | uint32_t usbmode; |
---|
| 208 | uint32_t endptsetupstat; |
---|
| 209 | uint32_t endpointprime; |
---|
| 210 | uint32_t endptflush; |
---|
| 211 | uint32_t endptstatus; |
---|
| 212 | uint32_t endptcomplete; |
---|
| 213 | uint32_t endptctrl[6]; |
---|
| 214 | QORIQ_RESERVE(0x1d8, 0x400); |
---|
| 215 | uint32_t snoop1; |
---|
| 216 | uint32_t snoop2; |
---|
| 217 | uint32_t age_cnt_thresh; |
---|
| 218 | uint32_t pri_ctrl; |
---|
| 219 | uint32_t si_ctrl; |
---|
| 220 | QORIQ_RESERVE(0x414, 0x500); |
---|
| 221 | uint32_t control; |
---|
| 222 | } qoriq_usb; |
---|
| 223 | |
---|
| 224 | typedef struct { |
---|
| 225 | uint32_t dsaddr; |
---|
| 226 | uint32_t blkattr; |
---|
| 227 | uint32_t cmdarg; |
---|
| 228 | uint32_t xfertyp; |
---|
| 229 | uint32_t cmdrsp0; |
---|
| 230 | uint32_t cmdrsp1; |
---|
| 231 | uint32_t cmdrsp2; |
---|
| 232 | uint32_t cmdrsp3; |
---|
| 233 | uint32_t datport; |
---|
| 234 | uint32_t prsstat; |
---|
| 235 | uint32_t proctl; |
---|
| 236 | uint32_t sysctl; |
---|
| 237 | uint32_t irqstat; |
---|
| 238 | uint32_t irqstaten; |
---|
| 239 | uint32_t irqsigen; |
---|
| 240 | uint32_t autoc12err; |
---|
| 241 | uint32_t hostcapblt; |
---|
| 242 | uint32_t wml; |
---|
| 243 | QORIQ_FILL(0x00044, 0x00050, uint32_t); |
---|
| 244 | uint32_t fevt; |
---|
| 245 | QORIQ_FILL(0x00050, 0x000fc, uint32_t); |
---|
| 246 | uint32_t hostver; |
---|
| 247 | QORIQ_FILL(0x000fc, 0x0040c, uint32_t); |
---|
| 248 | uint32_t dcr; |
---|
| 249 | } qoriq_esdhc; |
---|
| 250 | |
---|
[f2e6c3e] | 251 | #if QORIQ_CHIP_IS_T_VARIANT(QORIQ_CHIP_VARIANT) |
---|
| 252 | |
---|
| 253 | typedef struct { |
---|
| 254 | uint32_t ccsrbarh; |
---|
| 255 | uint32_t ccsrbarl; |
---|
| 256 | uint32_t ccsrar; |
---|
| 257 | uint32_t altcbarh; |
---|
| 258 | uint32_t altcbarl; |
---|
| 259 | uint32_t altcar; |
---|
| 260 | uint32_t bstrh; |
---|
| 261 | uint32_t bstrl; |
---|
| 262 | uint32_t bstar; |
---|
| 263 | } qoriq_lcc; |
---|
| 264 | |
---|
| 265 | #define LCC_BSTAR_EN BSP_BBIT32(0) |
---|
| 266 | |
---|
| 267 | typedef struct { |
---|
| 268 | uint32_t lawbarh; |
---|
| 269 | uint32_t lawbarl; |
---|
| 270 | uint32_t lawar; |
---|
| 271 | uint32_t reserved_0xc; |
---|
| 272 | } qoriq_law; |
---|
| 273 | |
---|
[98df160] | 274 | typedef struct { |
---|
| 275 | QORIQ_RESERVE(0x0000, 0x1000); |
---|
| 276 | } qoriq_bman; |
---|
| 277 | |
---|
| 278 | typedef struct { |
---|
| 279 | QORIQ_RESERVE(0x0000, 0x1000); |
---|
| 280 | } qoriq_qman; |
---|
| 281 | |
---|
| 282 | typedef struct { |
---|
| 283 | QORIQ_RESERVE(0x000000, 0x100000); |
---|
| 284 | } qoriq_fman; |
---|
| 285 | |
---|
[f2e6c3e] | 286 | typedef struct { |
---|
| 287 | qoriq_lcc lcc; |
---|
| 288 | QORIQ_FILL(0x000000, 0x000c00, qoriq_lcc); |
---|
| 289 | qoriq_law law [32]; |
---|
| 290 | QORIQ_FILL(0x000c00, 0x001000, qoriq_law [32]); |
---|
| 291 | QORIQ_RESERVE(0x001000, 0x040000); |
---|
| 292 | qoriq_pic pic; |
---|
| 293 | QORIQ_FILL(0x040000, 0x070000, qoriq_pic); |
---|
[8e10f62] | 294 | QORIQ_RESERVE(0x070000, 0x114000); |
---|
| 295 | qoriq_esdhc esdhc; |
---|
| 296 | QORIQ_FILL(0x114000, 0x115000, qoriq_esdhc); |
---|
| 297 | QORIQ_RESERVE(0x115000, 0x11c500); |
---|
[f2e6c3e] | 298 | qoriq_uart uart_0; |
---|
| 299 | QORIQ_FILL(0x11c500, 0x11c600, qoriq_uart); |
---|
| 300 | qoriq_uart uart_1; |
---|
| 301 | QORIQ_FILL(0x11c600, 0x11d500, qoriq_uart); |
---|
| 302 | qoriq_uart uart_2; |
---|
| 303 | QORIQ_FILL(0x11d500, 0x11d600, qoriq_uart); |
---|
| 304 | qoriq_uart uart_3; |
---|
| 305 | QORIQ_FILL(0x11d600, 0x11e000, qoriq_uart); |
---|
[8e10f62] | 306 | QORIQ_RESERVE(0x11e000, 0x210000); |
---|
| 307 | qoriq_usb usb_1; |
---|
| 308 | QORIQ_FILL(0x210000, 0x211000, qoriq_usb); |
---|
[98df160] | 309 | QORIQ_RESERVE(0x211000, 0x318000); |
---|
| 310 | qoriq_qman qman; |
---|
| 311 | QORIQ_RESERVE(0x319000, 0x31a000); |
---|
| 312 | qoriq_bman bman; |
---|
| 313 | QORIQ_RESERVE(0x31b000, 0x400000); |
---|
| 314 | qoriq_fman fman_0; |
---|
| 315 | qoriq_fman fman_1; |
---|
| 316 | QORIQ_RESERVE(0x600000, 0x2000000); |
---|
[f2e6c3e] | 317 | } qoriq_ccsr; |
---|
| 318 | |
---|
| 319 | #else /* QORIQ_CHIP_VARIANT */ |
---|
| 320 | |
---|
[dc0a7df] | 321 | typedef struct { |
---|
| 322 | uint32_t ccsrbar; |
---|
| 323 | uint32_t reserved_0; |
---|
| 324 | uint32_t altcbar; |
---|
| 325 | uint32_t reserved_1; |
---|
| 326 | uint32_t altcar; |
---|
| 327 | uint32_t reserved_2 [3]; |
---|
| 328 | uint32_t bptr; |
---|
| 329 | } qoriq_lcc; |
---|
| 330 | |
---|
| 331 | #define CCSRBAR_BASE_ADDR(val) BSP_BFLD32(val, 8, 23) |
---|
| 332 | #define CCSRBAR_BASE_ADDR_GET(reg) BSP_BFLD32GET(reg, 8, 23) |
---|
| 333 | #define CCSRBAR_BASE_ADDR_SET(reg, val) BSP_BFLD32SET(reg, val, 8, 23) |
---|
| 334 | |
---|
| 335 | #define ALTCBAR_BASE_ADDR(val) BSP_BFLD32(val, 8, 23) |
---|
| 336 | #define ALTCBAR_BASE_ADDR_GET(reg) BSP_BFLD32GET(reg, 8, 23) |
---|
| 337 | #define ALTCBAR_BASE_ADDR_SET(reg, val) BSP_BFLD32SET(reg, val, 8, 23) |
---|
| 338 | |
---|
| 339 | #define ALTCAR_EN BSP_BBIT32(0) |
---|
| 340 | #define ALTCAR_TRGT_ID(val) BSP_BFLD32(val, 8, 11) |
---|
| 341 | #define ALTCAR_TRGT_ID_GET(reg) BSP_BFLD32GET(reg, 8, 11) |
---|
| 342 | #define ALTCAR_TRGT_ID_SET(reg, val) BSP_BFLD32SET(reg, val, 8, 11) |
---|
| 343 | |
---|
| 344 | #define BPTR_EN BSP_BBIT32(0) |
---|
| 345 | #define BPTR_BOOT_PAGE(val) BSP_BFLD32(val, 8, 31) |
---|
| 346 | #define BPTR_BOOT_PAGE_GET(reg) BSP_BFLD32GET(reg, 8, 31) |
---|
| 347 | #define BPTR_BOOT_PAGE_SET(reg, val) BSP_BFLD32SET(reg, val, 8, 31) |
---|
| 348 | |
---|
| 349 | typedef struct { |
---|
| 350 | uint32_t bar; |
---|
| 351 | uint32_t reserved_0; |
---|
| 352 | uint32_t ar; |
---|
| 353 | uint32_t reserved_1 [5]; |
---|
| 354 | } qoriq_law; |
---|
| 355 | |
---|
| 356 | #define LAWBAR_BASE_ADDR(val) BSP_BFLD32(val, 8, 31) |
---|
| 357 | #define LAWBAR_BASE_ADDR_GET(reg) BSP_BFLD32GET(reg, 8, 31) |
---|
| 358 | #define LAWBAR_BASE_ADDR_SET(reg, val) BSP_BFLD32SET(reg, val, 8, 31) |
---|
| 359 | |
---|
| 360 | #define LAWAR_EN BSP_BBIT32(0) |
---|
| 361 | #define LAWAR_TRGT(val) BSP_BFLD32(val, 8, 11) |
---|
| 362 | #define LAWAR_TRGT_GET(reg) BSP_BFLD32GET(reg, 8, 11) |
---|
| 363 | #define LAWAR_TRGT_SET(reg, val) BSP_BFLD32SET(reg, val, 8, 11) |
---|
| 364 | #define LAWAR_SIZE(val) BSP_BFLD32(val, 26, 31) |
---|
| 365 | #define LAWAR_SIZE_GET(reg) BSP_BFLD32GET(reg, 26, 31) |
---|
| 366 | #define LAWAR_SIZE_SET(reg, val) BSP_BFLD32SET(reg, val, 26, 31) |
---|
| 367 | |
---|
| 368 | typedef struct { |
---|
| 369 | } qoriq_ecm; |
---|
| 370 | |
---|
| 371 | typedef struct { |
---|
| 372 | } qoriq_ddr_controller; |
---|
| 373 | |
---|
| 374 | typedef struct { |
---|
| 375 | } qoriq_i2c; |
---|
| 376 | |
---|
| 377 | typedef struct { |
---|
| 378 | } qoriq_local_bus; |
---|
| 379 | |
---|
| 380 | typedef struct { |
---|
| 381 | } qoriq_spi; |
---|
| 382 | |
---|
| 383 | typedef struct { |
---|
| 384 | } qoriq_pci_express; |
---|
| 385 | |
---|
| 386 | typedef struct { |
---|
| 387 | } qoriq_gpio; |
---|
| 388 | |
---|
| 389 | typedef struct { |
---|
| 390 | } qoriq_tdm; |
---|
| 391 | |
---|
| 392 | typedef struct { |
---|
| 393 | } qoriq_l2_cache; |
---|
| 394 | |
---|
| 395 | typedef struct { |
---|
| 396 | } qoriq_dma; |
---|
| 397 | |
---|
| 398 | typedef struct { |
---|
| 399 | } qoriq_tdm_dma; |
---|
| 400 | |
---|
| 401 | typedef struct { |
---|
| 402 | } qoriq_sec; |
---|
| 403 | |
---|
| 404 | typedef struct { |
---|
| 405 | } qoriq_serial_rapid_io; |
---|
| 406 | |
---|
| 407 | typedef struct { |
---|
| 408 | } qoriq_global_utilities; |
---|
| 409 | |
---|
| 410 | typedef struct { |
---|
| 411 | } qoriq_performance_monitor; |
---|
| 412 | |
---|
| 413 | typedef struct { |
---|
| 414 | } qoriq_debug_watchpoint; |
---|
| 415 | |
---|
| 416 | typedef struct { |
---|
| 417 | } qoriq_serdes; |
---|
| 418 | |
---|
| 419 | typedef struct { |
---|
| 420 | } qoriq_boot_rom; |
---|
| 421 | |
---|
| 422 | typedef struct { |
---|
| 423 | qoriq_lcc lcc; |
---|
| 424 | QORIQ_FILL(0x00000, 0x00c08, qoriq_lcc); |
---|
| 425 | qoriq_law law [12]; |
---|
| 426 | QORIQ_FILL(0x00c08, 0x01000, qoriq_law [12]); |
---|
| 427 | qoriq_ecm ecm; |
---|
| 428 | QORIQ_FILL(0x01000, 0x02000, qoriq_ecm); |
---|
| 429 | qoriq_ddr_controller ddr_controller; |
---|
| 430 | QORIQ_FILL(0x02000, 0x03000, qoriq_ddr_controller); |
---|
| 431 | qoriq_i2c i2c; |
---|
| 432 | QORIQ_FILL(0x03000, 0x04000, qoriq_i2c); |
---|
| 433 | QORIQ_RESERVE(0x04000, 0x04500); |
---|
| 434 | qoriq_uart uart_0; |
---|
| 435 | QORIQ_FILL(0x04500, 0x04600, qoriq_uart); |
---|
| 436 | qoriq_uart uart_1; |
---|
| 437 | QORIQ_FILL(0x04600, 0x04700, qoriq_uart); |
---|
| 438 | QORIQ_RESERVE(0x04700, 0x05000); |
---|
| 439 | qoriq_local_bus local_bus; |
---|
| 440 | QORIQ_FILL(0x05000, 0x06000, qoriq_local_bus); |
---|
| 441 | qoriq_spi spi; |
---|
| 442 | QORIQ_FILL(0x06000, 0x07000, qoriq_spi); |
---|
| 443 | QORIQ_RESERVE(0x07000, 0x08000); |
---|
| 444 | qoriq_pci_express pci_express_3; |
---|
| 445 | QORIQ_FILL(0x08000, 0x09000, qoriq_pci_express); |
---|
| 446 | qoriq_pci_express pci_express_2; |
---|
| 447 | QORIQ_FILL(0x09000, 0x0a000, qoriq_pci_express); |
---|
| 448 | qoriq_pci_express pci_express_1; |
---|
| 449 | QORIQ_FILL(0x0a000, 0x0b000, qoriq_pci_express); |
---|
| 450 | QORIQ_RESERVE(0x0b000, 0x0c000); |
---|
| 451 | qoriq_dma dma_2; |
---|
| 452 | QORIQ_FILL(0x0c000, 0x0d000, qoriq_dma); |
---|
| 453 | QORIQ_RESERVE(0x0d000, 0x0f000); |
---|
| 454 | qoriq_gpio gpio; |
---|
| 455 | QORIQ_FILL(0x0f000, 0x10000, qoriq_gpio); |
---|
| 456 | QORIQ_RESERVE(0x10000, 0x16000); |
---|
| 457 | qoriq_tdm tdm; |
---|
| 458 | QORIQ_FILL(0x16000, 0x17000, qoriq_tdm); |
---|
| 459 | QORIQ_RESERVE(0x17000, 0x20000); |
---|
| 460 | qoriq_l2_cache l2_cache; |
---|
| 461 | QORIQ_FILL(0x20000, 0x21000, qoriq_l2_cache); |
---|
| 462 | qoriq_dma dma_1; |
---|
| 463 | QORIQ_FILL(0x21000, 0x22000, qoriq_dma); |
---|
| 464 | qoriq_usb usb_1; |
---|
| 465 | QORIQ_FILL(0x22000, 0x23000, qoriq_usb); |
---|
| 466 | qoriq_usb usb_2; |
---|
| 467 | QORIQ_FILL(0x23000, 0x24000, qoriq_usb); |
---|
| 468 | tsec_registers tsec_1; |
---|
| 469 | QORIQ_FILL(0x24000, 0x25000, tsec_registers); |
---|
| 470 | tsec_registers tsec_2; |
---|
| 471 | QORIQ_FILL(0x25000, 0x26000, tsec_registers); |
---|
| 472 | tsec_registers tsec_3; |
---|
| 473 | QORIQ_FILL(0x26000, 0x27000, tsec_registers); |
---|
| 474 | QORIQ_RESERVE(0x27000, 0x2c000); |
---|
| 475 | qoriq_tdm_dma tdm_dma; |
---|
| 476 | QORIQ_FILL(0x2c000, 0x2d000, qoriq_tdm_dma); |
---|
| 477 | QORIQ_RESERVE(0x2d000, 0x2e000); |
---|
| 478 | qoriq_esdhc esdhc; |
---|
| 479 | QORIQ_FILL(0x2e000, 0x2f000, qoriq_esdhc); |
---|
| 480 | QORIQ_RESERVE(0x2f000, 0x30000); |
---|
| 481 | qoriq_sec sec; |
---|
| 482 | QORIQ_FILL(0x30000, 0x31000, qoriq_sec); |
---|
| 483 | QORIQ_RESERVE(0x31000, 0x40000); |
---|
| 484 | qoriq_pic pic; |
---|
| 485 | QORIQ_FILL(0x40000, 0x80000, qoriq_pic); |
---|
| 486 | QORIQ_RESERVE(0x80000, 0xb0000); |
---|
| 487 | tsec_registers tsec_1_group_0; |
---|
| 488 | QORIQ_FILL(0xb0000, 0xb1000, tsec_registers); |
---|
| 489 | tsec_registers tsec_2_group_0; |
---|
| 490 | QORIQ_FILL(0xb1000, 0xb2000, tsec_registers); |
---|
| 491 | tsec_registers tsec_3_group_0; |
---|
| 492 | QORIQ_FILL(0xb2000, 0xb3000, tsec_registers); |
---|
| 493 | QORIQ_RESERVE(0xb3000, 0xb4000); |
---|
| 494 | tsec_registers tsec_1_group_1; |
---|
| 495 | QORIQ_FILL(0xb4000, 0xb5000, tsec_registers); |
---|
| 496 | tsec_registers tsec_2_group_1; |
---|
| 497 | QORIQ_FILL(0xb5000, 0xb6000, tsec_registers); |
---|
| 498 | tsec_registers tsec_3_group_1; |
---|
| 499 | QORIQ_FILL(0xb6000, 0xb7000, tsec_registers); |
---|
| 500 | QORIQ_RESERVE(0xb7000, 0xc0000); |
---|
| 501 | qoriq_serial_rapid_io serial_rapid_io; |
---|
| 502 | QORIQ_FILL(0xc0000, 0xe0000, qoriq_serial_rapid_io); |
---|
| 503 | qoriq_global_utilities global_utilities; |
---|
| 504 | QORIQ_FILL(0xe0000, 0xe1000, qoriq_global_utilities); |
---|
| 505 | qoriq_performance_monitor performance_monitor; |
---|
| 506 | QORIQ_FILL(0xe1000, 0xe2000, qoriq_performance_monitor); |
---|
| 507 | qoriq_debug_watchpoint debug_watchpoint; |
---|
| 508 | QORIQ_FILL(0xe2000, 0xe3000, qoriq_debug_watchpoint); |
---|
| 509 | qoriq_serdes serdes; |
---|
| 510 | QORIQ_FILL(0xe3000, 0xe4000, qoriq_serdes); |
---|
| 511 | QORIQ_RESERVE(0xe4000, 0xf0000); |
---|
| 512 | qoriq_boot_rom boot_rom; |
---|
| 513 | QORIQ_FILL(0xf0000, 0x100000, qoriq_boot_rom); |
---|
| 514 | } qoriq_ccsr; |
---|
| 515 | |
---|
[f2e6c3e] | 516 | #endif /* QORIQ_CHIP_VARIANT */ |
---|
| 517 | |
---|
[dc0a7df] | 518 | extern volatile qoriq_ccsr qoriq; |
---|
| 519 | |
---|
[dd863f8] | 520 | #if QORIQ_CHIP_IS_T_VARIANT(QORIQ_CHIP_VARIANT) |
---|
| 521 | extern uint8_t qoriq_bman_portal[2][16777216]; |
---|
| 522 | extern uint8_t qoriq_qman_portal[2][16777216]; |
---|
| 523 | #endif |
---|
| 524 | |
---|
[dc0a7df] | 525 | #ifdef __cplusplus |
---|
| 526 | } |
---|
| 527 | #endif /* __cplusplus */ |
---|
| 528 | |
---|
| 529 | #endif /* LIBBSP_POWERPC_QORIQ_QORIQ_H */ |
---|