• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * asm/metag_mem.h
3  *
4  * Copyright (C) 2000-2007, 2012 Imagination Technologies.
5  *
6  * This program is free software; you can redistribute it and/or modify it under
7  * the terms of the GNU General Public License version 2 as published by the
8  * Free Software Foundation.
9  *
10  * Various defines for Meta (memory-mapped) registers.
11  */
12 
13 #ifndef _ASM_METAG_MEM_H_
14 #define _ASM_METAG_MEM_H_
15 
16 /*****************************************************************************
17  *                   META MEMORY MAP LINEAR ADDRESS VALUES
18  ****************************************************************************/
19 /*
20  * COMMON MEMORY MAP
21  * -----------------
22  */
23 
24 #define LINSYSTEM_BASE  0x00200000
25 #define LINSYSTEM_LIMIT 0x07FFFFFF
26 
27 /* Linear cache flush now implemented via DCACHE instruction. These defines
28    related to a special region that used to exist for achieving cache flushes.
29  */
30 #define         LINSYSLFLUSH_S 0
31 
32 #define     LINSYSRES0_BASE     0x00200000
33 #define     LINSYSRES0_LIMIT    0x01FFFFFF
34 
35 #define     LINSYSCUSTOM_BASE 0x02000000
36 #define     LINSYSCUSTOM_LIMIT   0x02FFFFFF
37 
38 #define     LINSYSEXPAND_BASE 0x03000000
39 #define     LINSYSEXPAND_LIMIT   0x03FFFFFF
40 
41 #define     LINSYSEVENT_BASE  0x04000000
42 #define         LINSYSEVENT_WR_ATOMIC_UNLOCK    0x04000000
43 #define         LINSYSEVENT_WR_ATOMIC_LOCK      0x04000040
44 #define         LINSYSEVENT_WR_CACHE_DISABLE    0x04000080
45 #define         LINSYSEVENT_WR_CACHE_ENABLE     0x040000C0
46 #define         LINSYSEVENT_WR_COMBINE_FLUSH    0x04000100
47 #define         LINSYSEVENT_WR_FENCE            0x04000140
48 #define     LINSYSEVENT_LIMIT   0x04000FFF
49 
50 #define     LINSYSCFLUSH_BASE   0x04400000
51 #define         LINSYSCFLUSH_DCACHE_LINE    0x04400000
52 #define         LINSYSCFLUSH_ICACHE_LINE    0x04500000
53 #define         LINSYSCFLUSH_MMCU           0x04700000
54 #ifndef METAC_1_2
55 #define         LINSYSCFLUSH_TxMMCU_BASE    0x04700020
56 #define         LINSYSCFLUSH_TxMMCU_STRIDE  0x00000008
57 #endif
58 #define         LINSYSCFLUSH_ADDR_BITS      0x000FFFFF
59 #define         LINSYSCFLUSH_ADDR_S         0
60 #define     LINSYSCFLUSH_LIMIT  0x047FFFFF
61 
62 #define     LINSYSCTRL_BASE     0x04800000
63 #define     LINSYSCTRL_LIMIT    0x04FFFFFF
64 
65 #define     LINSYSMTABLE_BASE   0x05000000
66 #define     LINSYSMTABLE_LIMIT  0x05FFFFFF
67 
68 #define     LINSYSDIRECT_BASE   0x06000000
69 #define     LINSYSDIRECT_LIMIT  0x07FFFFFF
70 
71 #define LINLOCAL_BASE   0x08000000
72 #define LINLOCAL_LIMIT  0x7FFFFFFF
73 
74 #define LINCORE_BASE    0x80000000
75 #define LINCORE_LIMIT   0x87FFFFFF
76 
77 #define LINCORE_CODE_BASE  0x80000000
78 #define LINCORE_CODE_LIMIT 0x81FFFFFF
79 
80 #define LINCORE_DATA_BASE  0x82000000
81 #define LINCORE_DATA_LIMIT 0x83FFFFFF
82 
83 
84 /* The core can support locked icache lines in this region */
85 #define LINCORE_ICACHE_BASE  0x84000000
86 #define LINCORE_ICACHE_LIMIT 0x85FFFFFF
87 
88 /* The core can support locked dcache lines in this region */
89 #define LINCORE_DCACHE_BASE  0x86000000
90 #define LINCORE_DCACHE_LIMIT 0x87FFFFFF
91 
92 #define LINGLOBAL_BASE  0x88000000
93 #define LINGLOBAL_LIMIT 0xFFFDFFFF
94 
95 /*
96  * CHIP Core Register Map
97  * ----------------------
98  */
99 #define CORE_HWBASE     0x04800000
100 #define PRIV_HWBASE     0x04810000
101 #define TRIG_HWBASE     0x04820000
102 #define SYSC_HWBASE     0x04830000
103 
104 /*****************************************************************************
105  *         INTER-THREAD KICK REGISTERS FOR SOFTWARE EVENT GENERATION
106  ****************************************************************************/
107 /*
108  * These values define memory mapped registers that can be used to supply
109  * kicks to threads that service arbitrary software events.
110  */
111 
112 #define T0KICK     0x04800800   /* Background kick 0     */
113 #define     TXXKICK_MAX 0xFFFF  /* Maximum kicks */
114 #define     TnXKICK_STRIDE      0x00001000  /* Thread scale value    */
115 #define     TnXKICK_STRIDE_S    12
116 #define T0KICKI    0x04800808   /* Interrupt kick 0      */
117 #define     TXIKICK_OFFSET  0x00000008  /* Int level offset value */
118 #define T1KICK     0x04801800   /* Background kick 1     */
119 #define T1KICKI    0x04801808   /* Interrupt kick 1      */
120 #define T2KICK     0x04802800   /* Background kick 2     */
121 #define T2KICKI    0x04802808   /* Interrupt kick 2      */
122 #define T3KICK     0x04803800   /* Background kick 3     */
123 #define T3KICKI    0x04803808   /* Interrupt kick 3      */
124 
125 /*****************************************************************************
126  *                GLOBAL REGISTER ACCESS RESOURCES
127  ****************************************************************************/
128 /*
129  * These values define memory mapped registers that allow access to the
130  * internal state of all threads in order to allow global set-up of thread
131  * state and external handling of thread events, errors, or debugging.
132  *
133  * The actual unit and register index values needed to access individul
134  * registers are chip specific see - METAC_TXUXX_VALUES in metac_x_y.h.
135  * However two C array initialisers TXUXX_MASKS and TGUXX_MASKS will always be
136  * defined to allow arbitrary loading, display, and saving of all valid
137  * register states without detailed knowledge of their purpose - TXUXX sets
138  * bits for all valid registers and TGUXX sets bits for the sub-set which are
139  * global.
140  */
141 
142 #define T0UCTREG0   0x04800000  /* Access to all CT regs */
143 #define TnUCTRX_STRIDE      0x00001000  /* Thread scale value    */
144 #define TXUCTREGn_STRIDE    0x00000008  /* Register scale value  */
145 
146 #define TXUXXRXDT  0x0480FFF0   /* Data to/from any threads reg */
147 #define TXUXXRXRQ  0x0480FFF8
148 #define     TXUXXRXRQ_DREADY_BIT 0x80000000  /* Poll for done */
149 #define     TXUXXRXRQ_DSPEXT_BIT 0x00020000  /* Addr DSP Regs */
150 #define     TXUXXRXRQ_RDnWR_BIT  0x00010000  /* Set for read  */
151 #define     TXUXXRXRQ_TX_BITS    0x00003000  /* Thread number */
152 #define     TXUXXRXRQ_TX_S       12
153 #define     TXUXXRXRQ_RX_BITS    0x000001F0  /* Register num  */
154 #define     TXUXXRXRQ_RX_S       4
155 #define         TXUXXRXRQ_DSPRARD0    0      /* DSP RAM A Read Pointer 0 */
156 #define         TXUXXRXRQ_DSPRARD1    1      /* DSP RAM A Read Pointer 1 */
157 #define         TXUXXRXRQ_DSPRAWR0    2      /* DSP RAM A Write Pointer 0 */
158 #define         TXUXXRXRQ_DSPRAWR2    3      /* DSP RAM A Write Pointer 1 */
159 #define         TXUXXRXRQ_DSPRBRD0    4      /* DSP RAM B Read Pointer 0 */
160 #define         TXUXXRXRQ_DSPRBRD1    5      /* DSP RAM B Read Pointer 1 */
161 #define         TXUXXRXRQ_DSPRBWR0    6      /* DSP RAM B Write Pointer 0 */
162 #define         TXUXXRXRQ_DSPRBWR1    7      /* DSP RAM B Write Pointer 1 */
163 #define         TXUXXRXRQ_DSPRARINC0  8      /* DSP RAM A Read Increment 0 */
164 #define         TXUXXRXRQ_DSPRARINC1  9      /* DSP RAM A Read Increment 1 */
165 #define         TXUXXRXRQ_DSPRAWINC0 10      /* DSP RAM A Write Increment 0 */
166 #define         TXUXXRXRQ_DSPRAWINC1 11      /* DSP RAM A Write Increment 1 */
167 #define         TXUXXRXRQ_DSPRBRINC0 12      /* DSP RAM B Read Increment 0 */
168 #define         TXUXXRXRQ_DSPRBRINC1 13      /* DSP RAM B Read Increment 1 */
169 #define         TXUXXRXRQ_DSPRBWINC0 14      /* DSP RAM B Write Increment 0 */
170 #define         TXUXXRXRQ_DSPRBWINC1 15      /* DSP RAM B Write Increment 1 */
171 
172 #define         TXUXXRXRQ_ACC0L0     16      /* Accumulator 0 bottom 32-bits */
173 #define         TXUXXRXRQ_ACC1L0     17      /* Accumulator 1 bottom 32-bits */
174 #define         TXUXXRXRQ_ACC2L0     18      /* Accumulator 2 bottom 32-bits */
175 #define         TXUXXRXRQ_ACC3L0     19      /* Accumulator 3 bottom 32-bits */
176 #define         TXUXXRXRQ_ACC0HI     20      /* Accumulator 0 top 8-bits */
177 #define         TXUXXRXRQ_ACC1HI     21      /* Accumulator 1 top 8-bits */
178 #define         TXUXXRXRQ_ACC2HI     22      /* Accumulator 2 top 8-bits */
179 #define         TXUXXRXRQ_ACC3HI     23      /* Accumulator 3 top 8-bits */
180 #define     TXUXXRXRQ_UXX_BITS   0x0000000F  /* Unit number   */
181 #define     TXUXXRXRQ_UXX_S      0
182 
183 /*****************************************************************************
184  *          PRIVILEGE CONTROL VALUES FOR MEMORY MAPPED RESOURCES
185  ****************************************************************************/
186 /*
187  * These values define memory mapped registers that give control over and
188  * the privilege required to access other memory mapped resources. These
189  * registers themselves always require privilege to update them.
190  */
191 
192 #define TXPRIVREG_STRIDE    0x8 /* Delta between per-thread regs */
193 #define TXPRIVREG_STRIDE_S  3
194 
195 /*
196  * Each bit 0 to 15 defines privilege required to access internal register
197  * regions 0x04800000 to 0x048FFFFF in 64k chunks
198  */
199 #define T0PIOREG    0x04810100
200 #define T1PIOREG    0x04810108
201 #define T2PIOREG    0x04810110
202 #define T3PIOREG    0x04810118
203 
204 /*
205  * Each bit 0 to 31 defines privilege required to use the pair of
206  * system events implemented as writee in the regions 0x04000000 to
207  * 0x04000FFF in 2*64 byte chunks.
208  */
209 #define T0PSYREG    0x04810180
210 #define T1PSYREG    0x04810188
211 #define T2PSYREG    0x04810190
212 #define T3PSYREG    0x04810198
213 
214 /*
215  * CHIP PRIV CONTROLS
216  * ------------------
217  */
218 
219 /* The TXPIOREG register holds a bit mask directly mappable to
220    corresponding addresses in the range 0x04800000 to 049FFFFF */
221 #define     TXPIOREG_ADDR_BITS  0x1F0000 /* Up to 32x64K bytes */
222 #define     TXPIOREG_ADDR_S     16
223 
224 /* Hence based on the _HWBASE values ... */
225 #define     TXPIOREG_CORE_BIT       (1<<((0x04800000>>16)&0x1F))
226 #define     TXPIOREG_PRIV_BIT       (1<<((0x04810000>>16)&0x1F))
227 #define     TXPIOREG_TRIG_BIT       (1<<((0x04820000>>16)&0x1F))
228 #define     TXPIOREG_SYSC_BIT       (1<<((0x04830000>>16)&0x1F))
229 
230 #define     TXPIOREG_WRC_BIT          0x00080000  /* Wr combiner reg priv */
231 #define     TXPIOREG_LOCALBUS_RW_BIT  0x00040000  /* Local bus rd/wr priv */
232 #define     TXPIOREG_SYSREGBUS_RD_BIT 0x00020000  /* Sys reg bus write priv */
233 #define     TXPIOREG_SYSREGBUS_WR_BIT 0x00010000  /* Sys reg bus read priv */
234 
235 /* CORE region privilege controls */
236 #define T0PRIVCORE 0x04800828
237 #define         TXPRIVCORE_TXBKICK_BIT   0x001  /* Background kick priv */
238 #define         TXPRIVCORE_TXIKICK_BIT   0x002  /* Interrupt kick priv  */
239 #define         TXPRIVCORE_TXAMAREGX_BIT 0x004  /* TXAMAREG4|5|6 priv   */
240 #define TnPRIVCORE_STRIDE 0x00001000
241 
242 #define T0PRIVSYSR 0x04810000
243 #define     TnPRIVSYSR_STRIDE   0x00000008
244 #define     TnPRIVSYSR_STRIDE_S 3
245 #define     TXPRIVSYSR_CFLUSH_BIT     0x01
246 #define     TXPRIVSYSR_MTABLE_BIT     0x02
247 #define     TXPRIVSYSR_DIRECT_BIT     0x04
248 #ifdef METAC_1_2
249 #define     TXPRIVSYSR_ALL_BITS       0x07
250 #else
251 #define     TXPRIVSYSR_CORE_BIT       0x08
252 #define     TXPRIVSYSR_CORECODE_BIT   0x10
253 #define     TXPRIVSYSR_ALL_BITS       0x1F
254 #endif
255 #define T1PRIVSYSR 0x04810008
256 #define T2PRIVSYSR 0x04810010
257 #define T3PRIVSYSR 0x04810018
258 
259 /*****************************************************************************
260  *          H/W TRIGGER STATE/LEVEL REGISTERS AND H/W TRIGGER VECTORS
261  ****************************************************************************/
262 /*
263  * These values define memory mapped registers that give control over and
264  * the state of hardware trigger sources both external to the META processor
265  * and internal to it.
266  */
267 
268 #define HWSTATMETA  0x04820000  /* Hardware status/clear META trig */
269 #define         HWSTATMETA_T0HALT_BITS 0xF
270 #define         HWSTATMETA_T0HALT_S    0
271 #define     HWSTATMETA_T0BHALT_BIT 0x1  /* Background HALT */
272 #define     HWSTATMETA_T0IHALT_BIT 0x2  /* Interrupt HALT  */
273 #define     HWSTATMETA_T0PHALT_BIT 0x4  /* PF/RO Memory HALT */
274 #define     HWSTATMETA_T0AMATR_BIT 0x8  /* AMA trigger */
275 #define     HWSTATMETA_TnINT_S     4    /* Shift by (thread*4) */
276 #define HWSTATEXT   0x04820010  /* H/W status/clear external trigs  0-31 */
277 #define HWSTATEXT2  0x04820018  /* H/W status/clear external trigs 32-63 */
278 #define HWSTATEXT4  0x04820020  /* H/W status/clear external trigs 64-95 */
279 #define HWSTATEXT6  0x04820028  /* H/W status/clear external trigs 96-128 */
280 #define HWLEVELEXT  0x04820030  /* Edge/Level type of external trigs  0-31 */
281 #define HWLEVELEXT2 0x04820038  /* Edge/Level type of external trigs 32-63 */
282 #define HWLEVELEXT4 0x04820040  /* Edge/Level type of external trigs 64-95 */
283 #define HWLEVELEXT6 0x04820048  /* Edge/Level type of external trigs 96-128 */
284 #define     HWLEVELEXT_XXX_LEVEL 1  /* Level sense logic in HWSTATEXTn */
285 #define     HWLEVELEXT_XXX_EDGE  0
286 #define HWMASKEXT   0x04820050  /* Enable/disable of external trigs  0-31 */
287 #define HWMASKEXT2  0x04820058  /* Enable/disable of external trigs 32-63 */
288 #define HWMASKEXT4  0x04820060  /* Enable/disable of external trigs 64-95 */
289 #define HWMASKEXT6  0x04820068  /* Enable/disable of external trigs 96-128 */
290 #define T0VECINT_BHALT  0x04820500  /* Background HALT trigger vector */
291 #define     TXVECXXX_BITS   0xF       /* Per-trigger vector vals 0,1,4-15 */
292 #define     TXVECXXX_S  0
293 #define T0VECINT_IHALT  0x04820508  /* Interrupt HALT */
294 #define T0VECINT_PHALT  0x04820510  /* PF/RO memory fault */
295 #define T0VECINT_AMATR  0x04820518  /* AMA trigger */
296 #define     TnVECINT_STRIDE 0x00000020  /* Per thread stride */
297 #define HWVEC0EXT   0x04820700  /* Vectors for external triggers  0-31 */
298 #define HWVEC20EXT  0x04821700  /* Vectors for external triggers 32-63 */
299 #define HWVEC40EXT  0x04822700  /* Vectors for external triggers 64-95 */
300 #define HWVEC60EXT  0x04823700  /* Vectors for external triggers 96-127 */
301 #define     HWVECnEXT_STRIDE 0x00000008 /* Per trigger stride */
302 #define HWVECnEXT_DEBUG 0x1         /* Redirect trigger to debug i/f */
303 
304 /*
305  * CORE HWCODE-BREAKPOINT REGISTERS/VALUES
306  * ---------------------------------------
307  */
308 #define CODEB0ADDR         0x0480FF00  /* Address specifier */
309 #define     CODEBXADDR_MATCHX_BITS 0xFFFFFFFC
310 #define     CODEBXADDR_MATCHX_S    2
311 #define CODEB0CTRL         0x0480FF08  /* Control */
312 #define     CODEBXCTRL_MATEN_BIT   0x80000000   /* Match 'Enable'  */
313 #define     CODEBXCTRL_MATTXEN_BIT 0x10000000   /* Match threadn enable */
314 #define     CODEBXCTRL_HITC_BITS   0x00FF0000   /* Hit counter   */
315 #define     CODEBXCTRL_HITC_S      16
316 #define           CODEBXHITC_NEXT  0xFF     /* Next 'hit' will trigger */
317 #define           CODEBXHITC_HIT1  0x00     /* No 'hits' after trigger */
318 #define     CODEBXCTRL_MMASK_BITS  0x0000FFFC   /* Mask ADDR_MATCH bits */
319 #define     CODEBXCTRL_MMASK_S     2
320 #define     CODEBXCTRL_MATLTX_BITS 0x00000003   /* Match threadn LOCAL addr */
321 #define     CODEBXCTRL_MATLTX_S    0            /* Match threadn LOCAL addr */
322 #define CODEBnXXXX_STRIDE      0x00000010  /* Stride between CODEB reg sets */
323 #define CODEBnXXXX_STRIDE_S    4
324 #define CODEBnXXXX_LIMIT       3           /* Sets 0-3 */
325 
326 /*
327  * CORE DATA-WATCHPOINT REGISTERS/VALUES
328  * -------------------------------------
329  */
330 #define DATAW0ADDR         0x0480FF40  /* Address specifier */
331 #define     DATAWXADDR_MATCHR_BITS 0xFFFFFFF8
332 #define     DATAWXADDR_MATCHR_S    3
333 #define     DATAWXADDR_MATCHW_BITS 0xFFFFFFFF
334 #define     DATAWXADDR_MATCHW_S    0
335 #define DATAW0CTRL         0x0480FF48  /* Control */
336 #define     DATAWXCTRL_MATRD_BIT   0x80000000   /* Match 'Read'  */
337 #ifndef METAC_1_2
338 #define     DATAWXCTRL_MATNOTTX_BIT 0x20000000  /* Invert threadn enable */
339 #endif
340 #define     DATAWXCTRL_MATWR_BIT   0x40000000   /* Match 'Write' */
341 #define     DATAWXCTRL_MATTXEN_BIT 0x10000000   /* Match threadn enable */
342 #define     DATAWXCTRL_WRSIZE_BITS 0x0F000000   /* Write Match Size */
343 #define     DATAWXCTRL_WRSIZE_S    24
344 #define         DATAWWRSIZE_ANY   0         /* Any size transaction matches */
345 #define         DATAWWRSIZE_8BIT  1     /* Specific sizes ... */
346 #define         DATAWWRSIZE_16BIT 2
347 #define         DATAWWRSIZE_32BIT 3
348 #define         DATAWWRSIZE_64BIT 4
349 #define     DATAWXCTRL_HITC_BITS   0x00FF0000   /* Hit counter   */
350 #define     DATAWXCTRL_HITC_S      16
351 #define           DATAWXHITC_NEXT  0xFF     /* Next 'hit' will trigger */
352 #define           DATAWXHITC_HIT1  0x00     /* No 'hits' after trigger */
353 #define     DATAWXCTRL_MMASK_BITS 0x0000FFF8    /* Mask ADDR_MATCH bits */
354 #define     DATAWXCTRL_MMASK_S    3
355 #define     DATAWXCTRL_MATLTX_BITS 0x00000003   /* Match threadn LOCAL addr */
356 #define     DATAWXCTRL_MATLTX_S    0            /* Match threadn LOCAL addr */
357 #define DATAW0DMATCH0       0x0480FF50 /* Write match data */
358 #define DATAW0DMATCH1       0x0480FF58
359 #define DATAW0DMASK0        0x0480FF60 /* Write match data mask */
360 #define DATAW0DMASK1        0x0480FF68
361 #define DATAWnXXXX_STRIDE      0x00000040  /* Stride between DATAW reg sets */
362 #define DATAWnXXXX_STRIDE_S    6
363 #define DATAWnXXXX_LIMIT       1           /* Sets 0,1 */
364 
365 /*
366  * CHIP Automatic Mips Allocation control registers
367  * ------------------------------------------------
368  */
369 
370 /* CORE memory mapped AMA registers */
371 #define T0AMAREG4   0x04800810
372 #define     TXAMAREG4_POOLSIZE_BITS 0x3FFFFF00
373 #define     TXAMAREG4_POOLSIZE_S    8
374 #define     TXAMAREG4_AVALUE_BITS   0x000000FF
375 #define     TXAMAREG4_AVALUE_S  0
376 #define T0AMAREG5   0x04800818
377 #define     TXAMAREG5_POOLC_BITS    0x07FFFFFF
378 #define         TXAMAREG5_POOLC_S       0
379 #define T0AMAREG6   0x04800820
380 #define     TXAMAREG6_DLINEDEF_BITS 0x00FFFFF0
381 #define         TXAMAREG6_DLINEDEF_S    0
382 #define TnAMAREGX_STRIDE    0x00001000
383 
384 /*
385  * Memory Management Control Unit Table Entries
386  * --------------------------------------------
387  */
388 #define MMCU_ENTRY_S         4            /* -> Entry size                */
389 #define MMCU_ENTRY_ADDR_BITS 0xFFFFF000   /* Physical address             */
390 #define MMCU_ENTRY_ADDR_S    12           /* -> Page size                 */
391 #define MMCU_ENTRY_CWIN_BITS 0x000000C0   /* Caching 'window' selection   */
392 #define MMCU_ENTRY_CWIN_S    6
393 #define     MMCU_CWIN_UNCACHED  0 /* May not be memory etc.  */
394 #define     MMCU_CWIN_BURST     1 /* Cached but LRU unset */
395 #define     MMCU_CWIN_C1SET     2 /* Cached in 1 set only */
396 #define     MMCU_CWIN_CACHED    3 /* Fully cached            */
397 #define MMCU_ENTRY_CACHE_BIT 0x00000080   /* Set for cached region         */
398 #define     MMCU_ECACHE1_FULL_BIT  0x00000040 /* Use all the sets */
399 #define     MMCU_ECACHE0_BURST_BIT 0x00000040 /* Match bursts     */
400 #define MMCU_ENTRY_SYS_BIT   0x00000010   /* Sys-coherent access required  */
401 #define MMCU_ENTRY_WRC_BIT   0x00000008   /* Write combining allowed       */
402 #define MMCU_ENTRY_PRIV_BIT  0x00000004   /* Privilege required            */
403 #define MMCU_ENTRY_WR_BIT    0x00000002   /* Writes allowed                */
404 #define MMCU_ENTRY_VAL_BIT   0x00000001   /* Entry is valid                */
405 
406 #ifdef METAC_2_1
407 /*
408  * Extended first-level/top table entries have extra/larger fields in later
409  * cores as bits 11:0 previously had no effect in such table entries.
410  */
411 #define MMCU_E1ENT_ADDR_BITS 0xFFFFFFC0   /* Physical address             */
412 #define MMCU_E1ENT_ADDR_S    6            /*   -> resolution < page size  */
413 #define MMCU_E1ENT_PGSZ_BITS 0x0000001E   /* Page size for 2nd level      */
414 #define MMCU_E1ENT_PGSZ_S    1
415 #define     MMCU_E1ENT_PGSZ0_POWER   12   /* PgSz  0 -> 4K */
416 #define     MMCU_E1ENT_PGSZ_MAX      10   /* PgSz 10 -> 4M maximum */
417 #define MMCU_E1ENT_MINIM_BIT 0x00000020
418 #endif /* METAC_2_1 */
419 
420 /* MMCU control register in SYSC region */
421 #define MMCU_TABLE_PHYS_ADDR        0x04830010
422 #define     MMCU_TABLE_PHYS_ADDR_BITS   0xFFFFFFFC
423 #ifdef METAC_2_1
424 #define     MMCU_TABLE_PHYS_EXTEND      0x00000001     /* See below */
425 #endif
426 #define MMCU_DCACHE_CTRL_ADDR       0x04830018
427 #define     MMCU_xCACHE_CTRL_ENABLE_BIT     0x00000001
428 #define     MMCU_xCACHE_CTRL_PARTITION_BIT  0x00000000 /* See xCPART below */
429 #define MMCU_ICACHE_CTRL_ADDR       0x04830020
430 
431 #ifdef METAC_2_1
432 
433 /*
434  * Allow direct access to physical memory used to implement MMU table.
435  *
436  * Each is based on a corresponding MMCU_TnLOCAL_TABLE_PHYSn or similar
437  *    MMCU_TnGLOBAL_TABLE_PHYSn register pair (see next).
438  */
439 #define LINSYSMEMT0L_BASE   0x05000000
440 #define LINSYSMEMT0L_LIMIT  0x051FFFFF
441 #define     LINSYSMEMTnX_STRIDE     0x00200000  /*  2MB Local per thread */
442 #define     LINSYSMEMTnX_STRIDE_S   21
443 #define     LINSYSMEMTXG_OFFSET     0x00800000  /* +2MB Global per thread */
444 #define     LINSYSMEMTXG_OFFSET_S   23
445 #define LINSYSMEMT1L_BASE   0x05200000
446 #define LINSYSMEMT1L_LIMIT  0x053FFFFF
447 #define LINSYSMEMT2L_BASE   0x05400000
448 #define LINSYSMEMT2L_LIMIT  0x055FFFFF
449 #define LINSYSMEMT3L_BASE   0x05600000
450 #define LINSYSMEMT3L_LIMIT  0x057FFFFF
451 #define LINSYSMEMT0G_BASE   0x05800000
452 #define LINSYSMEMT0G_LIMIT  0x059FFFFF
453 #define LINSYSMEMT1G_BASE   0x05A00000
454 #define LINSYSMEMT1G_LIMIT  0x05BFFFFF
455 #define LINSYSMEMT2G_BASE   0x05C00000
456 #define LINSYSMEMT2G_LIMIT  0x05DFFFFF
457 #define LINSYSMEMT3G_BASE   0x05E00000
458 #define LINSYSMEMT3G_LIMIT  0x05FFFFFF
459 
460 /*
461  * Extended MMU table functionality allows a sparse or flat table to be
462  * described much more efficiently than before.
463  */
464 #define MMCU_T0LOCAL_TABLE_PHYS0    0x04830700
465 #define   MMCU_TnX_TABLE_PHYSX_STRIDE    0x20   /* Offset per thread */
466 #define   MMCU_TnX_TABLE_PHYSX_STRIDE_S  5
467 #define   MMCU_TXG_TABLE_PHYSX_OFFSET    0x10   /* Global versus local */
468 #define   MMCU_TXG_TABLE_PHYSX_OFFSET_S  4
469 #define     MMCU_TBLPHYS0_DCCTRL_BITS       0x000000DF  /* DC controls  */
470 #define     MMCU_TBLPHYS0_ENTLB_BIT         0x00000020  /* Cache in TLB */
471 #define     MMCU_TBLPHYS0_TBLSZ_BITS        0x00000F00  /* Area supported */
472 #define     MMCU_TBLPHYS0_TBLSZ_S           8
473 #define         MMCU_TBLPHYS0_TBLSZ0_POWER      22  /* 0 -> 4M */
474 #define         MMCU_TBLPHYS0_TBLSZ_MAX         9   /* 9 -> 2G */
475 #define     MMCU_TBLPHYS0_LINBASE_BITS      0xFFC00000  /* Linear base */
476 #define     MMCU_TBLPHYS0_LINBASE_S         22
477 
478 #define MMCU_T0LOCAL_TABLE_PHYS1    0x04830708
479 #define     MMCU_TBLPHYS1_ADDR_BITS         0xFFFFFFFC  /* Physical base */
480 #define     MMCU_TBLPHYS1_ADDR_S            2
481 
482 #define MMCU_T0GLOBAL_TABLE_PHYS0   0x04830710
483 #define MMCU_T0GLOBAL_TABLE_PHYS1   0x04830718
484 #define MMCU_T1LOCAL_TABLE_PHYS0    0x04830720
485 #define MMCU_T1LOCAL_TABLE_PHYS1    0x04830728
486 #define MMCU_T1GLOBAL_TABLE_PHYS0   0x04830730
487 #define MMCU_T1GLOBAL_TABLE_PHYS1   0x04830738
488 #define MMCU_T2LOCAL_TABLE_PHYS0    0x04830740
489 #define MMCU_T2LOCAL_TABLE_PHYS1    0x04830748
490 #define MMCU_T2GLOBAL_TABLE_PHYS0   0x04830750
491 #define MMCU_T2GLOBAL_TABLE_PHYS1   0x04830758
492 #define MMCU_T3LOCAL_TABLE_PHYS0    0x04830760
493 #define MMCU_T3LOCAL_TABLE_PHYS1    0x04830768
494 #define MMCU_T3GLOBAL_TABLE_PHYS0   0x04830770
495 #define MMCU_T3GLOBAL_TABLE_PHYS1   0x04830778
496 
497 #define MMCU_T0EBWCCTRL             0x04830640
498 #define     MMCU_TnEBWCCTRL_BITS    0x00000007
499 #define     MMCU_TnEBWCCTRL_S       0
500 #define         MMCU_TnEBWCCCTRL_DISABLE_ALL 0
501 #define         MMCU_TnEBWCCCTRL_ABIT25      1
502 #define         MMCU_TnEBWCCCTRL_ABIT26      2
503 #define         MMCU_TnEBWCCCTRL_ABIT27      3
504 #define         MMCU_TnEBWCCCTRL_ABIT28      4
505 #define         MMCU_TnEBWCCCTRL_ABIT29      5
506 #define         MMCU_TnEBWCCCTRL_ABIT30      6
507 #define         MMCU_TnEBWCCCTRL_ENABLE_ALL  7
508 #define MMCU_TnEBWCCTRL_STRIDE      8
509 
510 #endif /* METAC_2_1 */
511 
512 
513 /* Registers within the SYSC register region */
514 #define METAC_ID                0x04830000
515 #define     METAC_ID_MAJOR_BITS     0xFF000000
516 #define     METAC_ID_MAJOR_S        24
517 #define     METAC_ID_MINOR_BITS     0x00FF0000
518 #define     METAC_ID_MINOR_S        16
519 #define     METAC_ID_REV_BITS       0x0000FF00
520 #define     METAC_ID_REV_S          8
521 #define     METAC_ID_MAINT_BITS     0x000000FF
522 #define     METAC_ID_MAINT_S        0
523 
524 #ifdef METAC_2_1
525 /* Use of this section is strongly deprecated */
526 #define METAC_ID2               0x04830008
527 #define     METAC_ID2_DESIGNER_BITS 0xFFFF0000  /* Modified by customer */
528 #define     METAC_ID2_DESIGNER_S    16
529 #define     METAC_ID2_MINOR2_BITS   0x00000F00  /* 3rd digit of prod rev */
530 #define     METAC_ID2_MINOR2_S      8
531 #define     METAC_ID2_CONFIG_BITS   0x000000FF  /* Wrapper configuration */
532 #define     METAC_ID2_CONFIG_S      0
533 
534 /* Primary core identification and configuration information */
535 #define METAC_CORE_ID           0x04831000
536 #define     METAC_COREID_GROUP_BITS   0xFF000000
537 #define     METAC_COREID_GROUP_S      24
538 #define         METAC_COREID_GROUP_METAG  0x14
539 #define     METAC_COREID_ID_BITS      0x00FF0000
540 #define     METAC_COREID_ID_S         16
541 #define         METAC_COREID_ID_W32       0x10   /* >= for 32-bit pipeline */
542 #define     METAC_COREID_CONFIG_BITS  0x0000FFFF
543 #define     METAC_COREID_CONFIG_S     0
544 #define       METAC_COREID_CFGCACHE_BITS    0x0007
545 #define       METAC_COREID_CFGCACHE_S       0
546 #define           METAC_COREID_CFGCACHE_NOM       0
547 #define           METAC_COREID_CFGCACHE_TYPE0     1
548 #define           METAC_COREID_CFGCACHE_NOMMU     1 /* Alias for TYPE0 */
549 #define           METAC_COREID_CFGCACHE_NOCACHE   2
550 #define           METAC_COREID_CFGCACHE_PRIVNOMMU 3
551 #define       METAC_COREID_CFGDSP_BITS      0x0038
552 #define       METAC_COREID_CFGDSP_S         3
553 #define           METAC_COREID_CFGDSP_NOM       0
554 #define           METAC_COREID_CFGDSP_MIN       1
555 #define       METAC_COREID_NOFPACC_BIT      0x0040 /* Set if no FPU accum */
556 #define       METAC_COREID_CFGFPU_BITS      0x0180
557 #define       METAC_COREID_CFGFPU_S         7
558 #define           METAC_COREID_CFGFPU_NOM       0
559 #define           METAC_COREID_CFGFPU_SNGL      1
560 #define           METAC_COREID_CFGFPU_DBL       2
561 #define       METAC_COREID_NOAMA_BIT        0x0200 /* Set if no AMA present */
562 #define       METAC_COREID_NOCOH_BIT        0x0400 /* Set if no Gbl coherency */
563 
564 /* Core revision information */
565 #define METAC_CORE_REV          0x04831008
566 #define     METAC_COREREV_DESIGN_BITS   0xFF000000
567 #define     METAC_COREREV_DESIGN_S      24
568 #define     METAC_COREREV_MAJOR_BITS    0x00FF0000
569 #define     METAC_COREREV_MAJOR_S       16
570 #define     METAC_COREREV_MINOR_BITS    0x0000FF00
571 #define     METAC_COREREV_MINOR_S       8
572 #define     METAC_COREREV_MAINT_BITS    0x000000FF
573 #define     METAC_COREREV_MAINT_S       0
574 
575 /* Configuration information control outside the core */
576 #define METAC_CORE_DESIGNER1    0x04831010      /* Arbitrary value */
577 #define METAC_CORE_DESIGNER2    0x04831018      /* Arbitrary value */
578 
579 /* Configuration information covering presence/number of various features */
580 #define METAC_CORE_CONFIG2      0x04831020
581 #define     METAC_CORECFG2_COREDBGTYPE_BITS 0x60000000   /* Core debug type */
582 #define     METAC_CORECFG2_COREDBGTYPE_S    29
583 #define     METAC_CORECFG2_DCSMALL_BIT      0x04000000   /* Data cache small */
584 #define     METAC_CORECFG2_ICSMALL_BIT      0x02000000   /* Inst cache small */
585 #define     METAC_CORECFG2_DCSZNP_BITS      0x01C00000   /* Data cache size np */
586 #define     METAC_CORECFG2_DCSZNP_S         22
587 #define     METAC_CORECFG2_ICSZNP_BITS      0x00380000  /* Inst cache size np */
588 #define     METAC_CORECFG2_ICSZNP_S         19
589 #define     METAC_CORECFG2_DCSZ_BITS        0x00070000   /* Data cache size */
590 #define     METAC_CORECFG2_DCSZ_S           16
591 #define         METAC_CORECFG2_xCSZ_4K          0        /* Allocated values */
592 #define         METAC_CORECFG2_xCSZ_8K          1
593 #define         METAC_CORECFG2_xCSZ_16K         2
594 #define         METAC_CORECFG2_xCSZ_32K         3
595 #define         METAC_CORECFG2_xCSZ_64K         4
596 #define     METAC_CORE_C2ICSZ_BITS          0x0000E000   /* Inst cache size */
597 #define     METAC_CORE_C2ICSZ_S             13
598 #define     METAC_CORE_GBLACC_BITS          0x00001800   /* Number of Global Acc */
599 #define     METAC_CORE_GBLACC_S             11
600 #define     METAC_CORE_GBLDXR_BITS          0x00000700   /* 0 -> 0, R -> 2^(R-1) */
601 #define     METAC_CORE_GBLDXR_S             8
602 #define     METAC_CORE_GBLAXR_BITS          0x000000E0   /* 0 -> 0, R -> 2^(R-1) */
603 #define     METAC_CORE_GBLAXR_S             5
604 #define     METAC_CORE_RTTRACE_BIT          0x00000010
605 #define     METAC_CORE_WATCHN_BITS          0x0000000C   /* 0 -> 0, N -> 2^N */
606 #define     METAC_CORE_WATCHN_S             2
607 #define     METAC_CORE_BREAKN_BITS          0x00000003   /* 0 -> 0, N -> 2^N */
608 #define     METAC_CORE_BREAKN_S             0
609 
610 /* Configuration information covering presence/number of various features */
611 #define METAC_CORE_CONFIG3      0x04831028
612 #define     METAC_CORECFG3_L2C_REV_ID_BITS          0x000F0000   /* Revision of L2 cache */
613 #define     METAC_CORECFG3_L2C_REV_ID_S             16
614 #define     METAC_CORECFG3_L2C_LINE_SIZE_BITS       0x00003000   /* L2 line size */
615 #define     METAC_CORECFG3_L2C_LINE_SIZE_S          12
616 #define         METAC_CORECFG3_L2C_LINE_SIZE_64B    0x0          /* 64 bytes */
617 #define     METAC_CORECFG3_L2C_NUM_WAYS_BITS        0x00000F00   /* L2 number of ways (2^n) */
618 #define     METAC_CORECFG3_L2C_NUM_WAYS_S           8
619 #define     METAC_CORECFG3_L2C_SIZE_BITS            0x000000F0   /* L2 size (2^n) */
620 #define     METAC_CORECFG3_L2C_SIZE_S               4
621 #define     METAC_CORECFG3_L2C_UNIFIED_BIT          0x00000004   /* Unified cache: */
622 #define     METAC_CORECFG3_L2C_UNIFIED_S            2
623 #define       METAC_CORECFG3_L2C_UNIFIED_UNIFIED    1            /* - Unified D/I cache */
624 #define       METAC_CORECFG3_L2C_UNIFIED_SEPARATE   0            /* - Separate D/I cache */
625 #define     METAC_CORECFG3_L2C_MODE_BIT             0x00000002   /* Cache Mode: */
626 #define     METAC_CORECFG3_L2C_MODE_S               1
627 #define       METAC_CORECFG3_L2C_MODE_WRITE_BACK    1            /* - Write back */
628 #define       METAC_CORECFG3_L2C_MODE_WRITE_THROUGH 0            /* - Write through */
629 #define     METAC_CORECFG3_L2C_HAVE_L2C_BIT         0x00000001   /* Have L2C */
630 #define     METAC_CORECFG3_L2C_HAVE_L2C_S           0
631 
632 #endif /* METAC_2_1 */
633 
634 #define SYSC_CACHE_MMU_CONFIG       0x04830028
635 #ifdef METAC_2_1
636 #define     SYSC_CMMUCFG_DCSKEWABLE_BIT 0x00000040
637 #define     SYSC_CMMUCFG_ICSKEWABLE_BIT 0x00000020
638 #define     SYSC_CMMUCFG_DCSKEWOFF_BIT  0x00000010  /* Skew association override  */
639 #define     SYSC_CMMUCFG_ICSKEWOFF_BIT  0x00000008  /* -> default 0 on if present */
640 #define     SYSC_CMMUCFG_MODE_BITS      0x00000007  /* Access to old state */
641 #define     SYSC_CMMUCFG_MODE_S         0
642 #define         SYSC_CMMUCFG_ON             0x7
643 #define         SYSC_CMMUCFG_EBYPASS        0x6   /* Enhanced by-pass mode */
644 #define         SYSC_CMMUCFG_EBYPASSIC      0x4   /* EB just inst cache */
645 #define         SYSC_CMMUCFG_EBYPASSDC      0x2   /* EB just data cache */
646 #endif /* METAC_2_1 */
647 /* Old definitions, Keep them for now */
648 #define         SYSC_CMMUCFG_MMU_ON_BIT     0x1
649 #define         SYSC_CMMUCFG_DC_ON_BIT      0x2
650 #define         SYSC_CMMUCFG_IC_ON_BIT      0x4
651 
652 #define SYSC_JTAG_THREAD            0x04830030
653 #define     SYSC_JTAG_TX_BITS           0x00000003 /* Read only bits! */
654 #define     SYSC_JTAG_TX_S              0
655 #define     SYSC_JTAG_PRIV_BIT          0x00000004
656 #ifdef METAC_2_1
657 #define     SYSC_JTAG_SLAVETX_BITS      0x00000018
658 #define     SYSC_JTAG_SLAVETX_S         3
659 #endif /* METAC_2_1 */
660 
661 #define SYSC_DCACHE_FLUSH           0x04830038
662 #define SYSC_ICACHE_FLUSH           0x04830040
663 #define  SYSC_xCACHE_FLUSH_INIT     0x1
664 #define MMCU_DIRECTMAP0_ADDR        0x04830080 /* LINSYSDIRECT_BASE -> */
665 #define     MMCU_DIRECTMAPn_STRIDE      0x00000010 /* 4 Region settings */
666 #define     MMCU_DIRECTMAPn_S           4
667 #define         MMCU_DIRECTMAPn_ADDR_BITS       0xFF800000
668 #define         MMCU_DIRECTMAPn_ADDR_S          23
669 #define         MMCU_DIRECTMAPn_ADDR_SCALE      0x00800000 /* 8M Regions */
670 #ifdef METAC_2_1
671 /*
672  * These fields in the above registers provide MMCU_ENTRY_* values
673  *   for each direct mapped region to enable optimisation of these areas.
674  *       (LSB similar to VALID must be set for enhancments to be active)
675  */
676 #define         MMCU_DIRECTMAPn_ENHANCE_BIT     0x00000001 /* 0 = no optim */
677 #define         MMCU_DIRECTMAPn_DCCTRL_BITS     0x000000DF /* Get DC Ctrl */
678 #define         MMCU_DIRECTMAPn_DCCTRL_S        0
679 #define         MMCU_DIRECTMAPn_ICCTRL_BITS     0x0000C000 /* Get IC Ctrl */
680 #define         MMCU_DIRECTMAPn_ICCTRL_S        8
681 #define         MMCU_DIRECTMAPn_ENTLB_BIT       0x00000020 /* Cache in TLB */
682 #define         MMCU_DIRECTMAPn_ICCWIN_BITS     0x0000C000 /* Get IC Win Bits */
683 #define         MMCU_DIRECTMAPn_ICCWIN_S        14
684 #endif /* METAC_2_1 */
685 
686 #define MMCU_DIRECTMAP1_ADDR        0x04830090
687 #define MMCU_DIRECTMAP2_ADDR        0x048300a0
688 #define MMCU_DIRECTMAP3_ADDR        0x048300b0
689 
690 /*
691  * These bits partion each threads use of data cache or instruction cache
692  * resource by modifying the top 4 bits of the address within the cache
693  * storage area.
694  */
695 #define SYSC_DCPART0 0x04830200
696 #define     SYSC_xCPARTn_STRIDE   0x00000008
697 #define     SYSC_xCPARTL_AND_BITS 0x0000000F /* Masks top 4 bits */
698 #define     SYSC_xCPARTL_AND_S    0
699 #define     SYSC_xCPARTG_AND_BITS 0x00000F00 /* Masks top 4 bits */
700 #define     SYSC_xCPARTG_AND_S    8
701 #define     SYSC_xCPARTL_OR_BITS  0x000F0000 /* Ors into top 4 bits */
702 #define     SYSC_xCPARTL_OR_S     16
703 #ifdef METAC_2_1
704 #define     SYSC_DCPART_GCON_BIT  0x00100000 /* Coherent shared local */
705 #endif /* METAC_2_1 */
706 #define     SYSC_xCPARTG_OR_BITS  0x0F000000 /* Ors into top 4 bits */
707 #define     SYSC_xCPARTG_OR_S     24
708 #define     SYSC_CWRMODE_BIT      0x80000000 /* Write cache mode bit */
709 
710 #define SYSC_DCPART1 0x04830208
711 #define SYSC_DCPART2 0x04830210
712 #define SYSC_DCPART3 0x04830218
713 #define SYSC_ICPART0 0x04830220
714 #define SYSC_ICPART1 0x04830228
715 #define SYSC_ICPART2 0x04830230
716 #define SYSC_ICPART3 0x04830238
717 
718 /*
719  * META Core Memory and Cache Update registers
720  */
721 #define SYSC_MCMDATAX  0x04830300   /* 32-bit read/write data register */
722 #define SYSC_MCMDATAT  0x04830308   /* Read or write data triggers oper */
723 #define SYSC_MCMGCTRL  0x04830310   /* Control register */
724 #define     SYSC_MCMGCTRL_READ_BIT  0x00000001 /* Set to issue 1st read */
725 #define     SYSC_MCMGCTRL_AINC_BIT  0x00000002 /* Set for auto-increment */
726 #define     SYSC_MCMGCTRL_ADDR_BITS 0x000FFFFC /* Address or index */
727 #define     SYSC_MCMGCTRL_ADDR_S    2
728 #define     SYSC_MCMGCTRL_ID_BITS   0x0FF00000 /* Internal memory block Id */
729 #define     SYSC_MCMGCTRL_ID_S      20
730 #define         SYSC_MCMGID_NODEV       0xFF /* No Device Selected */
731 #define         SYSC_MCMGID_DSPRAM0A    0x04 /* DSP RAM D0 block A access */
732 #define         SYSC_MCMGID_DSPRAM0B    0x05 /* DSP RAM D0 block B access */
733 #define         SYSC_MCMGID_DSPRAM1A    0x06 /* DSP RAM D1 block A access */
734 #define         SYSC_MCMGID_DSPRAM1B    0x07 /* DSP RAM D1 block B access */
735 #define         SYSC_MCMGID_DCACHEL     0x08 /* DCACHE lines (64-bytes/line) */
736 #ifdef METAC_2_1
737 #define         SYSC_MCMGID_DCACHETLB   0x09 /* DCACHE TLB ( Read Only )     */
738 #endif /* METAC_2_1 */
739 #define         SYSC_MCMGID_DCACHET     0x0A /* DCACHE tags (32-bits/line)   */
740 #define         SYSC_MCMGID_DCACHELRU   0x0B /* DCACHE LRU (8-bits/line)     */
741 #define         SYSC_MCMGID_ICACHEL     0x0C /* ICACHE lines (64-bytes/line  */
742 #ifdef METAC_2_1
743 #define         SYSC_MCMGID_ICACHETLB   0x0D /* ICACHE TLB (Read Only )     */
744 #endif /* METAC_2_1 */
745 #define         SYSC_MCMGID_ICACHET     0x0E /* ICACHE Tags (32-bits/line)   */
746 #define         SYSC_MCMGID_ICACHELRU   0x0F /* ICACHE LRU (8-bits/line )    */
747 #define         SYSC_MCMGID_COREIRAM0   0x10 /* Core code mem id 0 */
748 #define         SYSC_MCMGID_COREIRAMn   0x17
749 #define         SYSC_MCMGID_COREDRAM0   0x18 /* Core data mem id 0 */
750 #define         SYSC_MCMGID_COREDRAMn   0x1F
751 #ifdef METAC_2_1
752 #define         SYSC_MCMGID_DCACHEST    0x20 /* DCACHE ST ( Read Only )      */
753 #define         SYSC_MCMGID_ICACHEST    0x21 /* ICACHE ST ( Read Only )      */
754 #define         SYSC_MCMGID_DCACHETLBLRU 0x22 /* DCACHE TLB LRU ( Read Only )*/
755 #define         SYSC_MCMGID_ICACHETLBLRU 0x23 /* ICACHE TLB LRU( Read Only ) */
756 #define         SYSC_MCMGID_DCACHESTLRU 0x24 /* DCACHE ST LRU ( Read Only )  */
757 #define         SYSC_MCMGID_ICACHESTLRU 0x25 /* ICACHE ST LRU ( Read Only )  */
758 #define         SYSC_MCMGID_DEBUGTLB    0x26 /* DEBUG TLB ( Read Only )      */
759 #define         SYSC_MCMGID_DEBUGST     0x27 /* DEBUG ST ( Read Only )       */
760 #define         SYSC_MCMGID_L2CACHEL    0x30 /* L2 Cache Lines (64-bytes/line) */
761 #define         SYSC_MCMGID_L2CACHET    0x31 /* L2 Cache Tags (32-bits/line) */
762 #define         SYSC_MCMGID_COPROX0     0x70 /* Coprocessor port id 0 */
763 #define         SYSC_MCMGID_COPROXn     0x77
764 #endif /* METAC_2_1 */
765 #define     SYSC_MCMGCTRL_TR31_BIT  0x80000000 /* Trigger 31 on completion */
766 #define SYSC_MCMSTATUS 0x04830318   /* Status read only */
767 #define     SYSC_MCMSTATUS_IDLE_BIT 0x00000001
768 
769 /* META System Events */
770 #define SYSC_SYS_EVENT            0x04830400
771 #define     SYSC_SYSEVT_ATOMIC_BIT      0x00000001
772 #define     SYSC_SYSEVT_CACHEX_BIT      0x00000002
773 #define SYSC_ATOMIC_LOCK          0x04830408
774 #define     SYSC_ATOMIC_STATE_TX_BITS 0x0000000F
775 #define     SYSC_ATOMIC_STATE_TX_S    0
776 #ifdef METAC_1_2
777 #define     SYSC_ATOMIC_STATE_DX_BITS 0x000000F0
778 #define     SYSC_ATOMIC_STATE_DX_S    4
779 #else /* METAC_1_2 */
780 #define     SYSC_ATOMIC_SOURCE_BIT    0x00000010
781 #endif /* !METAC_1_2 */
782 
783 
784 #ifdef METAC_2_1
785 
786 /* These definitions replace the EXPAND_TIMER_DIV register defines which are to
787  * be deprecated.
788  */
789 #define SYSC_TIMER_DIV            0x04830140
790 #define     SYSC_TIMDIV_BITS      0x000000FF
791 #define     SYSC_TIMDIV_S         0
792 
793 /* META Enhanced by-pass control for local and global region */
794 #define MMCU_LOCAL_EBCTRL   0x04830600
795 #define MMCU_GLOBAL_EBCTRL  0x04830608
796 #define     MMCU_EBCTRL_SINGLE_BIT      0x00000020 /* TLB Uncached */
797 /*
798  * These fields in the above registers provide MMCU_ENTRY_* values
799  *   for each direct mapped region to enable optimisation of these areas.
800  */
801 #define     MMCU_EBCTRL_DCCTRL_BITS     0x000000C0 /* Get DC Ctrl */
802 #define     MMCU_EBCTRL_DCCTRL_S        0
803 #define     MMCU_EBCTRL_ICCTRL_BITS     0x0000C000 /* Get DC Ctrl */
804 #define     MMCU_EBCTRL_ICCTRL_S        8
805 
806 /* META Cached Core Mode Registers */
807 #define MMCU_T0CCM_ICCTRL   0x04830680     /* Core cached code control */
808 #define     MMCU_TnCCM_xxCTRL_STRIDE    8
809 #define     MMCU_TnCCM_xxCTRL_STRIDE_S  3
810 #define MMCU_T1CCM_ICCTRL   0x04830688
811 #define MMCU_T2CCM_ICCTRL   0x04830690
812 #define MMCU_T3CCM_ICCTRL   0x04830698
813 #define MMCU_T0CCM_DCCTRL   0x048306C0     /* Core cached data control */
814 #define MMCU_T1CCM_DCCTRL   0x048306C8
815 #define MMCU_T2CCM_DCCTRL   0x048306D0
816 #define MMCU_T3CCM_DCCTRL   0x048306D8
817 #define     MMCU_TnCCM_ENABLE_BIT       0x00000001
818 #define     MMCU_TnCCM_WIN3_BIT         0x00000002
819 #define     MMCU_TnCCM_DCWRITE_BIT      0x00000004  /* In DCCTRL only */
820 #define     MMCU_TnCCM_REGSZ_BITS       0x00000F00
821 #define     MMCU_TnCCM_REGSZ_S          8
822 #define         MMCU_TnCCM_REGSZ0_POWER      12     /* RegSz 0 -> 4K */
823 #define         MMCU_TnCCM_REGSZ_MAXBYTES    0x00080000  /* 512K max */
824 #define     MMCU_TnCCM_ADDR_BITS        0xFFFFF000
825 #define     MMCU_TnCCM_ADDR_S           12
826 
827 #endif /* METAC_2_1 */
828 
829 /*
830  * Hardware performance counter registers
831  * --------------------------------------
832  */
833 #ifdef METAC_2_1
834 /* Two Performance Counter Internal Core Events Control registers */
835 #define PERF_ICORE0   0x0480FFD0
836 #define PERF_ICORE1   0x0480FFD8
837 #define     PERFI_CTRL_BITS    0x0000000F
838 #define     PERFI_CTRL_S       0
839 #define         PERFI_CAH_DMISS    0x0  /* Dcache Misses in cache (TLB Hit) */
840 #define         PERFI_CAH_IMISS    0x1  /* Icache Misses in cache (TLB Hit) */
841 #define         PERFI_TLB_DMISS    0x2  /* Dcache Misses in per-thread TLB */
842 #define         PERFI_TLB_IMISS    0x3  /* Icache Misses in per-thread TLB */
843 #define         PERFI_TLB_DWRHITS  0x4  /* DC Write-Hits in per-thread TLB */
844 #define         PERFI_TLB_DWRMISS  0x5  /* DC Write-Miss in per-thread TLB */
845 #define         PERFI_CAH_DLFETCH  0x8  /* DC Read cache line fetch */
846 #define         PERFI_CAH_ILFETCH  0x9  /* DC Read cache line fetch */
847 #define         PERFI_CAH_DWFETCH  0xA  /* DC Read cache word fetch */
848 #define         PERFI_CAH_IWFETCH  0xB  /* DC Read cache word fetch */
849 #endif /* METAC_2_1 */
850 
851 /* Two memory-mapped hardware performance counter registers */
852 #define PERF_COUNT0 0x0480FFE0
853 #define PERF_COUNT1 0x0480FFE8
854 
855 /* Fields in PERF_COUNTn registers */
856 #define PERF_COUNT_BITS  0x00ffffff /* Event count value */
857 
858 #define PERF_THREAD_BITS 0x0f000000 /* Thread mask selects threads */
859 #define PERF_THREAD_S    24
860 
861 #define PERF_CTRL_BITS   0xf0000000 /* Event filter control */
862 #define PERF_CTRL_S      28
863 
864 #define    PERFCTRL_SUPER   0  /* Superthread cycles */
865 #define    PERFCTRL_REWIND  1  /* Rewinds due to Dcache Misses */
866 #ifdef METAC_2_1
867 #define    PERFCTRL_SUPREW  2  /* Rewinds of superthreaded cycles (no mask) */
868 
869 #define    PERFCTRL_CYCLES  3  /* Counts all cycles (no mask) */
870 
871 #define    PERFCTRL_PREDBC  4  /* Conditional branch predictions */
872 #define    PERFCTRL_MISPBC  5  /* Conditional branch mispredictions */
873 #define    PERFCTRL_PREDRT  6  /* Return predictions */
874 #define    PERFCTRL_MISPRT  7  /* Return mispredictions */
875 #endif /* METAC_2_1 */
876 
877 #define    PERFCTRL_DHITS   8  /* Dcache Hits */
878 #define    PERFCTRL_IHITS   9  /* Icache Hits */
879 #define    PERFCTRL_IMISS   10 /* Icache Misses in cache or TLB */
880 #ifdef METAC_2_1
881 #define    PERFCTRL_DCSTALL 11 /* Dcache+TLB o/p delayed (per-thread) */
882 #define    PERFCTRL_ICSTALL 12 /* Icache+TLB o/p delayed (per-thread) */
883 
884 #define    PERFCTRL_INT     13 /* Internal core detailed events (see next) */
885 #define    PERFCTRL_EXT     15 /* External source in core periphery */
886 #endif /* METAC_2_1 */
887 
888 #ifdef METAC_2_1
889 /* These definitions replace the EXPAND_PERFCHANx register defines which are to
890  * be deprecated.
891  */
892 #define PERF_CHAN0 0x04830150
893 #define PERF_CHAN1 0x04830158
894 #define     PERF_CHAN_BITS    0x0000000F
895 #define     PERF_CHAN_S       0
896 #define         PERFCHAN_WRC_WRBURST   0x0   /* Write combiner write burst */
897 #define         PERFCHAN_WRC_WRITE     0x1   /* Write combiner write       */
898 #define         PERFCHAN_WRC_RDBURST   0x2   /* Write combiner read burst  */
899 #define         PERFCHAN_WRC_READ      0x3   /* Write combiner read        */
900 #define         PERFCHAN_PREARB_DELAY  0x4   /* Pre-arbiter delay cycle    */
901 					     /* Cross-bar hold-off cycle:  */
902 #define         PERFCHAN_XBAR_HOLDWRAP 0x5   /*    wrapper register        */
903 #define         PERFCHAN_XBAR_HOLDSBUS 0x6   /*    system bus (ATP only)   */
904 #define         PERFCHAN_XBAR_HOLDCREG 0x9   /*    core registers          */
905 #define         PERFCHAN_L2C_MISS      0x6   /* L2 Cache miss              */
906 #define         PERFCHAN_L2C_HIT       0x7   /* L2 Cache hit               */
907 #define         PERFCHAN_L2C_WRITEBACK 0x8   /* L2 Cache writeback         */
908 					     /* Admission delay cycle:     */
909 #define         PERFCHAN_INPUT_CREG    0xB   /*    core registers          */
910 #define         PERFCHAN_INPUT_INTR    0xC   /*    internal ram            */
911 #define         PERFCHAN_INPUT_WRC     0xD   /*    write combiners(memory) */
912 
913 /* Should following be removed as not in TRM anywhere? */
914 #define         PERFCHAN_XBAR_HOLDINTR 0x8   /*    internal ram            */
915 #define         PERFCHAN_INPUT_SBUS    0xA   /*    register port           */
916 /* End of remove section. */
917 
918 #define         PERFCHAN_MAINARB_DELAY 0xF   /* Main arbiter delay cycle   */
919 
920 #endif /* METAC_2_1 */
921 
922 #ifdef METAC_2_1
923 /*
924  * Write combiner registers
925  * ------------------------
926  *
927  * These replace the EXPAND_T0WRCOMBINE register defines, which will be
928  * deprecated.
929  */
930 #define WRCOMB_CONFIG0             0x04830100
931 #define     WRCOMB_LFFEn_BIT           0x00004000  /* Enable auto line full flush */
932 #define     WRCOMB_ENABLE_BIT          0x00002000  /* Enable write combiner */
933 #define     WRCOMB_TIMEOUT_ENABLE_BIT  0x00001000  /* Timeout flush enable */
934 #define     WRCOMB_TIMEOUT_COUNT_BITS  0x000003FF
935 #define     WRCOMB_TIMEOUT_COUNT_S     0
936 #define WRCOMB_CONFIG4             0x04830180
937 #define     WRCOMB_PARTALLOC_BITS      0x000000C0
938 #define     WRCOMB_PARTALLOC_S         64
939 #define     WRCOMB_PARTSIZE_BITS       0x00000030
940 #define     WRCOMB_PARTSIZE_S          4
941 #define     WRCOMB_PARTOFFSET_BITS     0x0000000F
942 #define     WRCOMB_PARTOFFSET_S        0
943 #define WRCOMB_CONFIG_STRIDE       8
944 #endif /* METAC_2_1 */
945 
946 #ifdef METAC_2_1
947 /*
948  * Thread arbiter registers
949  * ------------------------
950  *
951  * These replace the EXPAND_T0ARBITER register defines, which will be
952  * deprecated.
953  */
954 #define ARBITER_ARBCONFIG0       0x04830120
955 #define     ARBCFG_BPRIORITY_BIT     0x02000000
956 #define     ARBCFG_IPRIORITY_BIT     0x01000000
957 #define     ARBCFG_PAGE_BITS         0x00FF0000
958 #define     ARBCFG_PAGE_S            16
959 #define     ARBCFG_BBASE_BITS        0x0000FF00
960 #define     ARGCFG_BBASE_S           8
961 #define     ARBCFG_IBASE_BITS        0x000000FF
962 #define     ARBCFG_IBASE_S           0
963 #define ARBITER_TTECONFIG0       0x04820160
964 #define     ARBTTE_IUPPER_BITS       0xFF000000
965 #define     ARBTTE_IUPPER_S          24
966 #define     ARBTTE_ILOWER_BITS       0x00FF0000
967 #define     ARBTTE_ILOWER_S          16
968 #define     ARBTTE_BUPPER_BITS       0x0000FF00
969 #define     ARBTTE_BUPPER_S          8
970 #define     ARBTTE_BLOWER_BITS       0x000000FF
971 #define     ARBTTE_BLOWER_S          0
972 #define ARBITER_STRIDE           8
973 #endif /* METAC_2_1 */
974 
975 /*
976  * Expansion area registers
977  * --------------------------------------
978  */
979 
980 /* These defines are to be deprecated. See above instead. */
981 #define EXPAND_T0WRCOMBINE         0x03000000
982 #ifdef METAC_2_1
983 #define     EXPWRC_LFFEn_BIT           0x00004000  /* Enable auto line full flush */
984 #endif /* METAC_2_1 */
985 #define     EXPWRC_ENABLE_BIT          0x00002000  /* Enable write combiner */
986 #define     EXPWRC_TIMEOUT_ENABLE_BIT  0x00001000  /* Timeout flush enable */
987 #define     EXPWRC_TIMEOUT_COUNT_BITS  0x000003FF
988 #define     EXPWRC_TIMEOUT_COUNT_S     0
989 #define EXPAND_TnWRCOMBINE_STRIDE  0x00000008
990 
991 /* These defines are to be deprecated. See above instead. */
992 #define EXPAND_T0ARBITER         0x03000020
993 #define     EXPARB_BPRIORITY_BIT 0x02000000
994 #define     EXPARB_IPRIORITY_BIT 0x01000000
995 #define     EXPARB_PAGE_BITS     0x00FF0000
996 #define     EXPARB_PAGE_S        16
997 #define     EXPARB_BBASE_BITS    0x0000FF00
998 #define     EXPARB_BBASE_S       8
999 #define     EXPARB_IBASE_BITS    0x000000FF
1000 #define     EXPARB_IBASE_S       0
1001 #define EXPAND_TnARBITER_STRIDE  0x00000008
1002 
1003 /* These definitions are to be deprecated. See above instead. */
1004 #define EXPAND_TIMER_DIV   0x03000040
1005 #define     EXPTIM_DIV_BITS      0x000000FF
1006 #define     EXPTIM_DIV_S         0
1007 
1008 /* These definitions are to be deprecated. See above instead. */
1009 #define EXPAND_PERFCHAN0   0x03000050
1010 #define EXPAND_PERFCHAN1   0x03000058
1011 #define     EXPPERF_CTRL_BITS    0x0000000F
1012 #define     EXPPERF_CTRL_S       0
1013 #define         EXPPERF_WRC_WRBURST   0x0   /* Write combiner write burst */
1014 #define         EXPPERF_WRC_WRITE     0x1   /* Write combiner write       */
1015 #define         EXPPERF_WRC_RDBURST   0x2   /* Write combiner read burst  */
1016 #define         EXPPERF_WRC_READ      0x3   /* Write combiner read        */
1017 #define         EXPPERF_PREARB_DELAY  0x4   /* Pre-arbiter delay cycle    */
1018 					    /* Cross-bar hold-off cycle:  */
1019 #define         EXPPERF_XBAR_HOLDWRAP 0x5   /*    wrapper register        */
1020 #define         EXPPERF_XBAR_HOLDSBUS 0x6   /*    system bus              */
1021 #ifdef METAC_1_2
1022 #define         EXPPERF_XBAR_HOLDLBUS 0x7   /*    local bus               */
1023 #else /* METAC_1_2 */
1024 #define         EXPPERF_XBAR_HOLDINTR 0x8   /*    internal ram            */
1025 #define         EXPPERF_XBAR_HOLDCREG 0x9   /*    core registers          */
1026 					    /* Admission delay cycle:     */
1027 #define         EXPPERF_INPUT_SBUS    0xA   /*    register port           */
1028 #define         EXPPERF_INPUT_CREG    0xB   /*    core registers          */
1029 #define         EXPPERF_INPUT_INTR    0xC   /*    internal ram            */
1030 #define         EXPPERF_INPUT_WRC     0xD   /*    write combiners(memory) */
1031 #endif /* !METAC_1_2 */
1032 #define         EXPPERF_MAINARB_DELAY 0xF   /* Main arbiter delay cycle   */
1033 
1034 /*
1035  * Debug port registers
1036  * --------------------------------------
1037  */
1038 
1039 /* Data Exchange Register */
1040 #define DBGPORT_MDBGDATAX                    0x0
1041 
1042 /* Data Transfer register */
1043 #define DBGPORT_MDBGDATAT                    0x4
1044 
1045 /* Control Register 0 */
1046 #define DBGPORT_MDBGCTRL0                    0x8
1047 #define     DBGPORT_MDBGCTRL0_ADDR_BITS      0xFFFFFFFC
1048 #define     DBGPORT_MDBGCTRL0_ADDR_S         2
1049 #define     DBGPORT_MDBGCTRL0_AUTOINCR_BIT   0x00000002
1050 #define     DBGPORT_MDBGCTRL0_RD_BIT         0x00000001
1051 
1052 /* Control Register 1 */
1053 #define DBGPORT_MDBGCTRL1                    0xC
1054 #ifdef METAC_2_1
1055 #define    DBGPORT_MDBGCTRL1_DEFERRTHREAD_BITS      0xC0000000
1056 #define    DBGPORT_MDBGCTRL1_DEFERRTHREAD_S         30
1057 #endif /* METAC_2_1 */
1058 #define     DBGPORT_MDBGCTRL1_LOCK2_INTERLOCK_BIT   0x20000000
1059 #define     DBGPORT_MDBGCTRL1_ATOMIC_INTERLOCK_BIT  0x10000000
1060 #define     DBGPORT_MDBGCTRL1_TRIGSTATUS_BIT        0x08000000
1061 #define     DBGPORT_MDBGCTRL1_GBLPORT_IDLE_BIT      0x04000000
1062 #define     DBGPORT_MDBGCTRL1_COREMEM_IDLE_BIT      0x02000000
1063 #define     DBGPORT_MDBGCTRL1_READY_BIT             0x01000000
1064 #ifdef METAC_2_1
1065 #define     DBGPORT_MDBGCTRL1_DEFERRID_BITS         0x00E00000
1066 #define     DBGPORT_MDBGCTRL1_DEFERRID_S            21
1067 #define     DBGPORT_MDBGCTRL1_DEFERR_BIT            0x00100000
1068 #endif /* METAC_2_1 */
1069 #define     DBGPORT_MDBGCTRL1_WR_ACTIVE_BIT         0x00040000
1070 #define     DBGPORT_MDBGCTRL1_COND_LOCK2_BIT        0x00020000
1071 #define     DBGPORT_MDBGCTRL1_LOCK2_BIT             0x00010000
1072 #define     DBGPORT_MDBGCTRL1_DIAGNOSE_BIT          0x00008000
1073 #define     DBGPORT_MDBGCTRL1_FORCEDIAG_BIT         0x00004000
1074 #define     DBGPORT_MDBGCTRL1_MEMFAULT_BITS         0x00003000
1075 #define     DBGPORT_MDBGCTRL1_MEMFAULT_S            12
1076 #define     DBGPORT_MDBGCTRL1_TRIGGER_BIT           0x00000100
1077 #ifdef METAC_2_1
1078 #define     DBGPORT_MDBGCTRL1_INTSPECIAL_BIT        0x00000080
1079 #define     DBGPORT_MDBGCTRL1_INTRUSIVE_BIT         0x00000040
1080 #endif /* METAC_2_1 */
1081 #define     DBGPORT_MDBGCTRL1_THREAD_BITS           0x00000030 /* Thread mask selects threads */
1082 #define     DBGPORT_MDBGCTRL1_THREAD_S              4
1083 #define     DBGPORT_MDBGCTRL1_TRANS_SIZE_BITS       0x0000000C
1084 #define     DBGPORT_MDBGCTRL1_TRANS_SIZE_S          2
1085 #define         DBGPORT_MDBGCTRL1_TRANS_SIZE_32_BIT 0x00000000
1086 #define         DBGPORT_MDBGCTRL1_TRANS_SIZE_16_BIT 0x00000004
1087 #define         DBGPORT_MDBGCTRL1_TRANS_SIZE_8_BIT  0x00000008
1088 #define     DBGPORT_MDBGCTRL1_BYTE_ROUND_BITS       0x00000003
1089 #define     DBGPORT_MDBGCTRL1_BYTE_ROUND_S          0
1090 #define         DBGPORT_MDBGCTRL1_BYTE_ROUND_8_BIT  0x00000001
1091 #define         DBGPORT_MDBGCTRL1_BYTE_ROUND_16_BIT 0x00000002
1092 
1093 
1094 /* L2 Cache registers */
1095 #define SYSC_L2C_INIT              0x048300C0
1096 #define SYSC_L2C_INIT_INIT                  1
1097 #define SYSC_L2C_INIT_IN_PROGRESS           0
1098 #define SYSC_L2C_INIT_COMPLETE              1
1099 
1100 #define SYSC_L2C_ENABLE            0x048300D0
1101 #define SYSC_L2C_ENABLE_ENABLE_BIT     0x00000001
1102 #define SYSC_L2C_ENABLE_PFENABLE_BIT   0x00000002
1103 
1104 #define SYSC_L2C_PURGE             0x048300C8
1105 #define SYSC_L2C_PURGE_PURGE                1
1106 #define SYSC_L2C_PURGE_IN_PROGRESS          0
1107 #define SYSC_L2C_PURGE_COMPLETE             1
1108 
1109 #endif /* _ASM_METAG_MEM_H_ */
1110