OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [freertos-6.1.1/] [Demo/] [OpenRISC_SIM_GCC/] [arch/] [spr_defs.h] - Blame information for rev 800

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 799 filepang
/* ipc.h.  Microkernel IPC header for Or1ksim
2
 
3
   Copyright (C) 2000 Damjan Lampret
4
   Copyright (C) 2008, 2010 Embecosm Limited
5
 
6
   Contributor Damjan Lampret <lampret@opencores.org>
7
   Contributor Jeremy Bennett <jeremy.bennett@embecosm.com>
8 584 jeremybenn
 
9 799 filepang
   This file is part of OpenRISC 1000 Architectural Simulator.
10 584 jeremybenn
 
11 799 filepang
   This program is free software; you can redistribute it and/or modify it
12
   under the terms of the GNU General Public License as published by the Free
13
   Software Foundation; either version 3 of the License, or (at your option)
14
   any later version.
15 584 jeremybenn
 
16 799 filepang
   This program is distributed in the hope that it will be useful, but WITHOUT
17
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
18
   FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
19
   more details.
20 584 jeremybenn
 
21 799 filepang
   You should have received a copy of the GNU General Public License along
22
   with this program.  If not, see <http:  www.gnu.org/licenses/>.  */
23 584 jeremybenn
 
24 799 filepang
/* ----------------------------------------------------------------------------
25
   This code is commented throughout for use with Doxygen.
26
   --------------------------------------------------------------------------*/
27 584 jeremybenn
 
28 799 filepang
/* This file is part of test microkernel for OpenRISC 1000. */
29
/* spr-defs.h -- Defines OR1K architecture specific special-purpose registers
30 584 jeremybenn
 
31 799 filepang
   Copyright (C) 1999 Damjan Lampret, lampret@opencores.org
32
   Copyright (C) 2008 Embecosm Limited
33
 
34
   Contributor Jeremy Bennett <jeremy.bennett@embecosm.com>
35
 
36
   This file is part of OpenRISC 1000 Architectural Simulator.
37
 
38
   This program is free software; you can redistribute it and/or modify it
39
   under the terms of the GNU General Public License as published by the Free
40
   Software Foundation; either version 3 of the License, or (at your option)
41
   any later version.
42
 
43
   This program is distributed in the hope that it will be useful, but WITHOUT
44
   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
45
   FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
46
   more details.
47
 
48
   You should have received a copy of the GNU General Public License along
49
   with this program.  If not, see <http://www.gnu.org/licenses/>. */
50
 
51
/* This program is commented throughout in a fashion suitable for processing
52
   with Doxygen. */
53
 
54
 
55
#ifndef SPR_DEFS__H
56
#define SPR_DEFS__H
57
 
58
/* Definition of special-purpose registers (SPRs). */
59
 
60 584 jeremybenn
#define MAX_GRPS (32)
61
#define MAX_SPRS_PER_GRP_BITS (11)
62
#define MAX_SPRS_PER_GRP (1 << MAX_SPRS_PER_GRP_BITS)
63
#define MAX_SPRS (0x10000)
64
 
65
/* Base addresses for the groups */
66
#define SPRGROUP_SYS    (0<< MAX_SPRS_PER_GRP_BITS)
67
#define SPRGROUP_DMMU   (1<< MAX_SPRS_PER_GRP_BITS)
68
#define SPRGROUP_IMMU   (2<< MAX_SPRS_PER_GRP_BITS)
69 799 filepang
#define SPRGROUP_DC     (3<< MAX_SPRS_PER_GRP_BITS)
70
#define SPRGROUP_IC     (4<< MAX_SPRS_PER_GRP_BITS)
71 584 jeremybenn
#define SPRGROUP_MAC    (5<< MAX_SPRS_PER_GRP_BITS)
72 799 filepang
#define SPRGROUP_D      (6<< MAX_SPRS_PER_GRP_BITS)
73
#define SPRGROUP_PC     (7<< MAX_SPRS_PER_GRP_BITS)
74
#define SPRGROUP_PM     (8<< MAX_SPRS_PER_GRP_BITS)
75 584 jeremybenn
#define SPRGROUP_PIC    (9<< MAX_SPRS_PER_GRP_BITS)
76 799 filepang
#define SPRGROUP_TT     (10<< MAX_SPRS_PER_GRP_BITS)
77
#define SPRGROUP_FP     (11<< MAX_SPRS_PER_GRP_BITS)
78 584 jeremybenn
 
