tlsbreg.h revision 1.6 1 1.6 matt /* $NetBSD: tlsbreg.h,v 1.6 2012/02/06 02:14:16 matt Exp $ */
2 1.1 cgd
3 1.1 cgd /*
4 1.5 mjacob * Copyright (c) 1997, 2000 by Matthew Jacob
5 1.1 cgd * NASA AMES Research Center.
6 1.1 cgd * All rights reserved.
7 1.1 cgd *
8 1.1 cgd * Based in part upon a prototype version by Jason Thorpe
9 1.1 cgd * Copyright (c) 1996 by Jason Thorpe.
10 1.1 cgd *
11 1.1 cgd * Redistribution and use in source and binary forms, with or without
12 1.1 cgd * modification, are permitted provided that the following conditions
13 1.1 cgd * are met:
14 1.1 cgd * 1. Redistributions of source code must retain the above copyright
15 1.1 cgd * notice immediately at the beginning of the file, without modification,
16 1.1 cgd * this list of conditions, and the following disclaimer.
17 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright
18 1.1 cgd * notice, this list of conditions and the following disclaimer in the
19 1.1 cgd * documentation and/or other materials provided with the distribution.
20 1.1 cgd *
21 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
22 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR
25 1.1 cgd * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 1.1 cgd * SUCH DAMAGE.
32 1.1 cgd */
33 1.1 cgd
34 1.1 cgd /*
35 1.1 cgd * Definitions for the TurboLaser System Bus found on
36 1.1 cgd * AlphaServer 8200/8400 systems.
37 1.1 cgd */
38 1.1 cgd
39 1.1 cgd /*
40 1.1 cgd * There are 9 TurboLaser nodes, 0 though 8. Their uses are defined as
41 1.1 cgd * follows:
42 1.1 cgd *
43 1.1 cgd * Node Module
44 1.1 cgd * ---- ------
45 1.1 cgd * 0 CPU, Memory
46 1.1 cgd * 1 CPU, Memory
47 1.1 cgd * 2 CPU, Memory
48 1.1 cgd * 3 CPU, Memory
49 1.1 cgd * 4 CPU, Memory, I/O
50 1.1 cgd * 5 CPU, Memory, I/O
51 1.1 cgd * 6 CPU, Memory, I/O
52 1.1 cgd * 7 CPU, Memory, I/O
53 1.1 cgd * 8 I/O
54 1.1 cgd *
55 1.1 cgd * A node occurs every 0x00400000 bytes.
56 1.1 cgd *
57 1.1 cgd * Note, the AlphaServer 8200 only has nodes 4 though 8.
58 1.1 cgd */
59 1.1 cgd
60 1.1 cgd #define TLSB_NODE_BASE 0x000000ff88000000 /* Dense */
61 1.1 cgd #define TLSB_NODE_SIZE 0x00400000
62 1.4 mjacob #define TLSB_NODE_MAX 8 /* inclusive */
63 1.1 cgd
64 1.1 cgd /* Translate a node number to an address. */
65 1.1 cgd #define TLSB_NODE_ADDR(_node) \
66 1.1 cgd (long)(TLSB_NODE_BASE + ((_node) * TLSB_NODE_SIZE))
67 1.1 cgd
68 1.1 cgd #define TLSB_NODE_REG_ADDR(_node, _reg) \
69 1.1 cgd KV((long)TLSB_NODE_ADDR((_node)) + (_reg))
70 1.1 cgd
71 1.1 cgd /* Access the specified register on the specified node. */
72 1.1 cgd #define TLSB_GET_NODEREG(_node, _reg) \
73 1.6 matt *(volatile uint32_t *)(TLSB_NODE_REG_ADDR((_node), (_reg)))
74 1.1 cgd #define TLSB_PUT_NODEREG(_node, _reg, _val) \
75 1.6 matt *(volatile uint32_t *)(TLSB_NODE_REG_ADDR((_node), (_reg))) = (_val)
76 1.1 cgd
77 1.1 cgd /*
78 1.1 cgd * Some registers are shared by all TurboLaser nodes, and appear in
79 1.1 cgd * the TurboLaser Broadcast space.
80 1.1 cgd */
81 1.1 cgd #define TLSB_BCAST_BASE 0x000000ff8e000000 /* Dense */
82 1.1 cgd
83 1.1 cgd #define TLSB_BCAST_REG_ADDR(_reg) KV((long)(TLSB_BCASE_BASE + (_reg)))
84 1.1 cgd
85 1.1 cgd /* Access the specified register in the broadcast space. */
86 1.1 cgd #define TLSB_GET_BCASTREG(_reg) \
87 1.6 matt *(volatile uint32_t *)(TLSB_BCAST_REG_ADDR + (_reg))
88 1.1 cgd #define TLSB_PUT_BCASTREG(_reg, _val) \
89 1.6 matt *(volatile uint32_t *)(TLSB_BCAST_REG_ADDR + (_reg)) = (_val)
90 1.1 cgd
91 1.1 cgd /*
92 1.1 cgd * Location of the Gbus, the per-CPU bus containing the clock and
93 1.1 cgd * console hardware.
94 1.1 cgd */
95 1.1 cgd #define TLSB_GBUS_BASE 0x000000ff90000000 /* Dense */
96 1.1 cgd
97 1.1 cgd /*
98 1.1 cgd * Note that not every module type supports each TurboLaser register.
99 1.1 cgd * The following defines the keys used to denote module support for
100 1.1 cgd * a given register:
101 1.1 cgd *
102 1.1 cgd * C Supported by CPU module
103 1.1 cgd * M Supported by Memory module
104 1.1 cgd * I Supported by I/O module
105 1.1 cgd */
106 1.1 cgd
107 1.1 cgd /*
108 1.1 cgd * Per-node TurboLaser System Bus registers, offsets from the
109 1.1 cgd * base of the node.
110 1.1 cgd */
111 1.1 cgd #define TLDEV 0x0000 /* CMI: Device Register */
112 1.1 cgd #define TLBER 0x0040 /* CMI: Bus Error Register */
113 1.1 cgd #define TLCNR 0x0080 /* CMI: Congfiguration Register */
114 1.1 cgd #define TLVID 0x00c0 /* CM: Virtual ID Register */
115 1.1 cgd #define TLMMR0 0x0200 /* CM: Memory Mapping Register 0 */
116 1.1 cgd #define TLMMR1 0x0240 /* CM: Memory Mapping Register 1 */
117 1.1 cgd #define TLMMR2 0x0280 /* CM: Memory Mapping Register 2 */
118 1.1 cgd #define TLMMR3 0x02c0 /* CM: Memory Mapping Register 3 */
119 1.1 cgd #define TLMMR4 0x0300 /* CM: Memory Mapping Register 4 */
120 1.1 cgd #define TLMMR5 0x0340 /* CM: Memory Mapping Register 5 */
121 1.1 cgd #define TLMMR6 0x0380 /* CM: Memory Mapping Register 6 */
122 1.1 cgd #define TLMMR7 0x03c0 /* CM: Memory Mapping Register 7 */
123 1.1 cgd #define TLFADR0 0x0600 /* MI: Failing Address Register 0 */
124 1.1 cgd #define TLFADR1 0x0640 /* MI: Failing Address Register 1 */
125 1.1 cgd #define TLESR0 0x0680 /* CMI: Error Syndrome Register 0 */
126 1.1 cgd #define TLESR1 0x06c0 /* CMI: Error Syndrome Register 1 */
127 1.1 cgd #define TLESR2 0x0700 /* CMI: Error Syndrome Register 2 */
128 1.1 cgd #define TLESR3 0x0740 /* CMI: Error Syndrome Register 3 */
129 1.1 cgd #define TLILID0 0x0a00 /* I: Int. Level 0 IDENT Register */
130 1.1 cgd #define TLILID1 0x0a40 /* I: Int. Level 1 IDENT Register */
131 1.1 cgd #define TLILID2 0x0a80 /* I: Int. Level 2 IDENT Register */
132 1.1 cgd #define TLILID3 0x0ac0 /* I: Int. Level 3 IDENT Register */
133 1.1 cgd #define TLCPUMASK 0x0b00 /* I: CPU Interrupt Mask Register */
134 1.1 cgd #define TLMBPTR 0x0c00 /* I: Mailbox Pointer Register */
135 1.5 mjacob #define TLINTRMASK0 0x1100 /* C: Interrupt Mask Register CPU 0 */
136 1.5 mjacob #define TLINTRMASK1 0x1140 /* C: Interrupt Mask Register CPU 1 */
137 1.5 mjacob #define TLINTRSUM0 0x1180 /* C: Interrupt Sum Register CPU 0 */
138 1.5 mjacob #define TLINTRSUM1 0x11C0 /* C: Interrupt Sum Register CPU 1 */
139 1.1 cgd #define TLEPAERR 0x1500 /* C: ADG error register */
140 1.4 mjacob #define TLEPDERR 0x1540 /* C: DIGA error register */
141 1.4 mjacob #define TLEPMERR 0x1580 /* C: MMG error register */
142 1.4 mjacob #define TLDMCMD 0x1600 /* C: Data Mover Command */
143 1.4 mjacob #define TLDMADRA 0x1680 /* C: Data Mover Source */
144 1.4 mjacob #define TLDMADRB 0x16C0 /* C: Data Mover Destination */
145 1.1 cgd
146 1.1 cgd /*
147 1.1 cgd * Registers shared between TurboLaser nodes, offsets from the
148 1.1 cgd * TurboLaser Broadcast Base.
149 1.1 cgd */
150 1.1 cgd #define TLPRIVATE 0x0000 /* CMI: private "global" space */
151 1.1 cgd #define TLIPINTR 0x0040 /* C: Interprocessor Int. Register */
152 1.1 cgd #define TLIOINTR4 0x0100 /* C: I/O Interrupt Register 4 */
153 1.1 cgd #define TLIOINTR5 0x0140 /* C: I/O Interrupt Register 5 */
154 1.1 cgd #define TLIOINTR6 0x0180 /* C: I/O Interrupt Register 6 */
155 1.1 cgd #define TLIOINTR7 0x01c0 /* C: I/O Interrupt Register 7 */
156 1.1 cgd #define TLIOINTR8 0x0200 /* C: I/O Interrupt Register 8 */
157 1.1 cgd #define TLWSDQR4 0x0400 /* C: Win Spc Dcr Que Ctr Reg 4 */
158 1.1 cgd #define TLWSDQR5 0x0440 /* C: Win Spc Dcr Que Ctr Reg 5 */
159 1.1 cgd #define TLWSDQR6 0x0480 /* C: Win Spc Dcr Que Ctr Reg 6 */
160 1.1 cgd #define TLWSDQR7 0x04c0 /* C: Win Spc Dcr Que Ctr Reg 7 */
161 1.1 cgd #define TLWSDQR8 0x0500 /* C: Win Spc Dcr Que Ctr Reg 8 */
162 1.1 cgd #define TLRMDQRX 0x0600 /* C: Mem Chan Dcr Que Ctr Reg X */
163 1.1 cgd #define TLRMDQR8 0x0640 /* C: Mem Chan Dcr Que Ctr Reg 8 */
164 1.1 cgd #define TLRDRD 0x0800 /* C: CSR Read Data Rtn Data Reg */
165 1.1 cgd #define TLRDRE 0x0840 /* C: CSR Read Data Rtn Error Reg */
166 1.1 cgd #define TLMCR 0x1880 /* M: Memory Control Register */
167 1.1 cgd
168 1.1 cgd /*
169 1.1 cgd * TLDEV - Device Register
170 1.1 cgd *
171 1.1 cgd * Access: R/W
172 1.1 cgd *
173 1.1 cgd * Notes:
174 1.1 cgd * Register is loaded during initialization with information
175 1.1 cgd * that identifies a node. A zero value indicates a non-initialized
176 1.1 cgd * (slot empty) node.
177 1.1 cgd *
178 1.1 cgd * Bits 0-15 contain the hardware device type, bits 16-23
179 1.1 cgd * the board's software revision, and bits 24-31 the board's
180 1.1 cgd * hardware revision.
181 1.1 cgd *
182 1.1 cgd * The device type portion is laid out as follows:
183 1.1 cgd *
184 1.1 cgd * Bit 15: identifies a CPU
185 1.1 cgd * Bit 14: identifies a memory board
186 1.1 cgd * Bit 13: identifies an I/O board
187 1.1 cgd * Bits 0-7: specify the ID of a node type
188 1.1 cgd */
189 1.1 cgd #define TLDEV_DTYPE_MASK 0x0000ffff
190 1.1 cgd #define TLDEV_DTYPE_KFTHA 0x2000 /* KFTHA board, I/O */
191 1.1 cgd #define TLDEV_DTYPE_KFTIA 0x2020 /* KFTIA board, I/O */
192 1.1 cgd #define TLDEV_DTYPE_MS7CC 0x5000 /* Memory board */
193 1.1 cgd #define TLDEV_DTYPE_SCPU4 0x8011 /* 1 CPU, 4mb cache */
194 1.1 cgd #define TLDEV_DTYPE_SCPU16 0x8012 /* 1 CPU, 16mb cache */
195 1.1 cgd #define TLDEV_DTYPE_DCPU4 0x8014 /* 2 CPU, 4mb cache */
196 1.1 cgd #define TLDEV_DTYPE_DCPU16 0x8015 /* 2 CPU, 16mb cache */
197 1.1 cgd
198 1.1 cgd #define TLDEV_DTYPE(_val) ((_val) & TLDEV_DTYPE_MASK)
199 1.1 cgd # define TLDEV_ISCPU(_val) (TLDEV_DTYPE(_val) & 0x8000)
200 1.1 cgd # define TLDEV_ISMEM(_val) (TLDEV_DTYPE(_val) & 0x4000)
201 1.1 cgd # define TLDEV_ISIOPORT(_val) (TLDEV_DTYPE(_val) & 0x2000)
202 1.1 cgd #define TLDEV_SWREV(_val) (((_val) >> 16) & 0xff)
203 1.1 cgd #define TLDEV_HWREV(_val) (((_val) >> 24) & 0xff)
204 1.1 cgd
205 1.1 cgd /*
206 1.1 cgd * TLBER - Bus Error Register
207 1.1 cgd *
208 1.1 cgd * Access: R/W
209 1.1 cgd *
210 1.1 cgd * Notes:
211 1.1 cgd * This register contains information about TLSB errors detected by
212 1.1 cgd * nodes on the TLSB. The register will become locked when:
213 1.1 cgd *
214 1.1 cgd * * Any error occurs and the "lock on first error"
215 1.1 cgd * bit of the Configuration Register is set.
216 1.1 cgd *
217 1.1 cgd * * Any bit other than 20-23 (DS0-DS3) becomes set.
218 1.1 cgd *
219 1.1 cgd * and will remain locked until either:
220 1.1 cgd *
221 1.1 cgd * * All bits in the TLBER are cleared.
222 1.1 cgd *
223 1.1 cgd * * The "lock on first error" bit is cleared.
224 1.1 cgd *
225 1.1 cgd * TLBER locking is intended for diagnosic purposes only, and
226 1.1 cgd * not for general use.
227 1.1 cgd */
228 1.1 cgd #define TLBER_ATCE 0x00000001 /* Addr Transmit Ck Error */
229 1.1 cgd #define TLBER_APE 0x00000002 /* Addr Parity Error */
230 1.1 cgd #define TLBER_BAE 0x00000004 /* Bank Avail Violation Error */
231 1.1 cgd #define TLBER_LKTO 0x00000008 /* Bank Lock Timeout */
232 1.1 cgd #define TLBER_NAE 0x00000010 /* No Ack Error */
233 1.1 cgd #define TLBER_RTCE 0x00000020 /* Read Transmit Ck Error */
234 1.1 cgd #define TLBER_ACKTCE 0x00000040 /* Ack Transmit Ck Error */
235 1.1 cgd #define TLBER_MMRE 0x00000080 /* Mem Mapping Register Error */
236 1.1 cgd #define TLBER_FNAE 0x00000100 /* Fatal No Ack Error */
237 1.1 cgd #define TLBER_REQDE 0x00000200 /* Request Deassertion Error */
238 1.1 cgd #define TLBER_ATDE 0x00000400 /* Addredd Transmitter During Error */
239 1.1 cgd #define TLBER_UDE 0x00010000 /* Uncorrectable Data Error */
240 1.1 cgd #define TLBER_CWDE 0x00020000 /* Correctable Write Data Error */
241 1.1 cgd #define TLBER_CRDE 0x00040000 /* Correctable Read Data Error */
242 1.1 cgd #define TLBER_CRDE2 0x00080000 /* ...ditto... */
243 1.1 cgd #define TLBER_DS0 0x00100000 /* Data Synd 0 */
244 1.1 cgd #define TLBER_DS1 0x00200000 /* Data Synd 1 */
245 1.1 cgd #define TLBER_DS2 0x00400000 /* Data Synd 2 */
246 1.1 cgd #define TLBER_DS3 0x00800000 /* Data Synd 3 */
247 1.1 cgd #define TLBER_DTDE 0x01000000 /* Data Transmitter During Error */
248 1.1 cgd #define TLBER_FDTCE 0x02000000 /* Fatal Data Transmit Ck Error */
249 1.1 cgd #define TLBER_UACKE 0x04000000 /* Unexpected Ack Error */
250 1.1 cgd #define TLBER_ABTCE 0x08000000 /* Addr Bus Transmit Error */
251 1.1 cgd #define TLBER_DCTCE 0x10000000 /* Data Control Transmit Ck Error */
252 1.1 cgd #define TLBER_SEQE 0x20000000 /* Sequence Error */
253 1.1 cgd #define TLBER_DSE 0x40000000 /* Data Status Error */
254 1.1 cgd #define TLBER_DTO 0x80000000 /* Data Timeout Error */
255 1.1 cgd
256 1.1 cgd /*
257 1.1 cgd * TLCNR - Configuration Register
258 1.1 cgd *
259 1.1 cgd * Access: R/W
260 1.1 cgd */
261 1.1 cgd #define TLCNR_CWDD 0x00000001 /* Corr Write Data Err INTR Dis */
262 1.1 cgd #define TLCNR_CRDD 0x00000002 /* Corr Read Data Err INTR Dis */
263 1.1 cgd #define TLCNR_LKTOD 0x00000004 /* Bank Lock Timeout Disable */
264 1.1 cgd #define TLCNR_DTOD 0x00000008 /* Data Timeout Disable */
265 1.1 cgd #define TLCNR_STF_A 0x00001000 /* Self-Test Fail A */
266 1.1 cgd #define TLCNR_STF_B 0x00002000 /* Self-Test Fail B */
267 1.1 cgd #define TLCNR_HALT_A 0x00100000 /* Halt A */
268 1.1 cgd #define TLCNR_HALT_B 0x00200000 /* Halt B */
269 1.1 cgd #define TLCNR_RSTSTAT 0x10000000 /* Reset Status */
270 1.1 cgd #define TLCNR_NRST 0x40000000 /* Node Reset */
271 1.1 cgd #define TLCNR_LOFE 0x80000000 /* Lock On First Error */
272 1.1 cgd
273 1.1 cgd #define TLCNR_NODE_MASK 0x000000f0 /* Node ID mask */
274 1.1 cgd #define TLCNR_NODE_SHIFT 4
275 1.1 cgd
276 1.1 cgd #define TLCNR_VCNT_MASK 0x00000f00 /* VCNT mask */
277 1.1 cgd #define TLCNR_VCNT_SHIFT 8
278 1.1 cgd
279 1.1 cgd /*
280 1.1 cgd * TLVID - Virtual ID Register
281 1.1 cgd *
282 1.1 cgd * Access: R/W
283 1.1 cgd *
284 1.1 cgd * Notes:
285 1.1 cgd * Virtual units can be CPUs or Memory boards. The units are
286 1.1 cgd * are addressed using virtual IDs. These virtual IDs are assigned
287 1.1 cgd * by writing to the TLVID register. The upper 24 bits of this
288 1.1 cgd * register are reserved and must be written as `0'.
289 1.1 cgd */
290 1.1 cgd #define TLVID_VIDA_MASK 0x0000000f /* Virtual ID for unit 0 */
291 1.1 cgd #define TLVID_VIDA_SHIFT 0
292 1.1 cgd
293 1.1 cgd #define TLVID_VIDB_MASK 0x000000f0 /* Virtual ID for unit 1 */
294 1.1 cgd #define TLVID_VIDB_SHIFT 4
295 1.1 cgd
296 1.1 cgd /*
297 1.1 cgd * TLMMRn - Memory Mapping Registers
298 1.1 cgd *
299 1.1 cgd * Access: W
300 1.1 cgd *
301 1.1 cgd * Notes:
302 1.1 cgd * Contains mapping information for doing a bank-decode.
303 1.1 cgd */
304 1.1 cgd #define TLMMR_INTMASK 0x00000003 /* Valid bits in Interleave */
305 1.1 cgd #define TLMMR_ADRMASK 0x000000f0 /* Valid bits in Address */
306 1.1 cgd #define TLMMR_SBANK 0x00000800 /* Single-bank indicator */
307 1.1 cgd #define TLMMR_VALID 0x80000000 /* Indicated mapping is valid */
308 1.1 cgd
309 1.1 cgd #define TLMMR_INTLV_MASK 0x00000700 /* Mask for interleave value */
310 1.1 cgd #define TLMMR_INTLV_SHIFT 8
311 1.1 cgd
312 1.1 cgd #define TLMMR_ADDRESS_MASK 0x03fff000 /* Mask for address value */
313 1.1 cgd #define TLMMR_ADDRESS_SHIFT 12
314 1.1 cgd
315 1.1 cgd /*
316 1.1 cgd * TLFADRn - Failing Address Registers
317 1.1 cgd *
318 1.1 cgd * Access: R/W
319 1.1 cgd *
320 1.1 cgd * Notes:
321 1.1 cgd * These registers contain status information for a failed address.
322 1.1 cgd * Not all nodes preserve this information. The validation bits
323 1.1 cgd * indicate the validity of a given field.
324 1.1 cgd */
325 1.1 cgd
326 1.4 mjacob
327 1.5 mjacob /*
328 1.5 mjacob * CPU Interrupt Mask Register
329 1.5 mjacob *
330 1.5 mjacob * The PAL code reads this register for each CPU on a TLSB CPU board
331 1.5 mjacob * to see what is or isn't enabled.
332 1.5 mjacob */
333 1.5 mjacob #define TLINTRMASK_CONHALT 0x100 /* Enable ^P Halt */
334 1.5 mjacob #define TLINTRMASK_HALT 0x080 /* Enable Halt */
335 1.5 mjacob #define TLINTRMASK_CLOCK 0x040 /* Enable Clock Interrupts */
336 1.5 mjacob #define TLINTRMASK_XCALL 0x020 /* Enable Interprocessor Interrupts */
337 1.5 mjacob #define TLINTRMASK_IPL17 0x010 /* Enable IPL 17 Interrupts */
338 1.5 mjacob #define TLINTRMASK_IPL16 0x008 /* Enable IPL 16 Interrupts */
339 1.5 mjacob #define TLINTRMASK_IPL15 0x004 /* Enable IPL 15 Interrupts */
340 1.5 mjacob #define TLINTRMASK_IPL14 0x002 /* Enable IPL 14 Interrupts */
341 1.5 mjacob #define TLINTRMASK_DUART 0x001 /* Enable GBUS Duart0 Interrupts */
342 1.5 mjacob
343 1.5 mjacob /*
344 1.5 mjacob * CPU Interrupt Summary Register
345 1.5 mjacob *
346 1.5 mjacob * The PAL code reads this register at interrupt time to figure out
347 1.5 mjacob * which interrupt line to assert to the CPU. Note that when the
348 1.5 mjacob * interrupt is actually vectored through the PAL code, it arrives
349 1.5 mjacob * here already presorted as to type (clock, halt, iointr).
350 1.5 mjacob */
351 1.5 mjacob #define TLINTRSUM_HALT (1 << 28) /* Halted via TLCNR register */
352 1.5 mjacob #define TLINTRSUM_CONHALT (1 << 27) /* Halted via ^P (W1C) */
353 1.5 mjacob #define TLINTRSUM_CLOCK (1 << 6) /* Clock Interrupt (W1C) */
354 1.5 mjacob #define TLINTRSUM_XCALL (1 << 5) /* Interprocessor Int (W1C) */
355 1.5 mjacob #define TLINTRSUM_IPL17 (1 << 4) /* IPL 17 Interrupt Summary */
356 1.5 mjacob #define TLINTRSUM_IPL16 (1 << 3) /* IPL 16 Interrupt Summary */
357 1.5 mjacob #define TLINTRSUM_IPL15 (1 << 2) /* IPL 15 Interrupt Summary */
358 1.5 mjacob #define TLINTRSUM_IPL14 (1 << 1) /* IPL 14 Interrupt Summary */
359 1.5 mjacob #define TLINTRSUM_DUART (1 << 0) /* Duart Int (W1C) */
360 1.5 mjacob /* after checking the summaries, you can get the source node for each level */
361 1.5 mjacob #define TLINTRSUM_IPL17_SOURCE(x) ((x >> 22) & 0x1f)
362 1.5 mjacob #define TLINTRSUM_IPL16_SOURCE(x) ((x >> 17) & 0x1f)
363 1.5 mjacob #define TLINTRSUM_IPL15_SOURCE(x) ((x >> 12) & 0x1f)
364 1.5 mjacob #define TLINTRSUM_IPL14_SOURCE(x) ((x >> 7) & 0x1f)
365 1.4 mjacob
366 1.4 mjacob /*
367 1.4 mjacob * (some of) TurboLaser CPU ADG error register defines.
368 1.4 mjacob */
369 1.4 mjacob #define TLEPAERR_IBOX_TMO 0x1800 /* window space read failed */
370 1.4 mjacob #define TLEPAERR_WSPC_RD 0x0600 /* window space read failed */
371 1.4 mjacob
372 1.4 mjacob /*
373 1.4 mjacob * (some of) TurboLaser CPU DIGA error register defines.
374 1.4 mjacob */
375 1.4 mjacob #define TLEPDERR_GBTMO 0x4 /* GBus timeout */
376 1.4 mjacob
377 1.4 mjacob /*
378 1.4 mjacob * Platform specific uncorrectable machine check logout frame.
379 1.4 mjacob */
380 1.4 mjacob struct tlsb_mchk_fatal {
381 1.6 matt uint64_t rsvdheader;
382 1.6 matt uint32_t tldev;
383 1.6 matt uint32_t tlber;
384 1.6 matt uint32_t tlcnr;
385 1.6 matt uint32_t tlvid;
386 1.6 matt uint32_t tlesr0;
387 1.6 matt uint32_t tlesr1;
388 1.6 matt uint32_t tlesr2;
389 1.6 matt uint32_t tlesr3;
390 1.6 matt uint32_t tlepaerr;
391 1.6 matt uint32_t tlmodconfig;
392 1.6 matt uint32_t tlepmerr;
393 1.6 matt uint32_t tlepderr;
394 1.6 matt uint32_t tlintrmask0;
395 1.6 matt uint32_t tlintrmask1;
396 1.6 matt uint32_t tlintrsum0;
397 1.6 matt uint32_t tlintrsum1;
398 1.6 matt uint32_t tlep_vmg;
399 1.6 matt uint32_t spare[5];
400 1.4 mjacob };
401 1.4 mjacob /*
402 1.4 mjacob * Magic values from Digital Unix- if these bits are set in these
403 1.4 mjacob * registers in the fatal mcheck frame, then we *don't* take a look
404 1.4 mjacob * at system TLSB registers.
405 1.4 mjacob */
406 1.4 mjacob #define AERR_NO_TLSBSNAP 0x7B /* errors on bits TLEPAERR <6:3,1,0> */
407 1.4 mjacob #define DERR_NO_TLSBSNAP 0x07 /* errors on bits TLEPDERR <2:0> */
408 1.4 mjacob #define MERR_NO_TLSBSNAP 0x3F /* errors on bits TLEPMERR <5:0> */
409 1.4 mjacob
410 1.4 mjacob /*
411 1.4 mjacob * Platform specific correctable machine check logout frame.
412 1.4 mjacob */
413 1.4 mjacob struct tlsb_mchk_soft {
414 1.6 matt uint64_t rsvdheader;
415 1.6 matt uint32_t tldev;
416 1.6 matt uint32_t tlber;
417 1.6 matt uint32_t tlesr0;
418 1.6 matt uint32_t tlesr1;
419 1.6 matt uint32_t tlesr2;
420 1.6 matt uint32_t tlesr3;
421 1.4 mjacob };
422