OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [linux/] [linux-2.4/] [drivers/] [char/] [rio/] [cirrus.h] - Blame information for rev 1765

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 1275 phoenix
/****************************************************************************
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
 
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

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.