79
/* System control and status group */
80 799 filepang
#define SPR_VR          (SPRGROUP_SYS + 0)
81
#define SPR_UPR         (SPRGROUP_SYS + 1)
82
#define SPR_CPUCFGR     (SPRGROUP_SYS + 2)
83 584 jeremybenn
#define SPR_DMMUCFGR    (SPRGROUP_SYS + 3)
84
#define SPR_IMMUCFGR    (SPRGROUP_SYS + 4)
85 799 filepang
#define SPR_DCCFGR      (SPRGROUP_SYS + 5)
86
#define SPR_ICCFGR      (SPRGROUP_SYS + 6)
87
#define SPR_DCFGR       (SPRGROUP_SYS + 7)
88
#define SPR_PCCFGR      (SPRGROUP_SYS + 8)
89 584 jeremybenn
#define SPR_NPC         (SPRGROUP_SYS + 16)  /* CZ 21/06/01 */
90 799 filepang
#define SPR_SR          (SPRGROUP_SYS + 17)  /* CZ 21/06/01 */
91 584 jeremybenn
#define SPR_PPC         (SPRGROUP_SYS + 18)  /* CZ 21/06/01 */
92 799 filepang
#define SPR_FPCSR       (SPRGROUP_SYS + 20)  /* CZ 21/06/01 */
93 584 jeremybenn
#define SPR_EPCR_BASE   (SPRGROUP_SYS + 32)  /* CZ 21/06/01 */
94
#define SPR_EPCR_LAST   (SPRGROUP_SYS + 47)  /* CZ 21/06/01 */
95
#define SPR_EEAR_BASE   (SPRGROUP_SYS + 48)
96
#define SPR_EEAR_LAST   (SPRGROUP_SYS + 63)
97
#define SPR_ESR_BASE    (SPRGROUP_SYS + 64)
98
#define SPR_ESR_LAST    (SPRGROUP_SYS + 79)
99 799 filepang
#define SPR_GPR_BASE    (SPRGROUP_SYS + 1024)
100 584 jeremybenn
 
101
/* Data MMU group */
102 799 filepang
#define SPR_DMMUCR      (SPRGROUP_DMMU + 0)
103
#define SPR_DTLBMR_BASE(WAY)    (SPRGROUP_DMMU + 0x200 + (WAY) * 0x100)
104
#define SPR_DTLBMR_LAST(WAY)    (SPRGROUP_DMMU + 0x27f + (WAY) * 0x100)
105
#define SPR_DTLBTR_BASE(WAY)    (SPRGROUP_DMMU + 0x280 + (WAY) * 0x100)
106
#define SPR_DTLBTR_LAST(WAY)    (SPRGROUP_DMMU + 0x2ff + (WAY) * 0x100)
107
 
108 584 jeremybenn
/* Instruction MMU group */
109 799 filepang
#define SPR_IMMUCR      (SPRGROUP_IMMU + 0)
110
#define SPR_ITLBMR_BASE(WAY)    (SPRGROUP_IMMU + 0x200 + (WAY) * 0x100)
111
#define SPR_ITLBMR_LAST(WAY)    (SPRGROUP_IMMU + 0x27f + (WAY) * 0x100)
112
#define SPR_ITLBTR_BASE(WAY)    (SPRGROUP_IMMU + 0x280 + (WAY) * 0x100)
113
#define SPR_ITLBTR_LAST(WAY)    (SPRGROUP_IMMU + 0x2ff + (WAY) * 0x100)
114 584 jeremybenn
 
115
/* Data cache group */
116 799 filepang
#define SPR_DCCR        (SPRGROUP_DC + 0)
117
#define SPR_DCBPR       (SPRGROUP_DC + 1)
118
#define SPR_DCBFR       (SPRGROUP_DC + 2)
119
#define SPR_DCBIR       (SPRGROUP_DC + 3)
120
#define SPR_DCBWR       (SPRGROUP_DC + 4)
121
#define SPR_DCBLR       (SPRGROUP_DC + 5)
122 584 jeremybenn
#define SPR_DCR_BASE(WAY)       (SPRGROUP_DC + 0x200 + (WAY) * 0x200)
123
#define SPR_DCR_LAST(WAY)       (SPRGROUP_DC + 0x3ff + (WAY) * 0x200)
124
 
125
/* Instruction cache group */
126 799 filepang
#define SPR_ICCR        (SPRGROUP_IC + 0)
127
#define SPR_ICBPR       (SPRGROUP_IC + 1)
128
#define SPR_ICBIR       (SPRGROUP_IC + 2)
129
#define SPR_ICBLR       (SPRGROUP_IC + 3)
130 584 jeremybenn
#define SPR_ICR_BASE(WAY)       (SPRGROUP_IC + 0x200 + (WAY) * 0x200)
131
#define SPR_ICR_LAST(WAY)       (SPRGROUP_IC + 0x3ff + (WAY) * 0x200)
132
 
133
/* MAC group */
134
#define SPR_MACLO       (SPRGROUP_MAC + 1)
135
#define SPR_MACHI       (SPRGROUP_MAC + 2)
136
 
137
/* Debug group */
138
#define SPR_DVR(N)      (SPRGROUP_D + (N))
139
#define SPR_DCR(N)      (SPRGROUP_D + 8 + (N))
140
#define SPR_DMR1        (SPRGROUP_D + 16)
141
#define SPR_DMR2        (SPRGROUP_D + 17)
142
#define SPR_DWCR0       (SPRGROUP_D + 18)
143
#define SPR_DWCR1       (SPRGROUP_D + 19)
144
#define SPR_DSR         (SPRGROUP_D + 20)
145
#define SPR_DRR         (SPRGROUP_D + 21)
146
 
