diff options
Diffstat (limited to 'drivers/char/rio/cirrus.h')
-rw-r--r-- | drivers/char/rio/cirrus.h | 463 |
1 files changed, 463 insertions, 0 deletions
diff --git a/drivers/char/rio/cirrus.h b/drivers/char/rio/cirrus.h new file mode 100644 index 000000000000..cf056a990f18 --- /dev/null +++ b/drivers/char/rio/cirrus.h | |||
@@ -0,0 +1,463 @@ | |||
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 | ||