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 |
| 38 | #ifndef lint |
| 39 | /* static char* _cirrus_h_sccs = "@(#)cirrus.h 1.16"; */ |
| 40 | #endif |
| 41 | #define _cirrus_h 1 |
| 42 | |
| 43 | #ifdef RTA |
| 44 | #define TO_UART RX |
| 45 | #define TO_DRIVER TX |
| 46 | #endif |
| 47 | |
| 48 | #ifdef HOST |
| 49 | #define TO_UART TX |
| 50 | #define TO_DRIVER RX |
| 51 | #endif |
| 52 | #ifdef RTA |
| 53 | /* Miscellaneous defines for CIRRUS addresses and related logic for |
| 54 | interrupts etc. |
| 55 | */ |
| 56 | #define MAP(a) ((short *)(cirrus_base + (a))) |
| 57 | #define outp(a,b) (*MAP (a) =(b)) |
| 58 | #define inp(a) ((*MAP (a)) & 0xff) |
| 59 | #define CIRRUS_FIRST (short*)0x7300 |
| 60 | #define CIRRUS_SECOND (short*)0x7200 |
| 61 | #define CIRRUS_THIRD (short*)0x7100 |
| 62 | #define CIRRUS_FOURTH (short*)0x7000 |
| 63 | #define PORTS_ON_CIRRUS 4 |
| 64 | #define CIRRUS_FIFO_SIZE 12 |
| 65 | #define SPACE 0x20 |
| 66 | #define TAB 0x09 |
| 67 | #define LINE_FEED 0x0a |
| 68 | #define CARRIAGE_RETURN 0x0d |
| 69 | #define BACKSPACE 0x08 |
| 70 | #define SPACES_IN_TABS 8 |
| 71 | #define SEND_ESCAPE 0x00 |
| 72 | #define START_BREAK 0x81 |
| 73 | #define TIMER_TICK 0x82 |
| 74 | #define STOP_BREAK 0x83 |
| 75 | #define BASE(a) ((a) < 4 ? (short*)CIRRUS_FIRST : ((a) < 8 ? (short *)CIRRUS_SECOND : ((a) < 12 ? (short*)CIRRUS_THIRD : (short *)CIRRUS_FOURTH))) |
| 76 | #define txack1 ((short *)0x7104) |
| 77 | #define rxack1 ((short *)0x7102) |
| 78 | #define mdack1 ((short *)0x7106) |
| 79 | #define txack2 ((short *)0x7006) |
| 80 | #define rxack2 ((short *)0x7004) |
| 81 | #define mdack2 ((short *)0x7100) |
| 82 | #define int_latch ((short *) 0x7800) |
| 83 | #define int_status ((short *) 0x7c00) |
| 84 | #define tx1_pending 0x20 |
| 85 | #define rx1_pending 0x10 |
| 86 | #define md1_pending 0x40 |
| 87 | #define tx2_pending 0x02 |
| 88 | #define rx2_pending 0x01 |
| 89 | #define md2_pending 0x40 |
| 90 | #define module1_bits 0x07 |
| 91 | #define module1_modern 0x08 |
| 92 | #define module2_bits 0x70 |
| 93 | #define module2_modern 0x80 |
| 94 | #define module_blank 0xf |
| 95 | #define rs232_d25 0x0 |
| 96 | #define rs232_rj45 0x1 |
| 97 | #define rs422_d25 0x3 |
| 98 | #define parallel 0x5 |
| 99 | |
| 100 | #define CLK0 0x00 |
| 101 | #define CLK1 0x01 |
| 102 | #define CLK2 0x02 |
| 103 | #define CLK3 0x03 |
| 104 | #define CLK4 0x04 |
| 105 | |
| 106 | #define CIRRUS_REVC 0x42 |
| 107 | #define CIRRUS_REVE 0x44 |
| 108 | |
| 109 | #define TURNON 1 |
| 110 | #define TURNOFF 0 |
| 111 | |
| 112 | /* The list of CIRRUS registers. |
| 113 | NB. These registers are relative values on 8 bit boundaries whereas |
| 114 | on the RTA's the CIRRUS registers are on word boundaries. Use pointer |
| 115 | arithmetic (short *) to obtain the real addresses required */ |
| 116 | #define ccr 0x05 /* Channel Command Register */ |
| 117 | #define ier 0x06 /* Interrupt Enable Register */ |
| 118 | #define cor1 0x08 /* Channel Option Register 1 */ |
| 119 | #define cor2 0x09 /* Channel Option Register 2 */ |
| 120 | #define cor3 0x0a /* Channel Option Register 3 */ |
| 121 | #define cor4 0x1e /* Channel Option Register 4 */ |
| 122 | #define cor5 0x1f /* Channel Option Register 5 */ |
| 123 | |
| 124 | #define ccsr 0x0b /* Channel Control Status Register */ |
| 125 | #define rdcr 0x0e /* Receive Data Count Register */ |
| 126 | #define tdcr 0x12 /* Transmit Data Count Register */ |
| 127 | #define mcor1 0x15 /* Modem Change Option Register 1 */ |
| 128 | #define mcor2 0x16 /* Modem Change Option Regsiter 2 */ |
| 129 | |
| 130 | #define livr 0x18 /* Local Interrupt Vector Register */ |
| 131 | #define schr1 0x1a /* Special Character Register 1 */ |
| 132 | #define schr2 0x1b /* Special Character Register 2 */ |
| 133 | #define schr3 0x1c /* Special Character Register 3 */ |
| 134 | #define schr4 0x1d /* Special Character Register 4 */ |
| 135 | |
| 136 | #define rtr 0x20 /* Receive Timer Register */ |
| 137 | #define rtpr 0x21 /* Receive Timeout Period Register */ |
| 138 | #define lnc 0x24 /* Lnext character */ |
| 139 | |
| 140 | #define rivr 0x43 /* Receive Interrupt Vector Register */ |
| 141 | #define tivr 0x42 /* Transmit Interrupt Vector Register */ |
| 142 | #define mivr 0x41 /* Modem Interrupt Vector Register */ |
| 143 | #define gfrcr 0x40 /* Global Firmware Revision code Reg */ |
| 144 | #define ricr 0x44 /* Receive Interrupting Channel Reg */ |
| 145 | #define ticr 0x45 /* Transmit Interrupting Channel Reg */ |
| 146 | #define micr 0x46 /* Modem Interrupting Channel Register */ |
| 147 | |
| 148 | #define gcr 0x4b /* Global configuration register*/ |
| 149 | #define misr 0x4c /* Modem interrupt status register */ |
| 150 | |
| 151 | #define rbusr 0x59 |
| 152 | #define tbusr 0x5a |
| 153 | #define mbusr 0x5b |
| 154 | |
| 155 | #define eoir 0x60 /* End Of Interrupt Register */ |
| 156 | #define rdsr 0x62 /* Receive Data / Status Register */ |
| 157 | #define tdr 0x63 /* Transmit Data Register */ |
| 158 | #define svrr 0x67 /* Service Request Register */ |
| 159 | |
| 160 | #define car 0x68 /* Channel Access Register */ |
| 161 | #define mir 0x69 /* Modem Interrupt Register */ |
| 162 | #define tir 0x6a /* Transmit Interrupt Register */ |
| 163 | #define rir 0x6b /* Receive Interrupt Register */ |
| 164 | #define msvr1 0x6c /* Modem Signal Value Register 1 */ |
| 165 | #define msvr2 0x6d /* Modem Signal Value Register 2*/ |
| 166 | #define psvr 0x6f /* Printer Signal Value Register*/ |
| 167 | |
| 168 | #define tbpr 0x72 /* Transmit Baud Rate Period Register */ |
| 169 | #define tcor 0x76 /* Transmit Clock Option Register */ |
| 170 | |
| 171 | #define rbpr 0x78 /* Receive Baud Rate Period Register */ |
| 172 | #define rber 0x7a /* Receive Baud Rate Extension Register */ |
| 173 | #define rcor 0x7c /* Receive Clock Option Register*/ |
| 174 | #define ppr 0x7e /* Prescalar Period Register */ |
| 175 | |
| 176 | /* Misc registers used for forcing the 1400 out of its reset woes */ |
| 177 | #define airl 0x6d |
| 178 | #define airm 0x6e |
| 179 | #define airh 0x6f |
| 180 | #define btcr 0x66 |
| 181 | #define mtcr 0x6c |
| 182 | #define tber 0x74 |
| 183 | |
| 184 | #endif /* #ifdef RTA */ |
| 185 | |
| 186 | |
| 187 | /* Bit fields for particular registers */ |
| 188 | |
| 189 | /* GCR */ |
| 190 | #define GCR_SERIAL 0x00 /* Configure as serial channel */ |
| 191 | #define GCR_PARALLEL 0x80 /* Configure as parallel channel */ |
| 192 | |
| 193 | /* RDSR - when status read from FIFO */ |
| 194 | #define RDSR_BREAK 0x08 /* Break received */ |
| 195 | #define RDSR_TIMEOUT 0x80 /* No new data timeout */ |
| 196 | #define RDSR_SC1 0x10 /* Special char 1 (tx XON) matched */ |
| 197 | #define RDSR_SC2 0x20 /* Special char 2 (tx XOFF) matched */ |
| 198 | #define RDSR_SC12_MASK 0x30 /* Mask for special chars 1 and 2 */ |
| 199 | |
| 200 | /* PPR */ |
| 201 | #define PPR_DEFAULT 0x31 /* Default value - for a 25Mhz clock gives |
| 202 | a timeout period of 1ms */ |
| 203 | |
| 204 | /* LIVR */ |
| 205 | #define LIVR_EXCEPTION 0x07 /* Receive exception interrupt */ |
| 206 | |
| 207 | /* CCR */ |
| 208 | #define CCR_RESET 0x80 /* Reset channel */ |
| 209 | #define CCR_CHANGE 0x4e /* COR's have changed - NB always change all |
| 210 | COR's */ |
| 211 | #define CCR_WFLUSH 0x82 /* Flush transmit FIFO and TSR / THR */ |
| 212 | |
| 213 | #define CCR_SENDSC1 0x21 /* Send special character one */ |
| 214 | #define CCR_SENDSC2 0x22 /* Send special character two */ |
| 215 | #define CCR_SENDSC3 0x23 /* Send special character three */ |
| 216 | #define CCR_SENDSC4 0x24 /* Send special character four */ |
| 217 | |
| 218 | #define CCR_TENABLE 0x18 /* Enable transmitter */ |
| 219 | #define CCR_TDISABLE 0x14 /* Disable transmitter */ |
| 220 | #define CCR_RENABLE 0x12 /* Enable receiver */ |
| 221 | #define CCR_RDISABLE 0x11 /* Disable receiver */ |
| 222 | |
| 223 | #define CCR_READY 0x00 /* CCR is ready for another command */ |
| 224 | |
| 225 | /* CCSR */ |
| 226 | #define CCSR_TXENABLE 0x08 /* Transmitter enable */ |
| 227 | #define CCSR_RXENABLE 0x80 /* Receiver enable */ |
| 228 | #define CCSR_TXFLOWOFF 0x04 /* Transmit flow off */ |
| 229 | #define CCSR_TXFLOWON 0x02 /* Transmit flow on */ |
| 230 | |
| 231 | /* SVRR */ |
| 232 | #define SVRR_RECEIVE 0x01 /* Receive interrupt pending */ |
| 233 | #define SVRR_TRANSMIT 0x02 /* Transmit interrupt pending */ |
| 234 | #define SVRR_MODEM 0x04 /* Modem interrupt pending */ |
| 235 | |
| 236 | /* CAR */ |
| 237 | #define CAR_PORTS 0x03 /* Bit fields for ports */ |
| 238 | |
| 239 | /* IER */ |
| 240 | #define IER_MODEM 0x80 /* Change in modem status */ |
| 241 | #define IER_RECEIVE 0x10 /* Good data / data exception */ |
| 242 | #define IER_TRANSMITR 0x04 /* Transmit ready (FIFO empty) */ |
| 243 | #define IER_TRANSMITE 0x02 /* Transmit empty */ |
| 244 | #define IER_TIMEOUT 0x01 /* Timeout on no data */ |
| 245 | |
| 246 | #define IER_DEFAULT 0x94 /* Default values */ |
| 247 | #define IER_PARALLEL 0x84 /* Default for Parallel */ |
| 248 | #define IER_EMPTY 0x92 /* Transmitter empty rather than ready */ |
| 249 | |
| 250 | /* COR1 - Driver only */ |
| 251 | #define COR1_INPCK 0x10 /* Check parity of received characters */ |
| 252 | |
| 253 | /* COR1 - driver and RTA */ |
| 254 | #define COR1_ODD 0x80 /* Odd parity */ |
| 255 | #define COR1_EVEN 0x00 /* Even parity */ |
| 256 | #define COR1_NOP 0x00 /* No parity */ |
| 257 | #define COR1_FORCE 0x20 /* Force parity */ |
| 258 | #define COR1_NORMAL 0x40 /* With parity */ |
| 259 | #define COR1_1STOP 0x00 /* 1 stop bit */ |
| 260 | #define COR1_15STOP 0x04 /* 1.5 stop bits */ |
| 261 | #define COR1_2STOP 0x08 /* 2 stop bits */ |
| 262 | #define COR1_5BITS 0x00 /* 5 data bits */ |
| 263 | #define COR1_6BITS 0x01 /* 6 data bits */ |
| 264 | #define COR1_7BITS 0x02 /* 7 data bits */ |
| 265 | #define COR1_8BITS 0x03 /* 8 data bits */ |
| 266 | |
| 267 | #define COR1_HOST 0xef /* Safe host bits */ |
| 268 | |
| 269 | /* RTA only */ |
| 270 | #define COR1_CINPCK 0x00 /* Check parity of received characters */ |
| 271 | #define COR1_CNINPCK 0x10 /* Don't check parity */ |
| 272 | |
| 273 | /* COR2 bits for both RTA and driver use */ |
| 274 | #define COR2_IXANY 0x80 /* IXANY - any character is XON */ |
| 275 | #define COR2_IXON 0x40 /* IXON - enable tx soft flowcontrol */ |
| 276 | #define COR2_RTSFLOW 0x02 /* Enable tx hardware flow control */ |
| 277 | |
| 278 | /* Additional driver bits */ |
| 279 | #define COR2_HUPCL 0x20 /* Hang up on close */ |
| 280 | #define COR2_CTSFLOW 0x04 /* Enable rx hardware flow control */ |
| 281 | #define COR2_IXOFF 0x01 /* Enable rx software flow control */ |
| 282 | #define COR2_DTRFLOW 0x08 /* Enable tx hardware flow control */ |
| 283 | |
| 284 | /* RTA use only */ |
| 285 | #define COR2_ETC 0x20 /* Embedded transmit options */ |
| 286 | #define COR2_LOCAL 0x10 /* Local loopback mode */ |
| 287 | #define COR2_REMOTE 0x08 /* Remote loopback mode */ |
| 288 | #define COR2_HOST 0xc2 /* Safe host bits */ |
| 289 | |
| 290 | /* COR3 - RTA use only */ |
| 291 | #define COR3_SCDRNG 0x80 /* Enable special char detect for range */ |
| 292 | #define COR3_SCD34 0x40 /* Special character detect for SCHR's 3 + 4 */ |
| 293 | #define COR3_FCT 0x20 /* Flow control transparency */ |
| 294 | #define COR3_SCD12 0x10 /* Special character detect for SCHR's 1 + 2 */ |
| 295 | #define COR3_FIFO12 0x0c /* 12 chars for receive FIFO threshold */ |
| 296 | #define COR3_FIFO10 0x0a /* 10 chars for receive FIFO threshold */ |
| 297 | #define COR3_FIFO8 0x08 /* 8 chars for receive FIFO threshold */ |
| 298 | #define COR3_FIFO6 0x06 /* 6 chars for receive FIFO threshold */ |
| 299 | |
| 300 | #define COR3_THRESHOLD COR3_FIFO8 /* MUST BE LESS THAN MCOR_THRESHOLD */ |
| 301 | |
| 302 | #define COR3_DEFAULT (COR3_FCT | COR3_THRESHOLD) |
| 303 | /* Default bits for COR3 */ |
| 304 | |
| 305 | /* COR4 driver and RTA use */ |
| 306 | #define COR4_IGNCR 0x80 /* Throw away CR's on input */ |
| 307 | #define COR4_ICRNL 0x40 /* Map CR -> NL on input */ |
| 308 | #define COR4_INLCR 0x20 /* Map NL -> CR on input */ |
| 309 | #define COR4_IGNBRK 0x10 /* Ignore Break */ |
| 310 | #define COR4_NBRKINT 0x08 /* No interrupt on break (-BRKINT) */ |
| 311 | #define COR4_RAISEMOD 0x01 /* Raise modem output lines on non-zero baud */ |
| 312 | |
| 313 | |
| 314 | /* COR4 driver only */ |
| 315 | #define COR4_IGNPAR 0x04 /* IGNPAR (ignore characters with errors) */ |
| 316 | #define COR4_PARMRK 0x02 /* PARMRK */ |
| 317 | |
| 318 | #define COR4_HOST 0xf8 /* Safe host bits */ |
| 319 | |
| 320 | /* COR4 RTA only */ |
| 321 | #define COR4_CIGNPAR 0x02 /* Thrown away bad characters */ |
| 322 | #define COR4_CPARMRK 0x04 /* PARMRK characters */ |
| 323 | #define COR4_CNPARMRK 0x03 /* Don't PARMRK */ |
| 324 | |
| 325 | /* COR5 driver and RTA use */ |
| 326 | #define COR5_ISTRIP 0x80 /* Strip input chars to 7 bits */ |
| 327 | #define COR5_LNE 0x40 /* Enable LNEXT processing */ |
| 328 | #define COR5_CMOE 0x20 /* Match good and errored characters */ |
| 329 | #define COR5_ONLCR 0x02 /* NL -> CR NL on output */ |
| 330 | #define COR5_OCRNL 0x01 /* CR -> NL on output */ |
| 331 | |
| 332 | /* |
| 333 | ** Spare bits - these are not used in the CIRRUS registers, so we use |
| 334 | ** them to set various other features. |
| 335 | */ |
| 336 | /* |
| 337 | ** tstop and tbusy indication |
| 338 | */ |
| 339 | #define COR5_TSTATE_ON 0x08 /* Turn on monitoring of tbusy and tstop */ |
| 340 | #define COR5_TSTATE_OFF 0x04 /* Turn off monitoring of tbusy and tstop */ |
| 341 | /* |
| 342 | ** TAB3 |
| 343 | */ |
| 344 | #define COR5_TAB3 0x10 /* TAB3 mode */ |
| 345 | |
| 346 | #define COR5_HOST 0xc3 /* Safe host bits */ |
| 347 | |
| 348 | /* CCSR */ |
| 349 | #define CCSR_TXFLOFF 0x04 /* Tx is xoffed */ |
| 350 | |
| 351 | /* MSVR1 */ |
| 352 | /* NB. DTR / CD swapped from Cirrus spec as the pins are also reversed on the |
| 353 | RTA. This is because otherwise DCD would get lost on the 1 parallel / 3 |
| 354 | serial option. |
| 355 | */ |
| 356 | #define MSVR1_CD 0x80 /* CD (DSR on Cirrus) */ |
| 357 | #define MSVR1_RTS 0x40 /* RTS (CTS on Cirrus) */ |
| 358 | #define MSVR1_RI 0x20 /* RI */ |
| 359 | #define MSVR1_DTR 0x10 /* DTR (CD on Cirrus) */ |
| 360 | #define MSVR1_CTS 0x01 /* CTS output pin (RTS on Cirrus) */ |
| 361 | /* Next two used to indicate state of tbusy and tstop to driver */ |
| 362 | #define MSVR1_TSTOP 0x08 /* Set if port flow controlled */ |
| 363 | #define MSVR1_TEMPTY 0x04 /* Set if port tx buffer empty */ |
| 364 | |
| 365 | #define MSVR1_HOST 0xf3 /* The bits the host wants */ |
| 366 | |
| 367 | /* MSVR2 */ |
| 368 | #define MSVR2_DSR 0x02 /* DSR output pin (DTR on Cirrus) */ |
| 369 | |
| 370 | /* MCOR */ |
| 371 | #define MCOR_CD 0x80 /* CD (DSR on Cirrus) */ |
| 372 | #define MCOR_RTS 0x40 /* RTS (CTS on Cirrus) */ |
| 373 | #define MCOR_RI 0x20 /* RI */ |
| 374 | #define MCOR_DTR 0x10 /* DTR (CD on Cirrus) */ |
| 375 | |
| 376 | #define MCOR_DEFAULT (MCOR_CD | MCOR_RTS | MCOR_RI | MCOR_DTR) |
| 377 | #define MCOR_FULLMODEM MCOR_DEFAULT |
| 378 | #define MCOR_RJ45 (MCOR_CD | MCOR_RTS | MCOR_DTR) |
| 379 | #define MCOR_RESTRICTED (MCOR_CD | MCOR_RTS) |
| 380 | |
| 381 | /* More MCOR - H/W Handshake (flowcontrol) stuff */ |
| 382 | #define MCOR_THRESH8 0x08 /* eight characters then we stop */ |
| 383 | #define MCOR_THRESH9 0x09 /* nine characters then we stop */ |
| 384 | #define MCOR_THRESH10 0x0A /* ten characters then we stop */ |
| 385 | #define MCOR_THRESH11 0x0B /* eleven characters then we stop */ |
| 386 | |
| 387 | #define MCOR_THRESHBITS 0x0F /* mask for ANDing out the above */ |
| 388 | |
| 389 | #define MCOR_THRESHOLD MCOR_THRESH9 /* MUST BE GREATER THAN COR3_THRESHOLD */ |
| 390 | |
| 391 | |
| 392 | /* RTPR */ |
| 393 | #define RTPR_DEFAULT 0x02 /* Default */ |
| 394 | |
| 395 | |
| 396 | /* Defines for the subscripts of a CONFIG packet */ |
| 397 | #define CONFIG_COR1 1 /* Option register 1 */ |
| 398 | #define CONFIG_COR2 2 /* Option register 2 */ |
| 399 | #define CONFIG_COR4 3 /* Option register 4 */ |
| 400 | #define CONFIG_COR5 4 /* Option register 5 */ |
| 401 | #define CONFIG_TXXON 5 /* Tx XON character */ |
| 402 | #define CONFIG_TXXOFF 6 /* Tx XOFF character */ |
| 403 | #define CONFIG_RXXON 7 /* Rx XON character */ |
| 404 | #define CONFIG_RXXOFF 8 /* Rx XOFF character */ |
| 405 | #define CONFIG_LNEXT 9 /* LNEXT character */ |
| 406 | #define CONFIG_TXBAUD 10 /* Tx baud rate */ |
| 407 | #define CONFIG_RXBAUD 11 /* Rx baud rate */ |
| 408 | |
| 409 | /* Port status stuff */ |
| 410 | #define IDLE_CLOSED 0 /* Closed */ |
| 411 | #define IDLE_OPEN 1 /* Idle open */ |
| 412 | #define IDLE_BREAK 2 /* Idle on break */ |
| 413 | |
| 414 | /* Subscript of MODEM STATUS packet */ |
| 415 | #define MODEM_VALUE 3 /* Current values of handshake pins */ |
| 416 | /* Subscript of SBREAK packet */ |
| 417 | #define BREAK_LENGTH 1 /* Length of a break in slices of 0.01 seconds |
| 418 | 0 = stay on break until an EBREAK command |
| 419 | is sent */ |
| 420 | |
| 421 | |
| 422 | #define PRE_EMPTIVE 0x80 /* Pre-emptive bit in command field */ |
| 423 | |
| 424 | /* Packet types going from Host to remote - with the exception of OPEN, MOPEN, |
| 425 | CONFIG, SBREAK and MEMDUMP the remaining bytes of the data array will not |
| 426 | be used |
| 427 | */ |
| 428 | #define OPEN 0x00 /* Open a port */ |
| 429 | #define CONFIG 0x01 /* Configure a port */ |
| 430 | #define MOPEN 0x02 /* Modem open (block for DCD) */ |
| 431 | #define CLOSE 0x03 /* Close a port */ |
| 432 | #define WFLUSH (0x04 | PRE_EMPTIVE) /* Write flush */ |
| 433 | #define RFLUSH (0x05 | PRE_EMPTIVE) /* Read flush */ |
| 434 | #define RESUME (0x06 | PRE_EMPTIVE) /* Resume if xoffed */ |
| 435 | #define SBREAK 0x07 /* Start break */ |
| 436 | #define EBREAK 0x08 /* End break */ |
| 437 | #define SUSPEND (0x09 | PRE_EMPTIVE) /* Susp op (behave as tho xoffed) */ |
| 438 | #define FCLOSE (0x0a | PRE_EMPTIVE) /* Force close */ |
| 439 | #define XPRINT 0x0b /* Xprint packet */ |
| 440 | #define MBIS (0x0c | PRE_EMPTIVE) /* Set modem lines */ |
| 441 | #define MBIC (0x0d | PRE_EMPTIVE) /* Clear modem lines */ |
| 442 | #define MSET (0x0e | PRE_EMPTIVE) /* Set modem lines */ |
| 443 | #define PCLOSE 0x0f /* Pseudo close - Leaves rx/tx enabled */ |
| 444 | #define MGET (0x10 | PRE_EMPTIVE) /* Force update of modem status */ |
| 445 | #define MEMDUMP (0x11 | PRE_EMPTIVE) /* Send back mem from addr supplied */ |
| 446 | #define READ_REGISTER (0x12 | PRE_EMPTIVE) /* Read CD1400 register (debug) */ |
| 447 | |
| 448 | /* "Command" packets going from remote to host COMPLETE and MODEM_STATUS |
| 449 | use data[4] / data[3] to indicate current state and modem status respectively |
| 450 | */ |
| 451 | |
| 452 | #define COMPLETE (0x20 | PRE_EMPTIVE) |
| 453 | /* Command complete */ |
| 454 | #define BREAK_RECEIVED (0x21 | PRE_EMPTIVE) |
| 455 | /* Break received */ |
| 456 | #define MODEM_STATUS (0x22 | PRE_EMPTIVE) |
| 457 | /* Change in modem status */ |
| 458 | |
| 459 | /* "Command" packet that could go either way - handshake wake-up */ |
| 460 | #define HANDSHAKE (0x23 | PRE_EMPTIVE) |
| 461 | /* Wake-up to HOST / RTA */ |
| 462 | |
| 463 | #endif |