147
/* Performance counters group */
148
#define SPR_PCCR(N)     (SPRGROUP_PC + (N))
149
#define SPR_PCMR(N)     (SPRGROUP_PC + 8 + (N))
150
 
151
/* Power management group */
152
#define SPR_PMR (SPRGROUP_PM + 0)
153
 
154
/* PIC group */
155
#define SPR_PICMR (SPRGROUP_PIC + 0)
156
#define SPR_PICPR (SPRGROUP_PIC + 1)
157
#define SPR_PICSR (SPRGROUP_PIC + 2)
158
 
159
/* Tick Timer group */
160
#define SPR_TTMR (SPRGROUP_TT + 0)
161
#define SPR_TTCR (SPRGROUP_TT + 1)
162
 
163
/*
164
 * Bit definitions for the Version Register
165
 *
166
 */
167 799 filepang
#define SPR_VR_VER      0xff000000  /* Processor version */
168
#define SPR_VR_CFG      0x00ff0000  /* Processor configuration */
169
#define SPR_VR_RES      0x00ff0000  /* Reserved */
170 584 jeremybenn
#define SPR_VR_REV      0x0000003f  /* Processor revision */
171
 
172 799 filepang
#define SPR_VR_VER_OFF  24
173
#define SPR_VR_CFG_OFF  16
174
#define SPR_VR_REV_OFF  0
175
 
176 584 jeremybenn
/*
177
 * Bit definitions for the Unit Present Register
178
 *
179
 */
180 799 filepang
#define SPR_UPR_UP         0x00000001  /* UPR present */
181
#define SPR_UPR_DCP        0x00000002  /* Data cache present */
182
#define SPR_UPR_ICP        0x00000004  /* Instruction cache present */
183
#define SPR_UPR_DMP        0x00000008  /* Data MMU present */
184
#define SPR_UPR_IMP        0x00000010  /* Instruction MMU present */
185
#define SPR_UPR_MP         0x00000020  /* MAC present */
186
#define SPR_UPR_DUP        0x00000040  /* Debug unit present */
187
#define SPR_UPR_PCUP       0x00000080  /* Performance counters unit present */
188
#define SPR_UPR_PMP        0x00000100  /* Power management present */
189
#define SPR_UPR_PICP       0x00000200  /* PIC present */
190
#define SPR_UPR_TTP        0x00000400  /* Tick timer present */
191
#define SPR_UPR_RES        0x00fe0000  /* Reserved */
192
#define SPR_UPR_CUP        0xff000000  /* Context units present */
193 584 jeremybenn
 
194
/*
195 799 filepang
 * JPB: Bit definitions for the CPU configuration register
196
 *
197
 */
198
#define SPR_CPUCFGR_NSGF   0x0000000f  /* Number of shadow GPR files */
199
#define SPR_CPUCFGR_CGF    0x00000010  /* Custom GPR file */
200
#define SPR_CPUCFGR_OB32S  0x00000020  /* ORBIS32 supported */
201
#define SPR_CPUCFGR_OB64S  0x00000040  /* ORBIS64 supported */
202
#define SPR_CPUCFGR_OF32S  0x00000080  /* ORFPX32 supported */
203
#define SPR_CPUCFGR_OF64S  0x00000100  /* ORFPX64 supported */
204
#define SPR_CPUCFGR_OV64S  0x00000200  /* ORVDX64 supported */
205
#define SPR_CPUCFGR_RES    0xfffffc00  /* Reserved */
206
 
207
/*
208
 * JPB: Bit definitions for the Debug configuration register and other
209
 * constants.
210
 *
211
 */
212
 
213
#define SPR_DCFGR_NDP      0x00000007  /* Number of matchpoints mask */
214
#define SPR_DCFGR_NDP1     0x00000000  /* One matchpoint supported */
215
#define SPR_DCFGR_NDP2     0x00000001  /* Two matchpoints supported */
216
#define SPR_DCFGR_NDP3     0x00000002  /* Three matchpoints supported */
217
#define SPR_DCFGR_NDP4     0x00000003  /* Four matchpoints supported */
218
#define SPR_DCFGR_NDP5     0x00000004  /* Five matchpoints supported */
219
#define SPR_DCFGR_NDP6     0x00000005  /* Six matchpoints supported */
220
#define SPR_DCFGR_NDP7     0x00000006  /* Seven matchpoints supported */
221
#define SPR_DCFGR_NDP8     0x00000007  /* Eight matchpoints supported */
222
#define SPR_DCFGR_WPCI     0x00000008  /* Watchpoint counters implemented */
223
 
224
#define MATCHPOINTS_TO_NDP(n) (1 == n ? SPR_DCFGR_NDP1 : \
225
                               2 == n ? SPR_DCFGR_NDP2 : \
226
                               3 == n ? SPR_DCFGR_NDP3 : \
227
                               4 == n ? SPR_DCFGR_NDP4 : \
228
                               5 == n ? SPR_DCFGR_NDP5 : \
229
                               6 == n ? SPR_DCFGR_NDP6 : \
230
                               7 == n ? SPR_DCFGR_NDP7 : SPR_DCFGR_NDP8)
