|
|
1.1 root 1: /*
2: * Copyright (c) 1998-2000 Apple Computer, Inc. All rights reserved.
3: *
4: * @APPLE_LICENSE_HEADER_START@
5: *
6: * The contents of this file constitute Original Code as defined in and
7: * are subject to the Apple Public Source License Version 1.1 (the
8: * "License"). You may not use this file except in compliance with the
9: * License. Please obtain a copy of the License at
10: * http://www.apple.com/publicsource and read it before using this file.
11: *
12: * This Original Code and all software distributed under the License are
13: * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER
14: * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
15: * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
16: * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
17: * License for the specific language governing rights and limitations
18: * under the License.
19: *
20: * @APPLE_LICENSE_HEADER_END@
21: */
22: /*
23: * Copyright 1996 1995 by Open Software Foundation, Inc. 1997 1996 1995 1994 1993 1992 1991
24: * All Rights Reserved
25: *
26: * Permission to use, copy, modify, and distribute this software and
27: * its documentation for any purpose and without fee is hereby granted,
28: * provided that the above copyright notice appears in all copies and
29: * that both the copyright notice and this permission notice appear in
30: * supporting documentation.
31: *
32: * OSF DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE
33: * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
34: * FOR A PARTICULAR PURPOSE.
35: *
36: * IN NO EVENT SHALL OSF BE LIABLE FOR ANY SPECIAL, INDIRECT, OR
37: * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
38: * LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT,
39: * NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
40: * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
41: *
42: */
43: /*
44: * Copyright 1996 1995 by Apple Computer, Inc. 1997 1996 1995 1994 1993 1992 1991
45: * All Rights Reserved
46: *
47: * Permission to use, copy, modify, and distribute this software and
48: * its documentation for any purpose and without fee is hereby granted,
49: * provided that the above copyright notice appears in all copies and
50: * that both the copyright notice and this permission notice appear in
51: * supporting documentation.
52: *
53: * APPLE COMPUTER DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE
54: * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
55: * FOR A PARTICULAR PURPOSE.
56: *
57: * IN NO EVENT SHALL APPLE COMPUTER BE LIABLE FOR ANY SPECIAL, INDIRECT, OR
58: * CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
59: * LOSS OF USE, DATA OR PROFITS, WHETHER IN ACTION OF CONTRACT,
60: * NEGLIGENCE, OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION
61: * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
62: */
63: /*
64: * MKLINUX-1.0DR2
65: */
66: /*
67: * 18 June 1998 sdouglas
68: * Start IOKit version.
69: */
70:
71:
72: /*
73: File: via6522.h
74:
75: Contains: xxx put contents here xxx
76:
77: Written by: xxx put writers here xxx
78:
79: Copyright: � 1993, 1995 by Apple Computer, Inc., all rights reserved.
80:
81: Change History (most recent first):
82:
83: <1> 2/22/95 AM First checked in.
84: <1> 04/04/94 MRN First checked in.
85:
86: */
87:
88: /*
89: * Copyright 1987-91 Apple Computer, Inc.
90: * All Rights Reserved.
91: */
92:
93: #ifndef __VIA6522_H__
94: #define __VIA6522_H__
95:
96: /*
97: * Synertek SY6522 VIA Versatile Interface Adapter
98: */
99:
100: /*
101: * This has been modified to address BOTH the via and RBV registers,
102: * because we know that both chips ignore part of the address, thus
103: * only responding correctly. It's ugly, but the ROM does it...
104: */
105:
106: #if defined(powerc) || defined (__powerc)
107: #pragma options align=mac68k
108: #endif
109:
110: typedef struct via6522Regs /* VIA / RBV address */
111: {
112: volatile unsigned char vBufB; /* 0000/0000 register b */
113: volatile unsigned char RvExp; /* 0001 RBV future expansion */
114: volatile unsigned char RvSlotIFR; /* 0002 RBV Slot interrupts reg. */
115: volatile unsigned char RvIFR; /* 0003 RBV interrupt flag reg. */
116: unsigned char jnk0[ 12 ];
117:
118: volatile unsigned char RvMonP; /* xxxx/0010 RBV video monitor type */
119: volatile unsigned char RvChpT; /* xxxx/0011 RBV test mode register */
120: volatile unsigned char RvSlotIER; /* xxxx/0012 RBV slot interrupt enables */
121: volatile unsigned char RvIER; /* xxxx/0013 RBV interrupt flag enable reg */
122: unsigned char jnk1[ 0x1FF - 0x13 ];
123:
124: volatile unsigned char vBufAH; /* 0200 buffer a (with handshake). */
125: unsigned char jnk2[ 0x1FF ]; /* Dont use! Here only for completeness */
126:
127: volatile unsigned char vDIRB; /* 0400 data direction register B */
128: unsigned char jnk25[ 0x1FF ];
129:
130: volatile unsigned char vDIRA; /* 0600 data direction register A */
131: unsigned char jnk3[ 0x1FF ];
132:
133: volatile unsigned char vT1C; /* 0800 timer one low */
134: unsigned char jnk4[ 0x1FF ];
135:
136: volatile unsigned char vT1CH; /* 0A00 timer one high */
137: unsigned char jnk5[ 0x1FF ];
138:
139: volatile unsigned char vT1L; /* 0C00 timer one latches low */
140: unsigned char jnk6[ 0x1FF ];
141:
142: volatile unsigned char vT1LH; /* 0E00 timer one latches high */
143: unsigned char jnk7[ 0x1FF ];
144:
145: volatile unsigned char vT2C; /* 1000 timer 2 low */
146: unsigned char jnk8[ 0x1FF ];
147:
148: volatile unsigned char vT2CH; /* 1200 timer two counter high */
149: unsigned char jnk9[ 0x1FF ];
150:
151: volatile unsigned char vSR; /* 1400 shift register */
152: unsigned char jnka[ 0x1FF ];
153:
154: volatile unsigned char vACR; /* 1600 auxilary control register */
155: unsigned char jnkb[ 0x1FF ];
156:
157: volatile unsigned char vPCR; /* 1800 peripheral control register */
158: unsigned char jnkc[ 0x1FF ];
159:
160: volatile unsigned char vIFR; /* 1A00 interrupt flag register */
161: unsigned char jnkd[ 0x1FF ];
162:
163: volatile unsigned char vIER; /* 1C00 interrupt enable register */
164: unsigned char jnkf[ 0x1FF ];
165:
166: volatile unsigned char vBufA; /* 1E00 register A, read and write */
167: } via6522Regs;
168:
169: #if defined(powerc) || defined(__powerc)
170: #pragma options align=reset
171: #endif
172:
173:
174: /* Register B contents */
175:
176: #define VRB_POWEROFF 0x04 /* disk head select */
177: #define RBV_POWEROFF VRB_POWEROFF
178: #define VRB_BUSLOCK 0x02 /* NuBus Transactions are locked */
179:
180:
181: /* Register A contents */
182:
183: #define VRA_DRIVE 0x10 /* drive select */
184: #define VRA_HEAD 0x20 /* disk head select */
185:
186:
187: /* Auxillary control register contents */
188:
189: #define VAC_PAENL 0x01 /* Enable latch for PA */
190: #define VAC_PADISL 0x00 /* Disable latch for PA */
191: #define VAC_PBENL 0x02 /* Enable latch for PA */
192: #define VAC_PBDISL 0x00 /* Disable latch for PA */
193: #define VAC_SRDIS 0x00 /* Shift Reg Disabled */
194: #define VAC_SRMD1 0x04 /* Shift In under control of T2 */
195: #define VAC_SRMD2 0x08 /* Shift In under control of Phase 2 */
196: #define VAC_SRMD3 0x0C /* Shift in under control of Ext Clk */
197: #define VAC_SRMD4 0x10 /* Shift Out free running at T2 rate */
198: #define VAC_SRMD5 0x14 /* Shift Out under control of T2 */
199: #define VAC_SRMD6 0x18 /* Shift Out under control of theta2 */
200: #define VAC_SRMD7 0x1C /* Shift Out under control of Ext Clk */
201: #define VAC_T2CTL 0x20 /* Timer two, control */
202: #define VAC_T2TI 0x00 /* Timer Two, Timed Interrupt */
203: #define VAC_T2CD 0x20 /* Timer Two, count down with pulses on PB6 */
204: #define VAC_T1CONT 0x40 /* Timer one, continous counting */
205: #define VAC_T11SHOT 0x00 /* Timer One, one shot output */
206: #define VAC_T1PB7 0x80 /* Timer one, drives PB7 */
207: #define VAC_T1PB7DIS 0x00 /* Timer one, drives PB7 disabled */
208:
209:
210: /* Interrupt enable register contents */
211:
212: #define VIE_CA2 0x01 /* interrupt on CA2 */
213: #define VIE_CA1 0x02 /* interrupt on CA1 */
214: #define VIE_SR 0x04 /* Shift Register */
215: #define VIE_CB2 0x08 /* interrupt on CB2 */
216: #define VIE_CB1 0x10 /* interrupt on CB1 */
217: #define VIE_TIM2 0x20 /* timer 2 interrupt */
218: #define VIE_TIM1 0x40 /* timer 1 interrupt */
219: #define VIE_SET 0x80 /* Set interrupt bits if this is on */
220: #define VIE_CLEAR 0x00 /* Clear bits if used */
221:
222: #define VIE_ALL ( VIE_TIM1 | VIE_TIM2 | VIE_CB1 | VIE_CB2 | VIE_SR | VIE_CA1 | VIE_CA2 )
223:
224:
225: /* VIA Data Direction Register Contents */
226:
227: #define VDR_P7_O 0x80 /* P7 is output */
228: #define VDR_P7_I 0x00 /* P7 is input */
229: #define VDR_P6_O 0x40 /* P6 is output */
230: #define VDR_P6_I 0x00 /* P6 is input */
231: #define VDR_P5_O 0x20 /* P5 is output */
232: #define VDR_P5_I 0x00 /* P5 is input */
233: #define VDR_P4_O 0x10 /* P4 is output */
234: #define VDR_P4_I 0x00 /* P4 is input */
235: #define VDR_P3_O 0x08 /* P3 is output */
236: #define VDR_P3_I 0x00 /* P3 is input */
237: #define VDR_P2_O 0x04 /* P2 is output */
238: #define VDR_P2_I 0x00 /* P2 is input */
239: #define VDR_P1_O 0x02 /* P1 is output */
240: #define VDR_P1_I 0x00 /* P1 is input */
241: #define VDR_P0_O 0x01 /* P0 is output */
242: #define VDR_P0_I 0x00 /* P0 is input */
243:
244:
245: /* VIA1 Register A contents where they differ from standard VIA1 */
246:
247: #define RBV_BURNIN 0x01 /* burnin flag */
248: #define RBV_CPUID0 0x02 /* CPU id bit 0 */
249: #define RBV_CPUID1 0x04 /* CPU id bit 1 */
250: #define RBV_CPUID2 0x10 /* CPU id bit 2 */
251: #define RBV_CPUID3 0x40 /* CPU id bit 3 */
252:
253:
254: /* VIA1 Register B contents where they differ from standard VIA1 */
255:
256: #define RBV_PARDIS 0x40 /* disable parity */
257: #define RBV_PAROK 0x80 /* parity OK */
258:
259: #define EVRB_XCVR 0x08 /* XCVR_SESSION* */
260: #define EVRB_FULL 0x10 /* VIA_FULL */
261: #define EVRB_SYSES 0x20 /* SYS_SESSION */
262: #define EVRB_AUXIE 0x00 /* Enable A/UX Interrupt Scheme */
263: #define EVRB_AUXID 0x40 /* Disable A/UX Interrupt Scheme */
264: #define EVRB_SFTWRIE 0x00 /* Software Interrupt ReQuest */
265: #define EVRB_SFTWRID 0x80 /* Software Interrupt ReQuest */
266:
267:
268: /* VIA2 Register A contents where they differ from standard VIA2 */
269:
270: #define RBV_SZEROIRQ 0x40 /* slot 0 irq */
271: #define EVRA_ENETIRQ 0x01 /* Ethernet irq */
272: #define EVRA_VIDIRQ 0x40 /* Video irq */
273:
274:
275: /* VIA2 Register B contents where they differ from standard VIA2 */
276:
277: #define RBV_CDIS 0x01 /* disable external cache */
278: #define RBV_CFLUSH 0x08 /* flush external cache */
279: #define EVRB_LED 0x10 /* LED */
280: #define RBV_PARODD 0x80 /* 1 for odd, 0 for even */
281:
282:
283: /* Video monitor parameters: */
284: #define RBV_DEPTH 0x07 /* bits per pixel: 000=1,001=2,010=4,011=8 */
285: #define RBV_MONID 0x38 /* monitor type as below */
286: #define RBV_VIDOFF 0x40 /* 1 turns off onboard video */
287:
288:
289: /* Supported video monitor types: */
290:
291: #define MON_15BW ( 1 << 3 ) /* 15" BW portrait */
292: #define MON_IIGS ( 2 << 3 ) /* modified IIGS monitor */
293: #define MON_15RGB ( 5 << 3 ) /* 15" RGB portrait */
294: #define MON_12OR13 ( 6 << 3 ) /* 12" BW or 13" RGB */
295: #define MON_NONE ( 7 << 3 ) /* No monitor attached */
296:
297: #endif /* __VIA6522_H__ */
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.