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
211