231
#define MAX_MATCHPOINTS  8
232
#define MAX_WATCHPOINTS  (MAX_MATCHPOINTS + 2)
233
 
234
/*
235 584 jeremybenn
 * Bit definitions for the Supervision Register
236
 *
237
 */
238 799 filepang
#define SPR_SR_SM          0x00000001  /* Supervisor Mode */
239
#define SPR_SR_TEE         0x00000002  /* Tick timer Exception Enable */
240
#define SPR_SR_IEE         0x00000004  /* Interrupt Exception Enable */
241
#define SPR_SR_DCE         0x00000008  /* Data Cache Enable */
242
#define SPR_SR_ICE         0x00000010  /* Instruction Cache Enable */
243
#define SPR_SR_DME         0x00000020  /* Data MMU Enable */
244
#define SPR_SR_IME         0x00000040  /* Instruction MMU Enable */
245
#define SPR_SR_LEE         0x00000080  /* Little Endian Enable */
246
#define SPR_SR_CE          0x00000100  /* CID Enable */
247
#define SPR_SR_F           0x00000200  /* Condition Flag */
248
#define SPR_SR_CY          0x00000400  /* Carry flag */
249
#define SPR_SR_OV          0x00000800  /* Overflow flag */
250
#define SPR_SR_OVE         0x00001000  /* Overflow flag Exception */
251
#define SPR_SR_DSX         0x00002000  /* Delay Slot Exception */
252
#define SPR_SR_EPH         0x00004000  /* Exception Prefix High */
253
#define SPR_SR_FO          0x00008000  /* Fixed one */
254
#define SPR_SR_SUMRA       0x00010000  /* Supervisor SPR read access */
255
#define SPR_SR_RES         0x0ffe0000  /* Reserved */
256
#define SPR_SR_CID         0xf0000000  /* Context ID */
257 584 jeremybenn
 
258
/*
259
 * Bit definitions for the Data MMU Control Register
260
 *
261
 */
262 799 filepang
#define SPR_DMMUCR_P2S     0x0000003e  /* Level 2 Page Size */
263
#define SPR_DMMUCR_P1S     0x000007c0  /* Level 1 Page Size */
264 584 jeremybenn
#define SPR_DMMUCR_VADDR_WIDTH  0x0000f800  /* Virtual ADDR Width */
265
#define SPR_DMMUCR_PADDR_WIDTH  0x000f0000  /* Physical ADDR Width */
266
 
267
/*
268
 * Bit definitions for the Instruction MMU Control Register
269
 *
270
 */
271 799 filepang
#define SPR_IMMUCR_P2S     0x0000003e  /* Level 2 Page Size */
272
#define SPR_IMMUCR_P1S     0x000007c0  /* Level 1 Page Size */
273 584 jeremybenn
#define SPR_IMMUCR_VADDR_WIDTH  0x0000f800  /* Virtual ADDR Width */
274
#define SPR_IMMUCR_PADDR_WIDTH  0x000f0000  /* Physical ADDR Width */
275
 
276
/*
277
 * Bit definitions for the Data TLB Match Register
278
 *
279
 */
280 799 filepang
#define SPR_DTLBMR_V       0x00000001  /* Valid */
281
#define SPR_DTLBMR_PL1     0x00000002  /* Page Level 1 (if 0 then PL2) */
282
#define SPR_DTLBMR_CID     0x0000003c  /* Context ID */
283
#define SPR_DTLBMR_LRU     0x000000c0  /* Least Recently Used */
284
#define SPR_DTLBMR_VPN     0xffffe000  /* Virtual Page Number */
285 584 jeremybenn
 
286
/*
287
 * Bit definitions for the Data TLB Translate Register
288
 *
289
 */
290 799 filepang
#define SPR_DTLBTR_CC      0x00000001  /* Cache Coherency */
291
#define SPR_DTLBTR_CI      0x00000002  /* Cache Inhibit */
292
#define SPR_DTLBTR_WBC     0x00000004  /* Write-Back Cache */
293
#define SPR_DTLBTR_WOM     0x00000008  /* Weakly-Ordered Memory */
294
#define SPR_DTLBTR_A       0x00000010  /* Accessed */
295
#define SPR_DTLBTR_D       0x00000020  /* Dirty */
296
#define SPR_DTLBTR_URE     0x00000040  /* User Read Enable */
297
#define SPR_DTLBTR_UWE     0x00000080  /* User Write Enable */
298
#define SPR_DTLBTR_SRE     0x00000100  /* Supervisor Read Enable */
299
#define SPR_DTLBTR_SWE     0x00000200  /* Supervisor Write Enable */
300
#define SPR_DTLBTR_PPN     0xffffe000  /* Physical Page Number */
301
 
302
#define DTLB_PR_NOLIMIT  ( SPR_DTLBTR_URE  | \
303
                           SPR_DTLBTR_UWE  | \
304
                           SPR_DTLBTR_SRE  | \
305
                           SPR_DTLBTR_SWE  )
306
 
307 584 jeremybenn
/*
308
 * Bit definitions for the Instruction TLB Match Register
309
 *
310
 */
