]>
git.saurik.com Git - apple/xnu.git/blob - iokit/Drivers/platform/drvAppleCuda/AppleVIA6522.h
2 * Copyright (c) 1998-2000 Apple Computer, Inc. All rights reserved.
4 * @APPLE_LICENSE_HEADER_START@
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.
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
20 * @APPLE_LICENSE_HEADER_END@
23 * Copyright 1996 1995 by Open Software Foundation, Inc. 1997 1996 1995 1994 1993 1992 1991
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.
32 * OSF DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE
33 * INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
34 * FOR A PARTICULAR PURPOSE.
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.
44 * Copyright 1996 1995 by Apple Computer, Inc. 1997 1996 1995 1994 1993 1992 1991
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.
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.
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.
67 * 18 June 1998 sdouglas
68 * Start IOKit version.
75 Contains: xxx put contents here xxx
77 Written by: xxx put writers here xxx
79 Copyright: © 1993, 1995 by Apple Computer, Inc., all rights reserved.
81 Change History (most recent first):
83 <1> 2/22/95 AM First checked in.
84 <1> 04/04/94 MRN First checked in.
89 * Copyright 1987-91 Apple Computer, Inc.
90 * All Rights Reserved.
97 * Synertek SY6522 VIA Versatile Interface Adapter
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...
106 #if defined(powerc) || defined (__powerc)
107 #pragma options align=mac68k
110 typedef struct via6522Regs
/* VIA / RBV address */
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 ];
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 ];
124 volatile unsigned char vBufAH
; /* 0200 buffer a (with handshake). */
125 unsigned char jnk2
[ 0x1FF ]; /* Dont use! Here only for completeness */
127 volatile unsigned char vDIRB
; /* 0400 data direction register B */
128 unsigned char jnk25
[ 0x1FF ];
130 volatile unsigned char vDIRA
; /* 0600 data direction register A */
131 unsigned char jnk3
[ 0x1FF ];
133 volatile unsigned char vT1C
; /* 0800 timer one low */
134 unsigned char jnk4
[ 0x1FF ];
136 volatile unsigned char vT1CH
; /* 0A00 timer one high */
137 unsigned char jnk5
[ 0x1FF ];
139 volatile unsigned char vT1L
; /* 0C00 timer one latches low */
140 unsigned char jnk6
[ 0x1FF ];
142 volatile unsigned char vT1LH
; /* 0E00 timer one latches high */
143 unsigned char jnk7
[ 0x1FF ];
145 volatile unsigned char vT2C
; /* 1000 timer 2 low */
146 unsigned char jnk8
[ 0x1FF ];
148 volatile unsigned char vT2CH
; /* 1200 timer two counter high */
149 unsigned char jnk9
[ 0x1FF ];
151 volatile unsigned char vSR
; /* 1400 shift register */
152 unsigned char jnka
[ 0x1FF ];
154 volatile unsigned char vACR
; /* 1600 auxilary control register */
155 unsigned char jnkb
[ 0x1FF ];
157 volatile unsigned char vPCR
; /* 1800 peripheral control register */
158 unsigned char jnkc
[ 0x1FF ];
160 volatile unsigned char vIFR
; /* 1A00 interrupt flag register */
161 unsigned char jnkd
[ 0x1FF ];
163 volatile unsigned char vIER
; /* 1C00 interrupt enable register */
164 unsigned char jnkf
[ 0x1FF ];
166 volatile unsigned char vBufA
; /* 1E00 register A, read and write */
169 #if defined(powerc) || defined(__powerc)
170 #pragma options align=reset
174 /* Register B contents */
176 #define VRB_POWEROFF 0x04 /* disk head select */
177 #define RBV_POWEROFF VRB_POWEROFF
178 #define VRB_BUSLOCK 0x02 /* NuBus Transactions are locked */
181 /* Register A contents */
183 #define VRA_DRIVE 0x10 /* drive select */
184 #define VRA_HEAD 0x20 /* disk head select */
187 /* Auxillary control register contents */
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 */
210 /* Interrupt enable register contents */
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 */
222 #define VIE_ALL ( VIE_TIM1 | VIE_TIM2 | VIE_CB1 | VIE_CB2 | VIE_SR | VIE_CA1 | VIE_CA2 )
225 /* VIA Data Direction Register Contents */
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 */
245 /* VIA1 Register A contents where they differ from standard VIA1 */
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 */
254 /* VIA1 Register B contents where they differ from standard VIA1 */
256 #define RBV_PARDIS 0x40 /* disable parity */
257 #define RBV_PAROK 0x80 /* parity OK */
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 */
268 /* VIA2 Register A contents where they differ from standard VIA2 */
270 #define RBV_SZEROIRQ 0x40 /* slot 0 irq */
271 #define EVRA_ENETIRQ 0x01 /* Ethernet irq */
272 #define EVRA_VIDIRQ 0x40 /* Video irq */
275 /* VIA2 Register B contents where they differ from standard VIA2 */
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 */
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 */
289 /* Supported video monitor types: */
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 */
297 #endif /* __VIA6522_H__ */