Merge commit 'kumar/kumar-next' into next
[linux-2.6] / drivers / char / rio / cirrus.h
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