311 799 filepang
#define SPR_ITLBMR_V       0x00000001  /* Valid */
312
#define SPR_ITLBMR_PL1     0x00000002  /* Page Level 1 (if 0 then PL2) */
313
#define SPR_ITLBMR_CID     0x0000003c  /* Context ID */
314
#define SPR_ITLBMR_LRU     0x000000c0  /* Least Recently Used */
315
#define SPR_ITLBMR_VPN     0xffffe000  /* Virtual Page Number */
316 584 jeremybenn
 
317
/*
318
 * Bit definitions for the Instruction TLB Translate Register
319
 *
320
 */
321 799 filepang
#define SPR_ITLBTR_CC      0x00000001  /* Cache Coherency */
322
#define SPR_ITLBTR_CI      0x00000002  /* Cache Inhibit */
323
#define SPR_ITLBTR_WBC     0x00000004  /* Write-Back Cache */
324
#define SPR_ITLBTR_WOM     0x00000008  /* Weakly-Ordered Memory */
325
#define SPR_ITLBTR_A       0x00000010  /* Accessed */
326
#define SPR_ITLBTR_D       0x00000020  /* Dirty */
327
#define SPR_ITLBTR_SXE     0x00000040  /* User Read Enable */
328
#define SPR_ITLBTR_UXE     0x00000080  /* User Write Enable */
329
#define SPR_ITLBTR_PPN     0xffffe000  /* Physical Page Number */
330 584 jeremybenn
 
331 799 filepang
#define ITLB_PR_NOLIMIT  ( SPR_ITLBTR_SXE  |    \
332
                           SPR_ITLBTR_UXE  )
333 584 jeremybenn
 
334
/*
335
 * Bit definitions for Data Cache Control register
336
 *
337
 */
338 799 filepang
#define SPR_DCCR_EW        0x000000ff  /* Enable ways */
339 584 jeremybenn
 
340
/*
341
 * Bit definitions for Insn Cache Control register
342
 *
343
 */
344 799 filepang
#define SPR_ICCR_EW        0x000000ff  /* Enable ways */
345 584 jeremybenn
 
346
/*
347 799 filepang
 * Bit definitions for Data Cache Configuration Register
348
 *
349
 */
350
 
351
#define SPR_DCCFGR_NCW          0x00000007
352
#define SPR_DCCFGR_NCS          0x00000078
353
#define SPR_DCCFGR_CBS          0x00000080
354
#define SPR_DCCFGR_CWS          0x00000100
355
#define SPR_DCCFGR_CCRI         0x00000200
356
#define SPR_DCCFGR_CBIRI        0x00000400
357
#define SPR_DCCFGR_CBPRI        0x00000800
358
#define SPR_DCCFGR_CBLRI        0x00001000
359
#define SPR_DCCFGR_CBFRI        0x00002000
360
#define SPR_DCCFGR_CBWBRI       0x00004000
361
 
362
#define SPR_DCCFGR_NCW_OFF      0
363
#define SPR_DCCFGR_NCS_OFF      3
364
#define SPR_DCCFGR_CBS_OFF      7
365
 
366
/*
367
 * Bit definitions for Instruction Cache Configuration Register
368
 *
369
 */
370
#define SPR_ICCFGR_NCW          0x00000007
371
#define SPR_ICCFGR_NCS          0x00000078
372
#define SPR_ICCFGR_CBS          0x00000080
373
#define SPR_ICCFGR_CCRI         0x00000200
374
#define SPR_ICCFGR_CBIRI        0x00000400
375
#define SPR_ICCFGR_CBPRI        0x00000800
376
#define SPR_ICCFGR_CBLRI        0x00001000
377
 
378
#define SPR_ICCFGR_NCW_OFF      0
379
#define SPR_ICCFGR_NCS_OFF      3
380
#define SPR_ICCFGR_CBS_OFF      7
381
 
382
/*
383
 * Bit definitions for Data MMU Configuration Register
384
 *
385
 */
386
 
387
#define SPR_DMMUCFGR_NTW        0x00000003
388
#define SPR_DMMUCFGR_NTS        0x0000001C
389
#define SPR_DMMUCFGR_NAE        0x000000E0
390
#define SPR_DMMUCFGR_CRI        0x00000100
391
#define SPR_DMMUCFGR_PRI        0x00000200
392
#define SPR_DMMUCFGR_TEIRI      0x00000400
393
#define SPR_DMMUCFGR_HTR        0x00000800
394
 
395
#define SPR_DMMUCFGR_NTW_OFF    0
396
#define SPR_DMMUCFGR_NTS_OFF    2
397
 
398
/*
399
 * Bit definitions for Instruction MMU Configuration Register
400
 *
401
 */
402
 
403
#define SPR_IMMUCFGR_NTW        0x00000003
404
#define SPR_IMMUCFGR_NTS        0x0000001C
405
#define SPR_IMMUCFGR_NAE        0x000000E0
406
#define SPR_IMMUCFGR_CRI        0x00000100
407
#define SPR_IMMUCFGR_PRI        0x00000200
408
#define SPR_IMMUCFGR_TEIRI      0x00000400
409
#define SPR_IMMUCFGR_HTR        0x00000800
410
 
