Linux-2.6.12-rc2
[linux-2.6/linux-acpi-2.6/ibm-acpi-2.6.git] / drivers / char / rio / cirrus.h
blobcf056a990f185b8506027037c2abaaf83aa05579
1 /****************************************************************************
2 ******* *******
3 ******* CIRRUS.H *******
4 ******* *******
5 ****************************************************************************
7 Author : Jeremy Rolls
8 Date : 3 Aug 1990
11 * (C) 1990 - 2000 Specialix International Ltd., Byfleet, Surrey, UK.
13 * This program is free software; you can redistribute it and/or modify
14 * it under the terms of the GNU General Public License as published by
15 * the Free Software Foundation; either version 2 of the License, or
16 * (at your option) any later version.
18 * This program is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU General Public License for more details.
23 * You should have received a copy of the GNU General Public License
24 * along with this program; if not, write to the Free Software
25 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
27 Version : 0.01
30 Mods
31 ----------------------------------------------------------------------------
32 Date By Description
33 ----------------------------------------------------------------------------
35 ***************************************************************************/
37 #ifndef _cirrus_h
38 #ifndef lint
39 /* static char* _cirrus_h_sccs = "@(#)cirrus.h 1.16"; */
40 #endif
41 #define _cirrus_h 1
43 #ifdef RTA
44 #define TO_UART RX
45 #define TO_DRIVER TX
46 #endif
48 #ifdef HOST
49 #define TO_UART TX
50 #define TO_DRIVER RX
51 #endif
52 #ifdef RTA
53 /* Miscellaneous defines for CIRRUS addresses and related logic for
54 interrupts etc.
56 #define MAP(a) ((short *)(cirrus_base + (a)))
57 #define outp(a,b) (*MAP (a) =(b))
58 #define inp(a) ((*MAP (a)) & 0xff)
59 #define CIRRUS_FIRST (short*)0x7300
60 #define CIRRUS_SECOND (short*)0x7200
61 #define CIRRUS_THIRD (short*)0x7100
62 #define CIRRUS_FOURTH (short*)0x7000
63 #define PORTS_ON_CIRRUS 4
64 #define CIRRUS_FIFO_SIZE 12
65 #define SPACE 0x20
66 #define TAB 0x09
67 #define LINE_FEED 0x0a
68 #define CARRIAGE_RETURN 0x0d
69 #define BACKSPACE 0x08
70 #define SPACES_IN_TABS 8
71 #define SEND_ESCAPE 0x00
72 #define START_BREAK 0x81
73 #define TIMER_TICK 0x82
74 #define STOP_BREAK 0x83
75 #define BASE(a) ((a) < 4 ? (short*)CIRRUS_FIRST : ((a) < 8 ? (short *)CIRRUS_SECOND : ((a) < 12 ? (short*)CIRRUS_THIRD : (short *)CIRRUS_FOURTH)))
76 #define txack1 ((short *)0x7104)
77 #define rxack1 ((short *)0x7102)
78 #define mdack1 ((short *)0x7106)
79 #define txack2 ((short *)0x7006)
80 #define rxack2 ((short *)0x7004)
81 #define mdack2 ((short *)0x7100)
82 #define int_latch ((short *) 0x7800)
83 #define int_status ((short *) 0x7c00)
84 #define tx1_pending 0x20
85 #define rx1_pending 0x10
86 #define md1_pending 0x40
87 #define tx2_pending 0x02
88 #define rx2_pending 0x01
89 #define md2_pending 0x40
90 #define module1_bits 0x07
91 #define module1_modern 0x08
92 #define module2_bits 0x70
93 #define module2_modern 0x80
94 #define module_blank 0xf
95 #define rs232_d25 0x0
96 #define rs232_rj45 0x1
97 #define rs422_d25 0x3
98 #define parallel 0x5
100 #define CLK0 0x00
101 #define CLK1 0x01
102 #define CLK2 0x02
103 #define CLK3 0x03
104 #define CLK4 0x04
106 #define CIRRUS_REVC 0x42
107 #define CIRRUS_REVE 0x44
109 #define TURNON 1
110 #define TURNOFF 0
112 /* The list of CIRRUS registers.
113 NB. These registers are relative values on 8 bit boundaries whereas
114 on the RTA's the CIRRUS registers are on word boundaries. Use pointer
115 arithmetic (short *) to obtain the real addresses required */
116 #define ccr 0x05 /* Channel Command Register */
117 #define ier 0x06 /* Interrupt Enable Register */
118 #define cor1 0x08 /* Channel Option Register 1 */
119 #define cor2 0x09 /* Channel Option Register 2 */
120 #define cor3 0x0a /* Channel Option Register 3 */
121 #define cor4 0x1e /* Channel Option Register 4 */
122 #define cor5 0x1f /* Channel Option Register 5 */
124 #define ccsr 0x0b /* Channel Control Status Register */
125 #define rdcr 0x0e /* Receive Data Count Register */
126 #define tdcr 0x12 /* Transmit Data Count Register */
127 #define mcor1 0x15 /* Modem Change Option Register 1 */
128 #define mcor2 0x16 /* Modem Change Option Regsiter 2 */
130 #define livr 0x18 /* Local Interrupt Vector Register */
131 #define schr1 0x1a /* Special Character Register 1 */
132 #define schr2 0x1b /* Special Character Register 2 */
133 #define schr3 0x1c /* Special Character Register 3 */
134 #define schr4 0x1d /* Special Character Register 4 */
136 #define rtr 0x20 /* Receive Timer Register */
137 #define rtpr 0x21 /* Receive Timeout Period Register */
138 #define lnc 0x24 /* Lnext character */
140 #define rivr 0x43 /* Receive Interrupt Vector Register */
141 #define tivr 0x42 /* Transmit Interrupt Vector Register */
142 #define mivr 0x41 /* Modem Interrupt Vector Register */
143 #define gfrcr 0x40 /* Global Firmware Revision code Reg */
144 #define ricr 0x44 /* Receive Interrupting Channel Reg */
145 #define ticr 0x45 /* Transmit Interrupting Channel Reg */
146 #define micr 0x46 /* Modem Interrupting Channel Register */
148 #define gcr 0x4b /* Global configuration register*/
149 #define misr 0x4c /* Modem interrupt status register */
151 #define rbusr 0x59
152 #define tbusr 0x5a
153 #define mbusr 0x5b
155 #define eoir 0x60 /* End Of Interrupt Register */
156 #define rdsr 0x62 /* Receive Data / Status Register */
157 #define tdr 0x63 /* Transmit Data Register */
158 #define svrr 0x67 /* Service Request Register */
160 #define car 0x68 /* Channel Access Register */
161 #define mir 0x69 /* Modem Interrupt Register */
162 #define tir 0x6a /* Transmit Interrupt Register */
163 #define rir 0x6b /* Receive Interrupt Register */
164 #define msvr1 0x6c /* Modem Signal Value Register 1 */
165 #define msvr2 0x6d /* Modem Signal Value Register 2*/
166 #define psvr 0x6f /* Printer Signal Value Register*/
168 #define tbpr 0x72 /* Transmit Baud Rate Period Register */
169 #define tcor 0x76 /* Transmit Clock Option Register */
171 #define rbpr 0x78 /* Receive Baud Rate Period Register */
172 #define rber 0x7a /* Receive Baud Rate Extension Register */
173 #define rcor 0x7c /* Receive Clock Option Register*/
174 #define ppr 0x7e /* Prescalar Period Register */
176 /* Misc registers used for forcing the 1400 out of its reset woes */
177 #define airl 0x6d
178 #define airm 0x6e
179 #define airh 0x6f
180 #define btcr 0x66
181 #define mtcr 0x6c
182 #define tber 0x74
184 #endif /* #ifdef RTA */
187 /* Bit fields for particular registers */
189 /* GCR */
190 #define GCR_SERIAL 0x00 /* Configure as serial channel */
191 #define GCR_PARALLEL 0x80 /* Configure as parallel channel */
193 /* RDSR - when status read from FIFO */
194 #define RDSR_BREAK 0x08 /* Break received */
195 #define RDSR_TIMEOUT 0x80 /* No new data timeout */
196 #define RDSR_SC1 0x10 /* Special char 1 (tx XON) matched */
197 #define RDSR_SC2 0x20 /* Special char 2 (tx XOFF) matched */
198 #define RDSR_SC12_MASK 0x30 /* Mask for special chars 1 and 2 */
200 /* PPR */
201 #define PPR_DEFAULT 0x31 /* Default value - for a 25Mhz clock gives
202 a timeout period of 1ms */
204 /* LIVR */
205 #define LIVR_EXCEPTION 0x07 /* Receive exception interrupt */
207 /* CCR */
208 #define CCR_RESET 0x80 /* Reset channel */
209 #define CCR_CHANGE 0x4e /* COR's have changed - NB always change all
210 COR's */
211 #define CCR_WFLUSH 0x82 /* Flush transmit FIFO and TSR / THR */
213 #define CCR_SENDSC1 0x21 /* Send special character one */
214 #define CCR_SENDSC2 0x22 /* Send special character two */
215 #define CCR_SENDSC3 0x23 /* Send special character three */
216 #define CCR_SENDSC4 0x24 /* Send special character four */
218 #define CCR_TENABLE 0x18 /* Enable transmitter */
219 #define CCR_TDISABLE 0x14 /* Disable transmitter */
220 #define CCR_RENABLE 0x12 /* Enable receiver */
221 #define CCR_RDISABLE 0x11 /* Disable receiver */
223 #define CCR_READY 0x00 /* CCR is ready for another command */
225 /* CCSR */
226 #define CCSR_TXENABLE 0x08 /* Transmitter enable */
227 #define CCSR_RXENABLE 0x80 /* Receiver enable */
228 #define CCSR_TXFLOWOFF 0x04 /* Transmit flow off */
229 #define CCSR_TXFLOWON 0x02 /* Transmit flow on */
231 /* SVRR */
232 #define SVRR_RECEIVE 0x01 /* Receive interrupt pending */
233 #define SVRR_TRANSMIT 0x02 /* Transmit interrupt pending */
234 #define SVRR_MODEM 0x04 /* Modem interrupt pending */
236 /* CAR */
237 #define CAR_PORTS 0x03 /* Bit fields for ports */
239 /* IER */
240 #define IER_MODEM 0x80 /* Change in modem status */
241 #define IER_RECEIVE 0x10 /* Good data / data exception */
242 #define IER_TRANSMITR 0x04 /* Transmit ready (FIFO empty) */
243 #define IER_TRANSMITE 0x02 /* Transmit empty */
244 #define IER_TIMEOUT 0x01 /* Timeout on no data */
246 #define IER_DEFAULT 0x94 /* Default values */
247 #define IER_PARALLEL 0x84 /* Default for Parallel */
248 #define IER_EMPTY 0x92 /* Transmitter empty rather than ready */
250 /* COR1 - Driver only */
251 #define COR1_INPCK 0x10 /* Check parity of received characters */
253 /* COR1 - driver and RTA */
254 #define COR1_ODD 0x80 /* Odd parity */
255 #define COR1_EVEN 0x00 /* Even parity */
256 #define COR1_NOP 0x00 /* No parity */
257 #define COR1_FORCE 0x20 /* Force parity */
258 #define COR1_NORMAL 0x40 /* With parity */
259 #define COR1_1STOP 0x00 /* 1 stop bit */
260 #define COR1_15STOP 0x04 /* 1.5 stop bits */
261 #define COR1_2STOP 0x08 /* 2 stop bits */
262 #define COR1_5BITS 0x00 /* 5 data bits */
263 #define COR1_6BITS 0x01 /* 6 data bits */
264 #define COR1_7BITS 0x02 /* 7 data bits */
265 #define COR1_8BITS 0x03 /* 8 data bits */
267 #define COR1_HOST 0xef /* Safe host bits */
269 /* RTA only */
270 #define COR1_CINPCK 0x00 /* Check parity of received characters */
271 #define COR1_CNINPCK 0x10 /* Don't check parity */
273 /* COR2 bits for both RTA and driver use */
274 #define COR2_IXANY 0x80 /* IXANY - any character is XON */
275 #define COR2_IXON 0x40 /* IXON - enable tx soft flowcontrol */
276 #define COR2_RTSFLOW 0x02 /* Enable tx hardware flow control */
278 /* Additional driver bits */
279 #define COR2_HUPCL 0x20 /* Hang up on close */
280 #define COR2_CTSFLOW 0x04 /* Enable rx hardware flow control */
281 #define COR2_IXOFF 0x01 /* Enable rx software flow control */
282 #define COR2_DTRFLOW 0x08 /* Enable tx hardware flow control */
284 /* RTA use only */
285 #define COR2_ETC 0x20 /* Embedded transmit options */
286 #define COR2_LOCAL 0x10 /* Local loopback mode */
287 #define COR2_REMOTE 0x08 /* Remote loopback mode */
288 #define COR2_HOST 0xc2 /* Safe host bits */
290 /* COR3 - RTA use only */
291 #define COR3_SCDRNG 0x80 /* Enable special char detect for range */
292 #define COR3_SCD34 0x40 /* Special character detect for SCHR's 3 + 4 */
293 #define COR3_FCT 0x20 /* Flow control transparency */
294 #define COR3_SCD12 0x10 /* Special character detect for SCHR's 1 + 2 */
295 #define COR3_FIFO12 0x0c /* 12 chars for receive FIFO threshold */
296 #define COR3_FIFO10 0x0a /* 10 chars for receive FIFO threshold */
297 #define COR3_FIFO8 0x08 /* 8 chars for receive FIFO threshold */
298 #define COR3_FIFO6 0x06 /* 6 chars for receive FIFO threshold */
300 #define COR3_THRESHOLD COR3_FIFO8 /* MUST BE LESS THAN MCOR_THRESHOLD */
302 #define COR3_DEFAULT (COR3_FCT | COR3_THRESHOLD)
303 /* Default bits for COR3 */
305 /* COR4 driver and RTA use */
306 #define COR4_IGNCR 0x80 /* Throw away CR's on input */
307 #define COR4_ICRNL 0x40 /* Map CR -> NL on input */
308 #define COR4_INLCR 0x20 /* Map NL -> CR on input */
309 #define COR4_IGNBRK 0x10 /* Ignore Break */
310 #define COR4_NBRKINT 0x08 /* No interrupt on break (-BRKINT) */
311 #define COR4_RAISEMOD 0x01 /* Raise modem output lines on non-zero baud */
314 /* COR4 driver only */
315 #define COR4_IGNPAR 0x04 /* IGNPAR (ignore characters with errors) */
316 #define COR4_PARMRK 0x02 /* PARMRK */
318 #define COR4_HOST 0xf8 /* Safe host bits */
320 /* COR4 RTA only */
321 #define COR4_CIGNPAR 0x02 /* Thrown away bad characters */
322 #define COR4_CPARMRK 0x04 /* PARMRK characters */
323 #define COR4_CNPARMRK 0x03 /* Don't PARMRK */
325 /* COR5 driver and RTA use */
326 #define COR5_ISTRIP 0x80 /* Strip input chars to 7 bits */
327 #define COR5_LNE 0x40 /* Enable LNEXT processing */
328 #define COR5_CMOE 0x20 /* Match good and errored characters */
329 #define COR5_ONLCR 0x02 /* NL -> CR NL on output */
330 #define COR5_OCRNL 0x01 /* CR -> NL on output */
333 ** Spare bits - these are not used in the CIRRUS registers, so we use
334 ** them to set various other features.
337 ** tstop and tbusy indication
339 #define COR5_TSTATE_ON 0x08 /* Turn on monitoring of tbusy and tstop */
340 #define COR5_TSTATE_OFF 0x04 /* Turn off monitoring of tbusy and tstop */
342 ** TAB3
344 #define COR5_TAB3 0x10 /* TAB3 mode */
346 #define COR5_HOST 0xc3 /* Safe host bits */
348 /* CCSR */
349 #define CCSR_TXFLOFF 0x04 /* Tx is xoffed */
351 /* MSVR1 */
352 /* NB. DTR / CD swapped from Cirrus spec as the pins are also reversed on the
353 RTA. This is because otherwise DCD would get lost on the 1 parallel / 3
354 serial option.
356 #define MSVR1_CD 0x80 /* CD (DSR on Cirrus) */
357 #define MSVR1_RTS 0x40 /* RTS (CTS on Cirrus) */
358 #define MSVR1_RI 0x20 /* RI */
359 #define MSVR1_DTR 0x10 /* DTR (CD on Cirrus) */
360 #define MSVR1_CTS 0x01 /* CTS output pin (RTS on Cirrus) */
361 /* Next two used to indicate state of tbusy and tstop to driver */
362 #define MSVR1_TSTOP 0x08 /* Set if port flow controlled */
363 #define MSVR1_TEMPTY 0x04 /* Set if port tx buffer empty */
365 #define MSVR1_HOST 0xf3 /* The bits the host wants */
367 /* MSVR2 */
368 #define MSVR2_DSR 0x02 /* DSR output pin (DTR on Cirrus) */
370 /* MCOR */
371 #define MCOR_CD 0x80 /* CD (DSR on Cirrus) */
372 #define MCOR_RTS 0x40 /* RTS (CTS on Cirrus) */
373 #define MCOR_RI 0x20 /* RI */
374 #define MCOR_DTR 0x10 /* DTR (CD on Cirrus) */
376 #define MCOR_DEFAULT (MCOR_CD | MCOR_RTS | MCOR_RI | MCOR_DTR)
377 #define MCOR_FULLMODEM MCOR_DEFAULT
378 #define MCOR_RJ45 (MCOR_CD | MCOR_RTS | MCOR_DTR)
379 #define MCOR_RESTRICTED (MCOR_CD | MCOR_RTS)
381 /* More MCOR - H/W Handshake (flowcontrol) stuff */
382 #define MCOR_THRESH8 0x08 /* eight characters then we stop */
383 #define MCOR_THRESH9 0x09 /* nine characters then we stop */
384 #define MCOR_THRESH10 0x0A /* ten characters then we stop */
385 #define MCOR_THRESH11 0x0B /* eleven characters then we stop */
387 #define MCOR_THRESHBITS 0x0F /* mask for ANDing out the above */
389 #define MCOR_THRESHOLD MCOR_THRESH9 /* MUST BE GREATER THAN COR3_THRESHOLD */
392 /* RTPR */
393 #define RTPR_DEFAULT 0x02 /* Default */
396 /* Defines for the subscripts of a CONFIG packet */
397 #define CONFIG_COR1 1 /* Option register 1 */
398 #define CONFIG_COR2 2 /* Option register 2 */
399 #define CONFIG_COR4 3 /* Option register 4 */
400 #define CONFIG_COR5 4 /* Option register 5 */
401 #define CONFIG_TXXON 5 /* Tx XON character */
402 #define CONFIG_TXXOFF 6 /* Tx XOFF character */
403 #define CONFIG_RXXON 7 /* Rx XON character */
404 #define CONFIG_RXXOFF 8 /* Rx XOFF character */
405 #define CONFIG_LNEXT 9 /* LNEXT character */
406 #define CONFIG_TXBAUD 10 /* Tx baud rate */
407 #define CONFIG_RXBAUD 11 /* Rx baud rate */
409 /* Port status stuff */
410 #define IDLE_CLOSED 0 /* Closed */
411 #define IDLE_OPEN 1 /* Idle open */
412 #define IDLE_BREAK 2 /* Idle on break */
414 /* Subscript of MODEM STATUS packet */
415 #define MODEM_VALUE 3 /* Current values of handshake pins */
416 /* Subscript of SBREAK packet */
417 #define BREAK_LENGTH 1 /* Length of a break in slices of 0.01 seconds
418 0 = stay on break until an EBREAK command
419 is sent */
422 #define PRE_EMPTIVE 0x80 /* Pre-emptive bit in command field */
424 /* Packet types going from Host to remote - with the exception of OPEN, MOPEN,
425 CONFIG, SBREAK and MEMDUMP the remaining bytes of the data array will not
426 be used
428 #define OPEN 0x00 /* Open a port */
429 #define CONFIG 0x01 /* Configure a port */
430 #define MOPEN 0x02 /* Modem open (block for DCD) */
431 #define CLOSE 0x03 /* Close a port */
432 #define WFLUSH (0x04 | PRE_EMPTIVE) /* Write flush */
433 #define RFLUSH (0x05 | PRE_EMPTIVE) /* Read flush */
434 #define RESUME (0x06 | PRE_EMPTIVE) /* Resume if xoffed */
435 #define SBREAK 0x07 /* Start break */
436 #define EBREAK 0x08 /* End break */
437 #define SUSPEND (0x09 | PRE_EMPTIVE) /* Susp op (behave as tho xoffed) */
438 #define FCLOSE (0x0a | PRE_EMPTIVE) /* Force close */
439 #define XPRINT 0x0b /* Xprint packet */
440 #define MBIS (0x0c | PRE_EMPTIVE) /* Set modem lines */
441 #define MBIC (0x0d | PRE_EMPTIVE) /* Clear modem lines */
442 #define MSET (0x0e | PRE_EMPTIVE) /* Set modem lines */
443 #define PCLOSE 0x0f /* Pseudo close - Leaves rx/tx enabled */
444 #define MGET (0x10 | PRE_EMPTIVE) /* Force update of modem status */
445 #define MEMDUMP (0x11 | PRE_EMPTIVE) /* Send back mem from addr supplied */
446 #define READ_REGISTER (0x12 | PRE_EMPTIVE) /* Read CD1400 register (debug) */
448 /* "Command" packets going from remote to host COMPLETE and MODEM_STATUS
449 use data[4] / data[3] to indicate current state and modem status respectively
452 #define COMPLETE (0x20 | PRE_EMPTIVE)
453 /* Command complete */
454 #define BREAK_RECEIVED (0x21 | PRE_EMPTIVE)
455 /* Break received */
456 #define MODEM_STATUS (0x22 | PRE_EMPTIVE)
457 /* Change in modem status */
459 /* "Command" packet that could go either way - handshake wake-up */
460 #define HANDSHAKE (0x23 | PRE_EMPTIVE)
461 /* Wake-up to HOST / RTA */
463 #endif