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 |