411
#define SPR_IMMUCFGR_NTW_OFF    0
412
#define SPR_IMMUCFGR_NTS_OFF    2
413
 
414
/*
415 584 jeremybenn
 * Bit definitions for Debug Control registers
416
 *
417
 */
418
#define SPR_DCR_DP      0x00000001  /* DVR/DCR present */
419
#define SPR_DCR_CC      0x0000000e  /* Compare condition */
420
#define SPR_DCR_SC      0x00000010  /* Signed compare */
421
#define SPR_DCR_CT      0x000000e0  /* Compare to */
422
 
423
/* Bit results with SPR_DCR_CC mask */
424
#define SPR_DCR_CC_MASKED 0x00000000
425 799 filepang
#define SPR_DCR_CC_EQUAL  0x00000002
426
#define SPR_DCR_CC_LESS   0x00000004
427
#define SPR_DCR_CC_LESSE  0x00000006
428
#define SPR_DCR_CC_GREAT  0x00000008
429
#define SPR_DCR_CC_GREATE 0x0000000a
430
#define SPR_DCR_CC_NEQUAL 0x0000000c
431 584 jeremybenn
 
432
/* Bit results with SPR_DCR_CT mask */
433
#define SPR_DCR_CT_DISABLED 0x00000000
434
#define SPR_DCR_CT_IFEA     0x00000020
435
#define SPR_DCR_CT_LEA      0x00000040
436
#define SPR_DCR_CT_SEA      0x00000060
437
#define SPR_DCR_CT_LD       0x00000080
438
#define SPR_DCR_CT_SD       0x000000a0
439
#define SPR_DCR_CT_LSEA     0x000000c0
440 799 filepang
#define SPR_DCR_CT_LSD      0x000000e0
441
/* SPR_DCR_CT_LSD doesn't seem to be implemented anywhere in or1ksim. 2004-1-30 HP */
442 584 jeremybenn
 
443
/*
444
 * Bit definitions for Debug Mode 1 register
445
 *
446
 */
447 799 filepang
#define SPR_DMR1_CW       0x000fffff  /* Chain register pair data */
448
#define SPR_DMR1_CW0_AND  0x00000001
449
#define SPR_DMR1_CW0_OR   0x00000002
450
#define SPR_DMR1_CW0      (SPR_DMR1_CW0_AND | SPR_DMR1_CW0_OR)
451
#define SPR_DMR1_CW1_AND  0x00000004
452
#define SPR_DMR1_CW1_OR   0x00000008
453
#define SPR_DMR1_CW1      (SPR_DMR1_CW1_AND | SPR_DMR1_CW1_OR)
454
#define SPR_DMR1_CW2_AND  0x00000010
455
#define SPR_DMR1_CW2_OR   0x00000020
456
#define SPR_DMR1_CW2      (SPR_DMR1_CW2_AND | SPR_DMR1_CW2_OR)
457
#define SPR_DMR1_CW3_AND  0x00000040
458
#define SPR_DMR1_CW3_OR   0x00000080
459
#define SPR_DMR1_CW3      (SPR_DMR1_CW3_AND | SPR_DMR1_CW3_OR)
460
#define SPR_DMR1_CW4_AND  0x00000100
461
#define SPR_DMR1_CW4_OR   0x00000200
462
#define SPR_DMR1_CW4      (SPR_DMR1_CW4_AND | SPR_DMR1_CW4_OR)
463
#define SPR_DMR1_CW5_AND  0x00000400
464
#define SPR_DMR1_CW5_OR   0x00000800
465
#define SPR_DMR1_CW5      (SPR_DMR1_CW5_AND | SPR_DMR1_CW5_OR)
466
#define SPR_DMR1_CW6_AND  0x00001000
467
#define SPR_DMR1_CW6_OR   0x00002000
468
#define SPR_DMR1_CW6      (SPR_DMR1_CW6_AND | SPR_DMR1_CW6_OR)
469
#define SPR_DMR1_CW7_AND  0x00004000
470
#define SPR_DMR1_CW7_OR   0x00008000
471
#define SPR_DMR1_CW7      (SPR_DMR1_CW7_AND | SPR_DMR1_CW7_OR)
472
#define SPR_DMR1_CW8_AND  0x00010000
473
#define SPR_DMR1_CW8_OR   0x00020000
474
#define SPR_DMR1_CW8      (SPR_DMR1_CW8_AND | SPR_DMR1_CW8_OR)
475
#define SPR_DMR1_CW9_AND  0x00040000
476
#define SPR_DMR1_CW9_OR   0x00080000
477
#define SPR_DMR1_CW9      (SPR_DMR1_CW9_AND | SPR_DMR1_CW9_OR)
478
#define SPR_DMR1_RES1      0x00300000  /* Reserved */
479
#define SPR_DMR1_ST       0x00400000  /* Single-step trace*/
480
#define SPR_DMR1_BT       0x00800000  /* Branch trace */
481
#define SPR_DMR1_RES2     0xff000000  /* Reserved */
482 584 jeremybenn
 
