diff options
Diffstat (limited to 'drivers/char/rio/cirrus.h')
-rw-r--r-- | drivers/char/rio/cirrus.h | 210 |
1 files changed, 0 insertions, 210 deletions
diff --git a/drivers/char/rio/cirrus.h b/drivers/char/rio/cirrus.h deleted file mode 100644 index 5ab51679caa2..000000000000 --- a/drivers/char/rio/cirrus.h +++ /dev/null | |||
@@ -1,210 +0,0 @@ | |||
1 | /**************************************************************************** | ||
2 | ******* ******* | ||
3 | ******* CIRRUS.H ******* | ||
4 | ******* ******* | ||
5 | **************************************************************************** | ||
6 | |||
7 | Author : Jeremy Rolls | ||
8 | Date : 3 Aug 1990 | ||
9 | |||
10 | * | ||
11 | * (C) 1990 - 2000 Specialix International Ltd., Byfleet, Surrey, UK. | ||
12 | * | ||
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. | ||
17 | * | ||
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. | ||
22 | * | ||
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. | ||
26 | |||
27 | Version : 0.01 | ||
28 | |||
29 | |||
30 | Mods | ||
31 | ---------------------------------------------------------------------------- | ||
32 | Date By Description | ||
33 | ---------------------------------------------------------------------------- | ||
34 | |||
35 | ***************************************************************************/ | ||
36 | |||
37 | #ifndef _cirrus_h | ||
38 | #define _cirrus_h 1 | ||
39 | |||
40 | /* Bit fields for particular registers shared with driver */ | ||
41 | |||
42 | /* COR1 - driver and RTA */ | ||
43 | #define RIOC_COR1_ODD 0x80 /* Odd parity */ | ||
44 | #define RIOC_COR1_EVEN 0x00 /* Even parity */ | ||
45 | #define RIOC_COR1_NOP 0x00 /* No parity */ | ||
46 | #define RIOC_COR1_FORCE 0x20 /* Force parity */ | ||
47 | #define RIOC_COR1_NORMAL 0x40 /* With parity */ | ||
48 | #define RIOC_COR1_1STOP 0x00 /* 1 stop bit */ | ||
49 | #define RIOC_COR1_15STOP 0x04 /* 1.5 stop bits */ | ||
50 | #define RIOC_COR1_2STOP 0x08 /* 2 stop bits */ | ||
51 | #define RIOC_COR1_5BITS 0x00 /* 5 data bits */ | ||
52 | #define RIOC_COR1_6BITS 0x01 /* 6 data bits */ | ||
53 | #define RIOC_COR1_7BITS 0x02 /* 7 data bits */ | ||
54 | #define RIOC_COR1_8BITS 0x03 /* 8 data bits */ | ||
55 | |||
56 | #define RIOC_COR1_HOST 0xef /* Safe host bits */ | ||
57 | |||
58 | /* RTA only */ | ||
59 | #define RIOC_COR1_CINPCK 0x00 /* Check parity of received characters */ | ||
60 | #define RIOC_COR1_CNINPCK 0x10 /* Don't check parity */ | ||
61 | |||
62 | /* COR2 bits for both RTA and driver use */ | ||
63 | #define RIOC_COR2_IXANY 0x80 /* IXANY - any character is XON */ | ||
64 | #define RIOC_COR2_IXON 0x40 /* IXON - enable tx soft flowcontrol */ | ||
65 | #define RIOC_COR2_RTSFLOW 0x02 /* Enable tx hardware flow control */ | ||
66 | |||
67 | /* Additional driver bits */ | ||
68 | #define RIOC_COR2_HUPCL 0x20 /* Hang up on close */ | ||
69 | #define RIOC_COR2_CTSFLOW 0x04 /* Enable rx hardware flow control */ | ||
70 | #define RIOC_COR2_IXOFF 0x01 /* Enable rx software flow control */ | ||
71 | #define RIOC_COR2_DTRFLOW 0x08 /* Enable tx hardware flow control */ | ||
72 | |||
73 | /* RTA use only */ | ||
74 | #define RIOC_COR2_ETC 0x20 /* Embedded transmit options */ | ||
75 | #define RIOC_COR2_LOCAL 0x10 /* Local loopback mode */ | ||
76 | #define RIOC_COR2_REMOTE 0x08 /* Remote loopback mode */ | ||
77 | #define RIOC_COR2_HOST 0xc2 /* Safe host bits */ | ||
78 | |||
79 | /* COR3 - RTA use only */ | ||
80 | #define RIOC_COR3_SCDRNG 0x80 /* Enable special char detect for range */ | ||
81 | #define RIOC_COR3_SCD34 0x40 /* Special character detect for SCHR's 3 + 4 */ | ||
82 | #define RIOC_COR3_FCT 0x20 /* Flow control transparency */ | ||
83 | #define RIOC_COR3_SCD12 0x10 /* Special character detect for SCHR's 1 + 2 */ | ||
84 | #define RIOC_COR3_FIFO12 0x0c /* 12 chars for receive FIFO threshold */ | ||
85 | #define RIOC_COR3_FIFO10 0x0a /* 10 chars for receive FIFO threshold */ | ||
86 | #define RIOC_COR3_FIFO8 0x08 /* 8 chars for receive FIFO threshold */ | ||
87 | #define RIOC_COR3_FIFO6 0x06 /* 6 chars for receive FIFO threshold */ | ||
88 | |||
89 | #define RIOC_COR3_THRESHOLD RIOC_COR3_FIFO8 /* MUST BE LESS THAN MCOR_THRESHOLD */ | ||
90 | |||
91 | #define RIOC_COR3_DEFAULT (RIOC_COR3_FCT | RIOC_COR3_THRESHOLD) | ||
92 | /* Default bits for COR3 */ | ||
93 | |||
94 | /* COR4 driver and RTA use */ | ||
95 | #define RIOC_COR4_IGNCR 0x80 /* Throw away CR's on input */ | ||
96 | #define RIOC_COR4_ICRNL 0x40 /* Map CR -> NL on input */ | ||
97 | #define RIOC_COR4_INLCR 0x20 /* Map NL -> CR on input */ | ||
98 | #define RIOC_COR4_IGNBRK 0x10 /* Ignore Break */ | ||
99 | #define RIOC_COR4_NBRKINT 0x08 /* No interrupt on break (-BRKINT) */ | ||
100 | #define RIOC_COR4_RAISEMOD 0x01 /* Raise modem output lines on non-zero baud */ | ||
101 | |||
102 | |||
103 | /* COR4 driver only */ | ||
104 | #define RIOC_COR4_IGNPAR 0x04 /* IGNPAR (ignore characters with errors) */ | ||
105 | #define RIOC_COR4_PARMRK 0x02 /* PARMRK */ | ||
106 | |||
107 | #define RIOC_COR4_HOST 0xf8 /* Safe host bits */ | ||
108 | |||
109 | /* COR4 RTA only */ | ||
110 | #define RIOC_COR4_CIGNPAR 0x02 /* Thrown away bad characters */ | ||
111 | #define RIOC_COR4_CPARMRK 0x04 /* PARMRK characters */ | ||
112 | #define RIOC_COR4_CNPARMRK 0x03 /* Don't PARMRK */ | ||
113 | |||
114 | /* COR5 driver and RTA use */ | ||
115 | #define RIOC_COR5_ISTRIP 0x80 /* Strip input chars to 7 bits */ | ||
116 | #define RIOC_COR5_LNE 0x40 /* Enable LNEXT processing */ | ||
117 | #define RIOC_COR5_CMOE 0x20 /* Match good and errored characters */ | ||
118 | #define RIOC_COR5_ONLCR 0x02 /* NL -> CR NL on output */ | ||
119 | #define RIOC_COR5_OCRNL 0x01 /* CR -> NL on output */ | ||
120 | |||
121 | /* | ||
122 | ** Spare bits - these are not used in the CIRRUS registers, so we use | ||
123 | ** them to set various other features. | ||
124 | */ | ||
125 | /* | ||
126 | ** tstop and tbusy indication | ||
127 | */ | ||
128 | #define RIOC_COR5_TSTATE_ON 0x08 /* Turn on monitoring of tbusy and tstop */ | ||
129 | #define RIOC_COR5_TSTATE_OFF 0x04 /* Turn off monitoring of tbusy and tstop */ | ||
130 | /* | ||
131 | ** TAB3 | ||
132 | */ | ||
133 | #define RIOC_COR5_TAB3 0x10 /* TAB3 mode */ | ||
134 | |||
135 | #define RIOC_COR5_HOST 0xc3 /* Safe host bits */ | ||
136 | |||
137 | /* CCSR */ | ||
138 | #define RIOC_CCSR_TXFLOFF 0x04 /* Tx is xoffed */ | ||
139 | |||
140 | /* MSVR1 */ | ||
141 | /* NB. DTR / CD swapped from Cirrus spec as the pins are also reversed on the | ||
142 | RTA. This is because otherwise DCD would get lost on the 1 parallel / 3 | ||
143 | serial option. | ||
144 | */ | ||
145 | #define RIOC_MSVR1_CD 0x80 /* CD (DSR on Cirrus) */ | ||
146 | #define RIOC_MSVR1_RTS 0x40 /* RTS (CTS on Cirrus) */ | ||
147 | #define RIOC_MSVR1_RI 0x20 /* RI */ | ||
148 | #define RIOC_MSVR1_DTR 0x10 /* DTR (CD on Cirrus) */ | ||
149 | #define RIOC_MSVR1_CTS 0x01 /* CTS output pin (RTS on Cirrus) */ | ||
150 | /* Next two used to indicate state of tbusy and tstop to driver */ | ||
151 | #define RIOC_MSVR1_TSTOP 0x08 /* Set if port flow controlled */ | ||
152 | #define RIOC_MSVR1_TEMPTY 0x04 /* Set if port tx buffer empty */ | ||
153 | |||
154 | #define RIOC_MSVR1_HOST 0xf3 /* The bits the host wants */ | ||
155 | |||
156 | /* Defines for the subscripts of a CONFIG packet */ | ||
157 | #define RIOC_CONFIG_COR1 1 /* Option register 1 */ | ||
158 | #define RIOC_CONFIG_COR2 2 /* Option register 2 */ | ||
159 | #define RIOC_CONFIG_COR4 3 /* Option register 4 */ | ||
160 | #define RIOC_CONFIG_COR5 4 /* Option register 5 */ | ||
161 | #define RIOC_CONFIG_TXXON 5 /* Tx XON character */ | ||
162 | #define RIOC_CONFIG_TXXOFF 6 /* Tx XOFF character */ | ||
163 | #define RIOC_CONFIG_RXXON 7 /* Rx XON character */ | ||
164 | #define RIOC_CONFIG_RXXOFF 8 /* Rx XOFF character */ | ||
165 | #define RIOC_CONFIG_LNEXT 9 /* LNEXT character */ | ||
166 | #define RIOC_CONFIG_TXBAUD 10 /* Tx baud rate */ | ||
167 | #define RIOC_CONFIG_RXBAUD 11 /* Rx baud rate */ | ||
168 | |||
169 | #define RIOC_PRE_EMPTIVE 0x80 /* Pre-emptive bit in command field */ | ||
170 | |||
171 | /* Packet types going from Host to remote - with the exception of OPEN, MOPEN, | ||
172 | CONFIG, SBREAK and MEMDUMP the remaining bytes of the data array will not | ||
173 | be used | ||
174 | */ | ||
175 | #define RIOC_OPEN 0x00 /* Open a port */ | ||
176 | #define RIOC_CONFIG 0x01 /* Configure a port */ | ||
177 | #define RIOC_MOPEN 0x02 /* Modem open (block for DCD) */ | ||
178 | #define RIOC_CLOSE 0x03 /* Close a port */ | ||
179 | #define RIOC_WFLUSH (0x04 | RIOC_PRE_EMPTIVE) /* Write flush */ | ||
180 | #define RIOC_RFLUSH (0x05 | RIOC_PRE_EMPTIVE) /* Read flush */ | ||
181 | #define RIOC_RESUME (0x06 | RIOC_PRE_EMPTIVE) /* Resume if xoffed */ | ||
182 | #define RIOC_SBREAK 0x07 /* Start break */ | ||
183 | #define RIOC_EBREAK 0x08 /* End break */ | ||
184 | #define RIOC_SUSPEND (0x09 | RIOC_PRE_EMPTIVE) /* Susp op (behave as tho xoffed) */ | ||
185 | #define RIOC_FCLOSE (0x0a | RIOC_PRE_EMPTIVE) /* Force close */ | ||
186 | #define RIOC_XPRINT 0x0b /* Xprint packet */ | ||
187 | #define RIOC_MBIS (0x0c | RIOC_PRE_EMPTIVE) /* Set modem lines */ | ||
188 | #define RIOC_MBIC (0x0d | RIOC_PRE_EMPTIVE) /* Clear modem lines */ | ||
189 | #define RIOC_MSET (0x0e | RIOC_PRE_EMPTIVE) /* Set modem lines */ | ||
190 | #define RIOC_PCLOSE 0x0f /* Pseudo close - Leaves rx/tx enabled */ | ||
191 | #define RIOC_MGET (0x10 | RIOC_PRE_EMPTIVE) /* Force update of modem status */ | ||
192 | #define RIOC_MEMDUMP (0x11 | RIOC_PRE_EMPTIVE) /* Send back mem from addr supplied */ | ||
193 | #define RIOC_READ_REGISTER (0x12 | RIOC_PRE_EMPTIVE) /* Read CD1400 register (debug) */ | ||
194 | |||
195 | /* "Command" packets going from remote to host COMPLETE and MODEM_STATUS | ||
196 | use data[4] / data[3] to indicate current state and modem status respectively | ||
197 | */ | ||
198 | |||
199 | #define RIOC_COMPLETE (0x20 | RIOC_PRE_EMPTIVE) | ||
200 | /* Command complete */ | ||
201 | #define RIOC_BREAK_RECEIVED (0x21 | RIOC_PRE_EMPTIVE) | ||
202 | /* Break received */ | ||
203 | #define RIOC_MODEM_STATUS (0x22 | RIOC_PRE_EMPTIVE) | ||
204 | /* Change in modem status */ | ||
205 | |||
206 | /* "Command" packet that could go either way - handshake wake-up */ | ||
207 | #define RIOC_HANDSHAKE (0x23 | RIOC_PRE_EMPTIVE) | ||
208 | /* Wake-up to HOST / RTA */ | ||
209 | |||
210 | #endif | ||