| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 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 | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 38 | #define _cirrus_h 1 | 
|  | 39 |  | 
| Alan Cox | 57c2d60 | 2006-03-24 03:18:31 -0800 | [diff] [blame] | 40 | /* Bit fields for particular registers shared with driver */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 41 |  | 
|  | 42 | /* COR1 - driver and RTA */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 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 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 55 |  | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 56 | #define RIOC_COR1_HOST		0xef	/* Safe host bits */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 57 |  | 
|  | 58 | /* RTA only */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 59 | #define RIOC_COR1_CINPCK	0x00	/* Check parity of received characters */ | 
|  | 60 | #define RIOC_COR1_CNINPCK	0x10	/* Don't check parity */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 61 |  | 
|  | 62 | /* COR2 bits for both RTA and driver use */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 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 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 66 |  | 
|  | 67 | /* Additional driver bits */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 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 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 72 |  | 
|  | 73 | /* RTA use only */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 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 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 78 |  | 
|  | 79 | /* COR3 - RTA use only */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 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 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 88 |  | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 89 | #define RIOC_COR3_THRESHOLD	RIOC_COR3_FIFO8	/* MUST BE LESS THAN MCOR_THRESHOLD */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 90 |  | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 91 | #define RIOC_COR3_DEFAULT	(RIOC_COR3_FCT | RIOC_COR3_THRESHOLD) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 92 | /* Default bits for COR3 */ | 
|  | 93 |  | 
|  | 94 | /* COR4 driver and RTA use */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 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 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 101 |  | 
|  | 102 |  | 
|  | 103 | /* COR4 driver only */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 104 | #define RIOC_COR4_IGNPAR	0x04	/* IGNPAR (ignore characters with errors) */ | 
|  | 105 | #define RIOC_COR4_PARMRK	0x02	/* PARMRK */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 106 |  | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 107 | #define RIOC_COR4_HOST		0xf8	/* Safe host bits */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 108 |  | 
|  | 109 | /* COR4 RTA only */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 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 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 113 |  | 
|  | 114 | /* COR5 driver and RTA use */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 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 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 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 | */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 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 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 130 | /* | 
|  | 131 | ** TAB3 | 
|  | 132 | */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 133 | #define RIOC_COR5_TAB3		0x10	/* TAB3 mode */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 134 |  | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 135 | #define RIOC_COR5_HOST		0xc3	/* Safe host bits */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 136 |  | 
|  | 137 | /* CCSR */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 138 | #define RIOC_CCSR_TXFLOFF	0x04	/* Tx is xoffed */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 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 | */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 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) */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 150 | /* Next two used to indicate state of tbusy and tstop to driver */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 151 | #define RIOC_MSVR1_TSTOP	0x08	/* Set if port flow controlled */ | 
|  | 152 | #define RIOC_MSVR1_TEMPTY	0x04	/* Set if port tx buffer empty */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 153 |  | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 154 | #define RIOC_MSVR1_HOST		0xf3	/* The bits the host wants */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 155 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 156 | /* Defines for the subscripts of a CONFIG packet */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 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 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 168 |  | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 169 | #define RIOC_PRE_EMPTIVE	0x80	/* Pre-emptive bit in command field */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 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 | */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 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) */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 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 | 
| Andrew Morton | 8d8706e | 2006-01-11 12:17:49 -0800 | [diff] [blame] | 197 | */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 198 |  | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 199 | #define RIOC_COMPLETE		(0x20 | RIOC_PRE_EMPTIVE) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 200 | /* Command complete */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 201 | #define RIOC_BREAK_RECEIVED	(0x21 | RIOC_PRE_EMPTIVE) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 202 | /* Break received */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 203 | #define RIOC_MODEM_STATUS	(0x22 | RIOC_PRE_EMPTIVE) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 204 | /* Change in modem status */ | 
|  | 205 |  | 
|  | 206 | /* "Command" packet that could go either way - handshake wake-up */ | 
| Jiri Slaby | d6f6341 | 2008-04-30 00:53:57 -0700 | [diff] [blame] | 207 | #define RIOC_HANDSHAKE		(0x23 | RIOC_PRE_EMPTIVE) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 208 | /* Wake-up to HOST / RTA */ | 
|  | 209 |  | 
|  | 210 | #endif |