483
/*
484 799 filepang
 * Bit definitions for Debug Mode 2 register. AWTC and WGB corrected by JPB
485 584 jeremybenn
 *
486
 */
487 799 filepang
#define SPR_DMR2_WCE0      0x00000001  /* Watchpoint counter 0 enable */
488
#define SPR_DMR2_WCE1      0x00000002  /* Watchpoint counter 0 enable */
489
#define SPR_DMR2_AWTC      0x00000ffc  /* Assign watchpoints to counters */
490
#define SPR_DMR2_AWTC_OFF           2  /* Bit offset to AWTC field */
491
#define SPR_DMR2_WGB       0x003ff000  /* Watchpoints generating breakpoint */
492
#define SPR_DMR2_WGB_OFF           12  /* Bit offset to WGB field */
493
#define SPR_DMR2_WBS       0xffc00000  /* JPB: Watchpoint status */
494
#define SPR_DMR2_WBS_OFF           22  /* Bit offset to WBS field */
495 584 jeremybenn
 
496
/*
497
 * Bit definitions for Debug watchpoint counter registers
498
 *
499
 */
500 799 filepang
#define SPR_DWCR_COUNT      0x0000ffff  /* Count */
501
#define SPR_DWCR_MATCH      0xffff0000  /* Match */
502
#define SPR_DWCR_MATCH_OFF          16  /* Match bit offset */
503 584 jeremybenn
 
504
/*
505
 * Bit definitions for Debug stop register
506
 *
507
 */
508
#define SPR_DSR_RSTE    0x00000001  /* Reset exception */
509
#define SPR_DSR_BUSEE   0x00000002  /* Bus error exception */
510
#define SPR_DSR_DPFE    0x00000004  /* Data Page Fault exception */
511
#define SPR_DSR_IPFE    0x00000008  /* Insn Page Fault exception */
512 799 filepang
#define SPR_DSR_TTE     0x00000010  /* Tick Timer exception */
513
#define SPR_DSR_AE      0x00000020  /* Alignment exception */
514
#define SPR_DSR_IIE     0x00000040  /* Illegal Instruction exception */
515
#define SPR_DSR_IE      0x00000080  /* Interrupt exception */
516
#define SPR_DSR_DME     0x00000100  /* DTLB miss exception */
517
#define SPR_DSR_IME     0x00000200  /* ITLB miss exception */
518
#define SPR_DSR_RE      0x00000400  /* Range exception */
519
#define SPR_DSR_SCE     0x00000800  /* System call exception */
520
#define SPR_DSR_FPE     0x00001000  /* Floating Point Exception */
521
#define SPR_DSR_TE      0x00002000  /* Trap exception */
522 584 jeremybenn
 
523
/*
524
 * Bit definitions for Debug reason register
525
 *
526
 */
527
#define SPR_DRR_RSTE    0x00000001  /* Reset exception */
528
#define SPR_DRR_BUSEE   0x00000002  /* Bus error exception */
529
#define SPR_DRR_DPFE    0x00000004  /* Data Page Fault exception */
530
#define SPR_DRR_IPFE    0x00000008  /* Insn Page Fault exception */
531 799 filepang
#define SPR_DRR_TTE     0x00000010  /* Tick Timer exception */
532
#define SPR_DRR_AE      0x00000020  /* Alignment exception */
533
#define SPR_DRR_IIE     0x00000040  /* Illegal Instruction exception */
534
#define SPR_DRR_IE      0x00000080  /* Interrupt exception */
535
#define SPR_DRR_DME     0x00000100  /* DTLB miss exception */
536
#define SPR_DRR_IME     0x00000200  /* ITLB miss exception */
537
#define SPR_DRR_RE      0x00000400  /* Range exception */
538
#define SPR_DRR_SCE     0x00000800  /* System call exception */
539
#define SPR_DRR_FPE     0x00001000  /* Floating Point Exception */
540
#define SPR_DRR_TE      0x00002000  /* Trap exception */
541 584 jeremybenn
 
542
/*
543
 * Bit definitions for Performance counters mode registers
544
 *
545
 */
546 799 filepang
#define SPR_PCMR_CP     0x00000001  /* Counter present */
547 584 jeremybenn
#define SPR_PCMR_UMRA   0x00000002  /* User mode read access */
548
#define SPR_PCMR_CISM   0x00000004  /* Count in supervisor mode */
549
#define SPR_PCMR_CIUM   0x00000008  /* Count in user mode */
550 799 filepang
#define SPR_PCMR_LA     0x00000010  /* Load access event */
551
#define SPR_PCMR_SA     0x00000020  /* Store access event */
552
#define SPR_PCMR_IF     0x00000040  /* Instruction fetch event*/
553 584 jeremybenn
#define SPR_PCMR_DCM    0x00000080  /* Data cache miss event */
554
#define SPR_PCMR_ICM    0x00000100  /* Insn cache miss event */
555
#define SPR_PCMR_IFS    0x00000200  /* Insn fetch stall event */
556
#define SPR_PCMR_LSUS   0x00000400  /* LSU stall event */
557 799 filepang
#define SPR_PCMR_BS     0x00000800  /* Branch stall event */
558 584 jeremybenn
#define SPR_PCMR_DTLBM  0x00001000  /* DTLB miss event */
559
#define SPR_PCMR_ITLBM  0x00002000  /* ITLB miss event */
560
#define SPR_PCMR_DDS    0x00004000  /* Data dependency stall event */
561
#define SPR_PCMR_WPE    0x03ff8000  /* Watchpoint events */
562
 
563
/*
564
 * Bit definitions for the Power management register
565
 *
566
 */
567 799 filepang
#define SPR_PMR_SDF     0x0000000f  /* Slow down factor */
568
#define SPR_PMR_DME     0x00000010  /* Doze mode enable */
569
#define SPR_PMR_SME     0x00000020  /* Sleep mode enable */
570 584 jeremybenn
#define SPR_PMR_DCGE    0x00000040  /* Dynamic clock gating enable */
571
#define SPR_PMR_SUME    0x00000080  /* Suspend mode enable */
572
 
573
/*
574
 * Bit definitions for PICMR
575
 *
576
 */
577
#define SPR_PICMR_IUM   0xfffffffc  /* Interrupt unmask */
578
 
579
/*
580
 * Bit definitions for PICPR
581
 *
582
 */
583
#define SPR_PICPR_IPRIO 0xfffffffc  /* Interrupt priority */
584
 
585
/*
586
 * Bit definitions for PICSR
587
 *
588
 */
589
#define SPR_PICSR_IS    0xffffffff  /* Interrupt status */
590
 
591
/*
592
 * Bit definitions for Tick Timer Control Register
593
 *
594
 */
595
#define SPR_TTCR_PERIOD 0x0fffffff  /* Time Period */
596
#define SPR_TTMR_PERIOD SPR_TTCR_PERIOD
597 799 filepang
#define SPR_TTMR_IP     0x10000000  /* Interrupt Pending */
598
#define SPR_TTMR_IE     0x20000000  /* Interrupt Enable */
599
#define SPR_TTMR_DI     0x00000000  /* Disabled */
600
#define SPR_TTMR_RT     0x40000000  /* Restart tick */
601 584 jeremybenn
#define SPR_TTMR_SR     0x80000000  /* Single run */
602
#define SPR_TTMR_CR     0xc0000000  /* Continuous run */
603
#define SPR_TTMR_M      0xc0000000  /* Tick mode */
604
 
605
/*
606 799 filepang
 * Bit definitions for the FP Control Status Register
607
 *
608
 */
609
#define SPR_FPCSR_FPEE  0x00000001  /* Floating Point Exception Enable */
610
#define SPR_FPCSR_RM    0x00000006  /* Rounding Mode */
611
#define SPR_FPCSR_OVF   0x00000008  /* Overflow Flag */
612
#define SPR_FPCSR_UNF   0x00000010  /* Underflow Flag */
613
#define SPR_FPCSR_SNF   0x00000020  /* SNAN Flag */
614
#define SPR_FPCSR_QNF   0x00000040  /* QNAN Flag */
615
#define SPR_FPCSR_ZF    0x00000080  /* Zero Flag */
616
#define SPR_FPCSR_IXF   0x00000100  /* Inexact Flag */
617
#define SPR_FPCSR_IVF   0x00000200  /* Invalid Flag */
618
#define SPR_FPCSR_INF   0x00000400  /* Infinity Flag */
619
#define SPR_FPCSR_DZF   0x00000800  /* Divide By Zero Flag */
620
#define SPR_FPCSR_ALLF (SPR_FPCSR_OVF | SPR_FPCSR_UNF | SPR_FPCSR_SNF | \
621
                        SPR_FPCSR_QNF | SPR_FPCSR_ZF | SPR_FPCSR_IXF |  \
622
                        SPR_FPCSR_IVF | SPR_FPCSR_INF | SPR_FPCSR_DZF)
623
 
624
#define FPCSR_RM_RN (0<<1)
625
#define FPCSR_RM_RZ (1<<1)
626
#define FPCSR_RM_RIP (2<<1)
627
#define FPCSR_RM_RIN (3<<1)
628
 
629
/*
630 584 jeremybenn
 * l.nop constants
631
 *
632
 */
633 799 filepang
#define NOP_NOP          0x0000      /* Normal nop instruction */
634
#define NOP_EXIT         0x0001      /* End of simulation */
635
#define NOP_REPORT       0x0002      /* Simple report */
636
/*#define NOP_PRINTF       0x0003       Simprintf instruction (obsolete)*/
637
#define NOP_PUTC         0x0004      /* JPB: Simputc instruction */
638
#define NOP_CNT_RESET    0x0005      /* Reset statistics counters */
639
#define NOP_GET_TICKS    0x0006      /* JPB: Get # ticks running */
640
#define NOP_GET_PS       0x0007      /* JPB: Get picosecs/cycle */
641
#define NOP_REPORT_FIRST 0x0400      /* Report with number */
642
#define NOP_REPORT_LAST  0x03ff      /* Report with number */
643
 
644
#endif  /* SPR_DEFS__H */

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.