tty/serial: lay the foundations for the next set of reworks
[pandora-kernel.git] / drivers / char / serial167.c
1 /*
2  * linux/drivers/char/serial167.c
3  *
4  * Driver for MVME166/7 board serial ports, which are via a CD2401.
5  * Based very much on cyclades.c.
6  *
7  * MVME166/7 work by Richard Hirst [richard@sleepie.demon.co.uk]
8  *
9  * ==============================================================
10  *
11  * static char rcsid[] =
12  * "$Revision: 1.36.1.4 $$Date: 1995/03/29 06:14:14 $";
13  *
14  *  linux/kernel/cyclades.c
15  *
16  * Maintained by Marcio Saito (cyclades@netcom.com) and
17  * Randolph Bentson (bentson@grieg.seaslug.org)
18  *
19  * Much of the design and some of the code came from serial.c
20  * which was copyright (C) 1991, 1992  Linus Torvalds.  It was
21  * extensively rewritten by Theodore Ts'o, 8/16/92 -- 9/14/92,
22  * and then fixed as suggested by Michael K. Johnson 12/12/92.
23  *
24  * This version does not support shared irq's.
25  *
26  * $Log: cyclades.c,v $
27  * Revision 1.36.1.4  1995/03/29  06:14:14  bentson
28  * disambiguate between Cyclom-16Y and Cyclom-32Ye;
29  *
30  * Changes:
31  *
32  * 200 lines of changes record removed - RGH 11-10-95, starting work on
33  * converting this to drive serial ports on mvme166 (cd2401).
34  *
35  * Arnaldo Carvalho de Melo <acme@conectiva.com.br> - 2000/08/25
36  * - get rid of verify_area
37  * - use get_user to access memory from userspace in set_threshold,
38  *   set_default_threshold and set_timeout
39  * - don't use the panic function in serial167_init
40  * - do resource release on failure on serial167_init
41  * - include missing restore_flags in mvme167_serial_console_setup
42  *
43  * Kars de Jong <jongk@linux-m68k.org> - 2004/09/06
44  * - replace bottom half handler with task queue handler
45  */
46
47 #include <linux/errno.h>
48 #include <linux/signal.h>
49 #include <linux/sched.h>
50 #include <linux/timer.h>
51 #include <linux/tty.h>
52 #include <linux/interrupt.h>
53 #include <linux/serial.h>
54 #include <linux/serialP.h>
55 #include <linux/string.h>
56 #include <linux/fcntl.h>
57 #include <linux/ptrace.h>
58 #include <linux/serial167.h>
59 #include <linux/delay.h>
60 #include <linux/major.h>
61 #include <linux/mm.h>
62 #include <linux/console.h>
63 #include <linux/module.h>
64 #include <linux/bitops.h>
65 #include <linux/tty_flip.h>
66
67 #include <asm/system.h>
68 #include <asm/io.h>
69 #include <asm/mvme16xhw.h>
70 #include <asm/bootinfo.h>
71 #include <asm/setup.h>
72
73 #include <linux/types.h>
74 #include <linux/kernel.h>
75
76 #include <asm/uaccess.h>
77 #include <linux/init.h>
78
79 #define SERIAL_PARANOIA_CHECK
80 #undef  SERIAL_DEBUG_OPEN
81 #undef  SERIAL_DEBUG_THROTTLE
82 #undef  SERIAL_DEBUG_OTHER
83 #undef  SERIAL_DEBUG_IO
84 #undef  SERIAL_DEBUG_COUNT
85 #undef  SERIAL_DEBUG_DTR
86 #undef  CYCLOM_16Y_HACK
87 #define  CYCLOM_ENABLE_MONITORING
88
89 #define WAKEUP_CHARS 256
90
91 #define STD_COM_FLAGS (0)
92
93 static struct tty_driver *cy_serial_driver;
94 extern int serial_console;
95 static struct cyclades_port *serial_console_info = NULL;
96 static unsigned int serial_console_cflag = 0;
97 u_char initial_console_speed;
98
99 /* Base address of cd2401 chip on mvme166/7 */
100
101 #define BASE_ADDR (0xfff45000)
102 #define pcc2chip        ((volatile u_char *)0xfff42000)
103 #define PccSCCMICR      0x1d
104 #define PccSCCTICR      0x1e
105 #define PccSCCRICR      0x1f
106 #define PccTPIACKR      0x25
107 #define PccRPIACKR      0x27
108 #define PccIMLR         0x3f
109
110 /* This is the per-port data structure */
111 struct cyclades_port cy_port[] = {
112         /* CARD#  */
113         {-1},                   /* ttyS0 */
114         {-1},                   /* ttyS1 */
115         {-1},                   /* ttyS2 */
116         {-1},                   /* ttyS3 */
117 };
118
119 #define NR_PORTS        ARRAY_SIZE(cy_port)
120
121 /*
122  * This is used to look up the divisor speeds and the timeouts
123  * We're normally limited to 15 distinct baud rates.  The extra
124  * are accessed via settings in info->flags.
125  *         0,     1,     2,     3,     4,     5,     6,     7,     8,     9,
126  *        10,    11,    12,    13,    14,    15,    16,    17,    18,    19,
127  *                                                  HI            VHI
128  */
129 static int baud_table[] = {
130         0, 50, 75, 110, 134, 150, 200, 300, 600, 1200,
131         1800, 2400, 4800, 9600, 19200, 38400, 57600, 76800, 115200, 150000,
132         0
133 };
134
135 #if 0
136 static char baud_co[] = {       /* 25 MHz clock option table */
137         /* value =>    00    01   02    03    04 */
138         /* divide by    8    32   128   512  2048 */
139         0x00, 0x04, 0x04, 0x04, 0x04, 0x04, 0x03, 0x03, 0x03, 0x02,
140         0x02, 0x02, 0x01, 0x01, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
141 };
142
143 static char baud_bpr[] = {      /* 25 MHz baud rate period table */
144         0x00, 0xf5, 0xa3, 0x6f, 0x5c, 0x51, 0xf5, 0xa3, 0x51, 0xa3,
145         0x6d, 0x51, 0xa3, 0x51, 0xa3, 0x51, 0x36, 0x29, 0x1b, 0x15
146 };
147 #endif
148
149 /* I think 166 brd clocks 2401 at 20MHz.... */
150
151 /* These values are written directly to tcor, and >> 5 for writing to rcor */
152 static u_char baud_co[] = {     /* 20 MHz clock option table */
153         0x00, 0x80, 0x80, 0x80, 0x80, 0x80, 0x80, 0x60, 0x60, 0x40,
154         0x40, 0x40, 0x20, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
155 };
156
157 /* These values written directly to tbpr/rbpr */
158 static u_char baud_bpr[] = {    /* 20 MHz baud rate period table */
159         0x00, 0xc0, 0x80, 0x58, 0x6c, 0x40, 0xc0, 0x81, 0x40, 0x81,
160         0x57, 0x40, 0x81, 0x40, 0x81, 0x40, 0x2b, 0x20, 0x15, 0x10
161 };
162
163 static u_char baud_cor4[] = {   /* receive threshold */
164         0x0a, 0x0a, 0x0a, 0x0a, 0x0a, 0x0a, 0x0a, 0x0a, 0x0a, 0x0a,
165         0x0a, 0x0a, 0x0a, 0x09, 0x09, 0x08, 0x08, 0x08, 0x08, 0x07
166 };
167
168 static void shutdown(struct cyclades_port *);
169 static int startup(struct cyclades_port *);
170 static void cy_throttle(struct tty_struct *);
171 static void cy_unthrottle(struct tty_struct *);
172 static void config_setup(struct cyclades_port *);
173 extern void console_print(const char *);
174 #ifdef CYCLOM_SHOW_STATUS
175 static void show_status(int);
176 #endif
177
178 #ifdef CONFIG_REMOTE_DEBUG
179 static void debug_setup(void);
180 void queueDebugChar(int c);
181 int getDebugChar(void);
182
183 #define DEBUG_PORT      1
184 #define DEBUG_LEN       256
185
186 typedef struct {
187         int in;
188         int out;
189         unsigned char buf[DEBUG_LEN];
190 } debugq;
191
192 debugq debugiq;
193 #endif
194
195 /*
196  * I have my own version of udelay(), as it is needed when initialising
197  * the chip, before the delay loop has been calibrated.  Should probably
198  * reference one of the vmechip2 or pccchip2 counter for an accurate
199  * delay, but this wild guess will do for now.
200  */
201
202 void my_udelay(long us)
203 {
204         u_char x;
205         volatile u_char *p = &x;
206         int i;
207
208         while (us--)
209                 for (i = 100; i; i--)
210                         x |= *p;
211 }
212
213 static inline int serial_paranoia_check(struct cyclades_port *info, char *name,
214                 const char *routine)
215 {
216 #ifdef SERIAL_PARANOIA_CHECK
217         if (!info) {
218                 printk("Warning: null cyclades_port for (%s) in %s\n", name,
219                                 routine);
220                 return 1;
221         }
222
223         if ((long)info < (long)(&cy_port[0])
224             || (long)(&cy_port[NR_PORTS]) < (long)info) {
225                 printk("Warning: cyclades_port out of range for (%s) in %s\n",
226                                 name, routine);
227                 return 1;
228         }
229
230         if (info->magic != CYCLADES_MAGIC) {
231                 printk("Warning: bad magic number for serial struct (%s) in "
232                                 "%s\n", name, routine);
233                 return 1;
234         }
235 #endif
236         return 0;
237 }                               /* serial_paranoia_check */
238
239 #if 0
240 /* The following diagnostic routines allow the driver to spew
241    information on the screen, even (especially!) during interrupts.
242  */
243 void SP(char *data)
244 {
245         unsigned long flags;
246         local_irq_save(flags);
247         console_print(data);
248         local_irq_restore(flags);
249 }
250
251 char scrn[2];
252 void CP(char data)
253 {
254         unsigned long flags;
255         local_irq_save(flags);
256         scrn[0] = data;
257         console_print(scrn);
258         local_irq_restore(flags);
259 }                               /* CP */
260
261 void CP1(int data)
262 {
263         (data < 10) ? CP(data + '0') : CP(data + 'A' - 10);
264 }                               /* CP1 */
265 void CP2(int data)
266 {
267         CP1((data >> 4) & 0x0f);
268         CP1(data & 0x0f);
269 }                               /* CP2 */
270 void CP4(int data)
271 {
272         CP2((data >> 8) & 0xff);
273         CP2(data & 0xff);
274 }                               /* CP4 */
275 void CP8(long data)
276 {
277         CP4((data >> 16) & 0xffff);
278         CP4(data & 0xffff);
279 }                               /* CP8 */
280 #endif
281
282 /* This routine waits up to 1000 micro-seconds for the previous
283    command to the Cirrus chip to complete and then issues the
284    new command.  An error is returned if the previous command
285    didn't finish within the time limit.
286  */
287 u_short write_cy_cmd(volatile u_char * base_addr, u_char cmd)
288 {
289         unsigned long flags;
290         volatile int i;
291
292         local_irq_save(flags);
293         /* Check to see that the previous command has completed */
294         for (i = 0; i < 100; i++) {
295                 if (base_addr[CyCCR] == 0) {
296                         break;
297                 }
298                 my_udelay(10L);
299         }
300         /* if the CCR never cleared, the previous command
301            didn't finish within the "reasonable time" */
302         if (i == 10) {
303                 local_irq_restore(flags);
304                 return (-1);
305         }
306
307         /* Issue the new command */
308         base_addr[CyCCR] = cmd;
309         local_irq_restore(flags);
310         return (0);
311 }                               /* write_cy_cmd */
312
313 /* cy_start and cy_stop provide software output flow control as a
314    function of XON/XOFF, software CTS, and other such stuff. */
315
316 static void cy_stop(struct tty_struct *tty)
317 {
318         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
319         volatile unsigned char *base_addr = (unsigned char *)BASE_ADDR;
320         int channel;
321         unsigned long flags;
322
323 #ifdef SERIAL_DEBUG_OTHER
324         printk("cy_stop %s\n", tty->name);      /* */
325 #endif
326
327         if (serial_paranoia_check(info, tty->name, "cy_stop"))
328                 return;
329
330         channel = info->line;
331
332         local_irq_save(flags);
333         base_addr[CyCAR] = (u_char) (channel);  /* index channel */
334         base_addr[CyIER] &= ~(CyTxMpty | CyTxRdy);
335         local_irq_restore(flags);
336 }                               /* cy_stop */
337
338 static void cy_start(struct tty_struct *tty)
339 {
340         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
341         volatile unsigned char *base_addr = (unsigned char *)BASE_ADDR;
342         int channel;
343         unsigned long flags;
344
345 #ifdef SERIAL_DEBUG_OTHER
346         printk("cy_start %s\n", tty->name);     /* */
347 #endif
348
349         if (serial_paranoia_check(info, tty->name, "cy_start"))
350                 return;
351
352         channel = info->line;
353
354         local_irq_save(flags);
355         base_addr[CyCAR] = (u_char) (channel);
356         base_addr[CyIER] |= CyTxMpty;
357         local_irq_restore(flags);
358 }                               /* cy_start */
359
360 /* The real interrupt service routines are called
361    whenever the card wants its hand held--chars
362    received, out buffer empty, modem change, etc.
363  */
364 static irqreturn_t cd2401_rxerr_interrupt(int irq, void *dev_id)
365 {
366         struct tty_struct *tty;
367         struct cyclades_port *info;
368         volatile unsigned char *base_addr = (unsigned char *)BASE_ADDR;
369         unsigned char err, rfoc;
370         int channel;
371         char data;
372
373         /* determine the channel and change to that context */
374         channel = (u_short) (base_addr[CyLICR] >> 2);
375         info = &cy_port[channel];
376         info->last_active = jiffies;
377
378         if ((err = base_addr[CyRISR]) & CyTIMEOUT) {
379                 /* This is a receive timeout interrupt, ignore it */
380                 base_addr[CyREOIR] = CyNOTRANS;
381                 return IRQ_HANDLED;
382         }
383
384         /* Read a byte of data if there is any - assume the error
385          * is associated with this character */
386
387         if ((rfoc = base_addr[CyRFOC]) != 0)
388                 data = base_addr[CyRDR];
389         else
390                 data = 0;
391
392         /* if there is nowhere to put the data, discard it */
393         if (info->tty == 0) {
394                 base_addr[CyREOIR] = rfoc ? 0 : CyNOTRANS;
395                 return IRQ_HANDLED;
396         } else {                /* there is an open port for this data */
397                 tty = info->tty;
398                 if (err & info->ignore_status_mask) {
399                         base_addr[CyREOIR] = rfoc ? 0 : CyNOTRANS;
400                         return IRQ_HANDLED;
401                 }
402                 if (tty_buffer_request_room(tty, 1) != 0) {
403                         if (err & info->read_status_mask) {
404                                 if (err & CyBREAK) {
405                                         tty_insert_flip_char(tty, data,
406                                                              TTY_BREAK);
407                                         if (info->flags & ASYNC_SAK) {
408                                                 do_SAK(tty);
409                                         }
410                                 } else if (err & CyFRAME) {
411                                         tty_insert_flip_char(tty, data,
412                                                              TTY_FRAME);
413                                 } else if (err & CyPARITY) {
414                                         tty_insert_flip_char(tty, data,
415                                                              TTY_PARITY);
416                                 } else if (err & CyOVERRUN) {
417                                         tty_insert_flip_char(tty, 0,
418                                                              TTY_OVERRUN);
419                                         /*
420                                            If the flip buffer itself is
421                                            overflowing, we still loose
422                                            the next incoming character.
423                                          */
424                                         if (tty_buffer_request_room(tty, 1) !=
425                                             0) {
426                                                 tty_insert_flip_char(tty, data,
427                                                                      TTY_FRAME);
428                                         }
429                                         /* These two conditions may imply */
430                                         /* a normal read should be done. */
431                                         /* else if(data & CyTIMEOUT) */
432                                         /* else if(data & CySPECHAR) */
433                                 } else {
434                                         tty_insert_flip_char(tty, 0,
435                                                              TTY_NORMAL);
436                                 }
437                         } else {
438                                 tty_insert_flip_char(tty, data, TTY_NORMAL);
439                         }
440                 } else {
441                         /* there was a software buffer overrun
442                            and nothing could be done about it!!! */
443                 }
444         }
445         tty_schedule_flip(tty);
446         /* end of service */
447         base_addr[CyREOIR] = rfoc ? 0 : CyNOTRANS;
448         return IRQ_HANDLED;
449 }                               /* cy_rxerr_interrupt */
450
451 static irqreturn_t cd2401_modem_interrupt(int irq, void *dev_id)
452 {
453         struct cyclades_port *info;
454         volatile unsigned char *base_addr = (unsigned char *)BASE_ADDR;
455         int channel;
456         int mdm_change;
457         int mdm_status;
458
459         /* determine the channel and change to that context */
460         channel = (u_short) (base_addr[CyLICR] >> 2);
461         info = &cy_port[channel];
462         info->last_active = jiffies;
463
464         mdm_change = base_addr[CyMISR];
465         mdm_status = base_addr[CyMSVR1];
466
467         if (info->tty == 0) {   /* nowhere to put the data, ignore it */
468                 ;
469         } else {
470                 if ((mdm_change & CyDCD)
471                     && (info->flags & ASYNC_CHECK_CD)) {
472                         if (mdm_status & CyDCD) {
473 /* CP('!'); */
474                                 wake_up_interruptible(&info->open_wait);
475                         } else {
476 /* CP('@'); */
477                                 tty_hangup(info->tty);
478                                 wake_up_interruptible(&info->open_wait);
479                                 info->flags &= ~ASYNC_NORMAL_ACTIVE;
480                         }
481                 }
482                 if ((mdm_change & CyCTS)
483                     && (info->flags & ASYNC_CTS_FLOW)) {
484                         if (info->tty->stopped) {
485                                 if (mdm_status & CyCTS) {
486                                         /* !!! cy_start isn't used because... */
487                                         info->tty->stopped = 0;
488                                         base_addr[CyIER] |= CyTxMpty;
489                                         tty_wakeup(info->tty);
490                                 }
491                         } else {
492                                 if (!(mdm_status & CyCTS)) {
493                                         /* !!! cy_stop isn't used because... */
494                                         info->tty->stopped = 1;
495                                         base_addr[CyIER] &=
496                                             ~(CyTxMpty | CyTxRdy);
497                                 }
498                         }
499                 }
500                 if (mdm_status & CyDSR) {
501                 }
502         }
503         base_addr[CyMEOIR] = 0;
504         return IRQ_HANDLED;
505 }                               /* cy_modem_interrupt */
506
507 static irqreturn_t cd2401_tx_interrupt(int irq, void *dev_id)
508 {
509         struct cyclades_port *info;
510         volatile unsigned char *base_addr = (unsigned char *)BASE_ADDR;
511         int channel;
512         int char_count, saved_cnt;
513         int outch;
514
515         /* determine the channel and change to that context */
516         channel = (u_short) (base_addr[CyLICR] >> 2);
517
518 #ifdef CONFIG_REMOTE_DEBUG
519         if (channel == DEBUG_PORT) {
520                 panic("TxInt on debug port!!!");
521         }
522 #endif
523
524         info = &cy_port[channel];
525
526         /* validate the port number (as configured and open) */
527         if ((channel < 0) || (NR_PORTS <= channel)) {
528                 base_addr[CyIER] &= ~(CyTxMpty | CyTxRdy);
529                 base_addr[CyTEOIR] = CyNOTRANS;
530                 return IRQ_HANDLED;
531         }
532         info->last_active = jiffies;
533         if (info->tty == 0) {
534                 base_addr[CyIER] &= ~(CyTxMpty | CyTxRdy);
535                 base_addr[CyTEOIR] = CyNOTRANS;
536                 return IRQ_HANDLED;
537         }
538
539         /* load the on-chip space available for outbound data */
540         saved_cnt = char_count = base_addr[CyTFTC];
541
542         if (info->x_char) {     /* send special char */
543                 outch = info->x_char;
544                 base_addr[CyTDR] = outch;
545                 char_count--;
546                 info->x_char = 0;
547         }
548
549         if (info->x_break) {
550                 /*  The Cirrus chip requires the "Embedded Transmit
551                    Commands" of start break, delay, and end break
552                    sequences to be sent.  The duration of the
553                    break is given in TICs, which runs at HZ
554                    (typically 100) and the PPR runs at 200 Hz,
555                    so the delay is duration * 200/HZ, and thus a
556                    break can run from 1/100 sec to about 5/4 sec.
557                    Need to check these values - RGH 141095.
558                  */
559                 base_addr[CyTDR] = 0;   /* start break */
560                 base_addr[CyTDR] = 0x81;
561                 base_addr[CyTDR] = 0;   /* delay a bit */
562                 base_addr[CyTDR] = 0x82;
563                 base_addr[CyTDR] = info->x_break * 200 / HZ;
564                 base_addr[CyTDR] = 0;   /* terminate break */
565                 base_addr[CyTDR] = 0x83;
566                 char_count -= 7;
567                 info->x_break = 0;
568         }
569
570         while (char_count > 0) {
571                 if (!info->xmit_cnt) {
572                         base_addr[CyIER] &= ~(CyTxMpty | CyTxRdy);
573                         break;
574                 }
575                 if (info->xmit_buf == 0) {
576                         base_addr[CyIER] &= ~(CyTxMpty | CyTxRdy);
577                         break;
578                 }
579                 if (info->tty->stopped || info->tty->hw_stopped) {
580                         base_addr[CyIER] &= ~(CyTxMpty | CyTxRdy);
581                         break;
582                 }
583                 /* Because the Embedded Transmit Commands have been
584                    enabled, we must check to see if the escape
585                    character, NULL, is being sent.  If it is, we
586                    must ensure that there is room for it to be
587                    doubled in the output stream.  Therefore we
588                    no longer advance the pointer when the character
589                    is fetched, but rather wait until after the check
590                    for a NULL output character. (This is necessary
591                    because there may not be room for the two chars
592                    needed to send a NULL.
593                  */
594                 outch = info->xmit_buf[info->xmit_tail];
595                 if (outch) {
596                         info->xmit_cnt--;
597                         info->xmit_tail = (info->xmit_tail + 1)
598                             & (PAGE_SIZE - 1);
599                         base_addr[CyTDR] = outch;
600                         char_count--;
601                 } else {
602                         if (char_count > 1) {
603                                 info->xmit_cnt--;
604                                 info->xmit_tail = (info->xmit_tail + 1)
605                                     & (PAGE_SIZE - 1);
606                                 base_addr[CyTDR] = outch;
607                                 base_addr[CyTDR] = 0;
608                                 char_count--;
609                                 char_count--;
610                         } else {
611                                 break;
612                         }
613                 }
614         }
615
616         if (info->xmit_cnt < WAKEUP_CHARS)
617                 tty_wakeup(info->tty);
618
619         base_addr[CyTEOIR] = (char_count != saved_cnt) ? 0 : CyNOTRANS;
620         return IRQ_HANDLED;
621 }                               /* cy_tx_interrupt */
622
623 static irqreturn_t cd2401_rx_interrupt(int irq, void *dev_id)
624 {
625         struct tty_struct *tty;
626         struct cyclades_port *info;
627         volatile unsigned char *base_addr = (unsigned char *)BASE_ADDR;
628         int channel;
629         char data;
630         int char_count;
631         int save_cnt;
632         int len;
633
634         /* determine the channel and change to that context */
635         channel = (u_short) (base_addr[CyLICR] >> 2);
636         info = &cy_port[channel];
637         info->last_active = jiffies;
638         save_cnt = char_count = base_addr[CyRFOC];
639
640 #ifdef CONFIG_REMOTE_DEBUG
641         if (channel == DEBUG_PORT) {
642                 while (char_count--) {
643                         data = base_addr[CyRDR];
644                         queueDebugChar(data);
645                 }
646         } else
647 #endif
648                 /* if there is nowhere to put the data, discard it */
649         if (info->tty == 0) {
650                 while (char_count--) {
651                         data = base_addr[CyRDR];
652                 }
653         } else {                /* there is an open port for this data */
654                 tty = info->tty;
655                 /* load # characters available from the chip */
656
657 #ifdef CYCLOM_ENABLE_MONITORING
658                 ++info->mon.int_count;
659                 info->mon.char_count += char_count;
660                 if (char_count > info->mon.char_max)
661                         info->mon.char_max = char_count;
662                 info->mon.char_last = char_count;
663 #endif
664                 len = tty_buffer_request_room(tty, char_count);
665                 while (len--) {
666                         data = base_addr[CyRDR];
667                         tty_insert_flip_char(tty, data, TTY_NORMAL);
668 #ifdef CYCLOM_16Y_HACK
669                         udelay(10L);
670 #endif
671                 }
672                 tty_schedule_flip(tty);
673         }
674         /* end of service */
675         base_addr[CyREOIR] = save_cnt ? 0 : CyNOTRANS;
676         return IRQ_HANDLED;
677 }                               /* cy_rx_interrupt */
678
679 /* This is called whenever a port becomes active;
680    interrupts are enabled and DTR & RTS are turned on.
681  */
682 static int startup(struct cyclades_port *info)
683 {
684         unsigned long flags;
685         volatile unsigned char *base_addr = (unsigned char *)BASE_ADDR;
686         int channel;
687
688         if (info->flags & ASYNC_INITIALIZED) {
689                 return 0;
690         }
691
692         if (!info->type) {
693                 if (info->tty) {
694                         set_bit(TTY_IO_ERROR, &info->tty->flags);
695                 }
696                 return 0;
697         }
698         if (!info->xmit_buf) {
699                 info->xmit_buf = (unsigned char *)get_zeroed_page(GFP_KERNEL);
700                 if (!info->xmit_buf) {
701                         return -ENOMEM;
702                 }
703         }
704
705         config_setup(info);
706
707         channel = info->line;
708
709 #ifdef SERIAL_DEBUG_OPEN
710         printk("startup channel %d\n", channel);
711 #endif
712
713         local_irq_save(flags);
714         base_addr[CyCAR] = (u_char) channel;
715         write_cy_cmd(base_addr, CyENB_RCVR | CyENB_XMTR);
716
717         base_addr[CyCAR] = (u_char) channel;    /* !!! Is this needed? */
718         base_addr[CyMSVR1] = CyRTS;
719 /* CP('S');CP('1'); */
720         base_addr[CyMSVR2] = CyDTR;
721
722 #ifdef SERIAL_DEBUG_DTR
723         printk("cyc: %d: raising DTR\n", __LINE__);
724         printk("     status: 0x%x, 0x%x\n", base_addr[CyMSVR1],
725                base_addr[CyMSVR2]);
726 #endif
727
728         base_addr[CyIER] |= CyRxData;
729         info->flags |= ASYNC_INITIALIZED;
730
731         if (info->tty) {
732                 clear_bit(TTY_IO_ERROR, &info->tty->flags);
733         }
734         info->xmit_cnt = info->xmit_head = info->xmit_tail = 0;
735
736         local_irq_restore(flags);
737
738 #ifdef SERIAL_DEBUG_OPEN
739         printk(" done\n");
740 #endif
741         return 0;
742 }                               /* startup */
743
744 void start_xmit(struct cyclades_port *info)
745 {
746         unsigned long flags;
747         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
748         int channel;
749
750         channel = info->line;
751         local_irq_save(flags);
752         base_addr[CyCAR] = channel;
753         base_addr[CyIER] |= CyTxMpty;
754         local_irq_restore(flags);
755 }                               /* start_xmit */
756
757 /*
758  * This routine shuts down a serial port; interrupts are disabled,
759  * and DTR is dropped if the hangup on close termio flag is on.
760  */
761 static void shutdown(struct cyclades_port *info)
762 {
763         unsigned long flags;
764         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
765         int channel;
766
767         if (!(info->flags & ASYNC_INITIALIZED)) {
768 /* CP('$'); */
769                 return;
770         }
771
772         channel = info->line;
773
774 #ifdef SERIAL_DEBUG_OPEN
775         printk("shutdown channel %d\n", channel);
776 #endif
777
778         /* !!! REALLY MUST WAIT FOR LAST CHARACTER TO BE
779            SENT BEFORE DROPPING THE LINE !!!  (Perhaps
780            set some flag that is read when XMTY happens.)
781            Other choices are to delay some fixed interval
782            or schedule some later processing.
783          */
784         local_irq_save(flags);
785         if (info->xmit_buf) {
786                 free_page((unsigned long)info->xmit_buf);
787                 info->xmit_buf = NULL;
788         }
789
790         base_addr[CyCAR] = (u_char) channel;
791         if (!info->tty || (info->tty->termios->c_cflag & HUPCL)) {
792                 base_addr[CyMSVR1] = 0;
793 /* CP('C');CP('1'); */
794                 base_addr[CyMSVR2] = 0;
795 #ifdef SERIAL_DEBUG_DTR
796                 printk("cyc: %d: dropping DTR\n", __LINE__);
797                 printk("     status: 0x%x, 0x%x\n", base_addr[CyMSVR1],
798                        base_addr[CyMSVR2]);
799 #endif
800         }
801         write_cy_cmd(base_addr, CyDIS_RCVR);
802         /* it may be appropriate to clear _XMIT at
803            some later date (after testing)!!! */
804
805         if (info->tty) {
806                 set_bit(TTY_IO_ERROR, &info->tty->flags);
807         }
808         info->flags &= ~ASYNC_INITIALIZED;
809         local_irq_restore(flags);
810
811 #ifdef SERIAL_DEBUG_OPEN
812         printk(" done\n");
813 #endif
814 }                               /* shutdown */
815
816 /*
817  * This routine finds or computes the various line characteristics.
818  */
819 static void config_setup(struct cyclades_port *info)
820 {
821         unsigned long flags;
822         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
823         int channel;
824         unsigned cflag;
825         int i;
826         unsigned char ti, need_init_chan = 0;
827
828         if (!info->tty || !info->tty->termios) {
829                 return;
830         }
831         if (info->line == -1) {
832                 return;
833         }
834         cflag = info->tty->termios->c_cflag;
835
836         /* baud rate */
837         i = cflag & CBAUD;
838 #ifdef CBAUDEX
839 /* Starting with kernel 1.1.65, there is direct support for
840    higher baud rates.  The following code supports those
841    changes.  The conditional aspect allows this driver to be
842    used for earlier as well as later kernel versions.  (The
843    mapping is slightly different from serial.c because there
844    is still the possibility of supporting 75 kbit/sec with
845    the Cyclades board.)
846  */
847         if (i & CBAUDEX) {
848                 if (i == B57600)
849                         i = 16;
850                 else if (i == B115200)
851                         i = 18;
852 #ifdef B78600
853                 else if (i == B78600)
854                         i = 17;
855 #endif
856                 else
857                         info->tty->termios->c_cflag &= ~CBAUDEX;
858         }
859 #endif
860         if (i == 15) {
861                 if ((info->flags & ASYNC_SPD_MASK) == ASYNC_SPD_HI)
862                         i += 1;
863                 if ((info->flags & ASYNC_SPD_MASK) == ASYNC_SPD_VHI)
864                         i += 3;
865         }
866         /* Don't ever change the speed of the console port.  It will
867          * run at the speed specified in bootinfo, or at 19.2K */
868         /* Actually, it should run at whatever speed 166Bug was using */
869         /* Note info->timeout isn't used at present */
870         if (info != serial_console_info) {
871                 info->tbpr = baud_bpr[i];       /* Tx BPR */
872                 info->tco = baud_co[i]; /* Tx CO */
873                 info->rbpr = baud_bpr[i];       /* Rx BPR */
874                 info->rco = baud_co[i] >> 5;    /* Rx CO */
875                 if (baud_table[i] == 134) {
876                         info->timeout =
877                             (info->xmit_fifo_size * HZ * 30 / 269) + 2;
878                         /* get it right for 134.5 baud */
879                 } else if (baud_table[i]) {
880                         info->timeout =
881                             (info->xmit_fifo_size * HZ * 15 / baud_table[i]) +
882                             2;
883                         /* this needs to be propagated into the card info */
884                 } else {
885                         info->timeout = 0;
886                 }
887         }
888         /* By tradition (is it a standard?) a baud rate of zero
889            implies the line should be/has been closed.  A bit
890            later in this routine such a test is performed. */
891
892         /* byte size and parity */
893         info->cor7 = 0;
894         info->cor6 = 0;
895         info->cor5 = 0;
896         info->cor4 = (info->default_threshold ? info->default_threshold : baud_cor4[i]);        /* receive threshold */
897         /* Following two lines added 101295, RGH. */
898         /* It is obviously wrong to access CyCORx, and not info->corx here,
899          * try and remember to fix it later! */
900         channel = info->line;
901         base_addr[CyCAR] = (u_char) channel;
902         if (C_CLOCAL(info->tty)) {
903                 if (base_addr[CyIER] & CyMdmCh)
904                         base_addr[CyIER] &= ~CyMdmCh;   /* without modem intr */
905                 /* ignore 1->0 modem transitions */
906                 if (base_addr[CyCOR4] & (CyDSR | CyCTS | CyDCD))
907                         base_addr[CyCOR4] &= ~(CyDSR | CyCTS | CyDCD);
908                 /* ignore 0->1 modem transitions */
909                 if (base_addr[CyCOR5] & (CyDSR | CyCTS | CyDCD))
910                         base_addr[CyCOR5] &= ~(CyDSR | CyCTS | CyDCD);
911         } else {
912                 if ((base_addr[CyIER] & CyMdmCh) != CyMdmCh)
913                         base_addr[CyIER] |= CyMdmCh;    /* with modem intr */
914                 /* act on 1->0 modem transitions */
915                 if ((base_addr[CyCOR4] & (CyDSR | CyCTS | CyDCD)) !=
916                     (CyDSR | CyCTS | CyDCD))
917                         base_addr[CyCOR4] |= CyDSR | CyCTS | CyDCD;
918                 /* act on 0->1 modem transitions */
919                 if ((base_addr[CyCOR5] & (CyDSR | CyCTS | CyDCD)) !=
920                     (CyDSR | CyCTS | CyDCD))
921                         base_addr[CyCOR5] |= CyDSR | CyCTS | CyDCD;
922         }
923         info->cor3 = (cflag & CSTOPB) ? Cy_2_STOP : Cy_1_STOP;
924         info->cor2 = CyETC;
925         switch (cflag & CSIZE) {
926         case CS5:
927                 info->cor1 = Cy_5_BITS;
928                 break;
929         case CS6:
930                 info->cor1 = Cy_6_BITS;
931                 break;
932         case CS7:
933                 info->cor1 = Cy_7_BITS;
934                 break;
935         case CS8:
936                 info->cor1 = Cy_8_BITS;
937                 break;
938         }
939         if (cflag & PARENB) {
940                 if (cflag & PARODD) {
941                         info->cor1 |= CyPARITY_O;
942                 } else {
943                         info->cor1 |= CyPARITY_E;
944                 }
945         } else {
946                 info->cor1 |= CyPARITY_NONE;
947         }
948
949         /* CTS flow control flag */
950 #if 0
951         /* Don't complcate matters for now! RGH 141095 */
952         if (cflag & CRTSCTS) {
953                 info->flags |= ASYNC_CTS_FLOW;
954                 info->cor2 |= CyCtsAE;
955         } else {
956                 info->flags &= ~ASYNC_CTS_FLOW;
957                 info->cor2 &= ~CyCtsAE;
958         }
959 #endif
960         if (cflag & CLOCAL)
961                 info->flags &= ~ASYNC_CHECK_CD;
962         else
963                 info->flags |= ASYNC_CHECK_CD;
964
965      /***********************************************
966         The hardware option, CyRtsAO, presents RTS when
967         the chip has characters to send.  Since most modems
968         use RTS as reverse (inbound) flow control, this
969         option is not used.  If inbound flow control is
970         necessary, DTR can be programmed to provide the
971         appropriate signals for use with a non-standard
972         cable.  Contact Marcio Saito for details.
973      ***********************************************/
974
975         channel = info->line;
976
977         local_irq_save(flags);
978         base_addr[CyCAR] = (u_char) channel;
979
980         /* CyCMR set once only in mvme167_init_serial() */
981         if (base_addr[CyLICR] != channel << 2)
982                 base_addr[CyLICR] = channel << 2;
983         if (base_addr[CyLIVR] != 0x5c)
984                 base_addr[CyLIVR] = 0x5c;
985
986         /* tx and rx baud rate */
987
988         if (base_addr[CyCOR1] != info->cor1)
989                 need_init_chan = 1;
990         if (base_addr[CyTCOR] != info->tco)
991                 base_addr[CyTCOR] = info->tco;
992         if (base_addr[CyTBPR] != info->tbpr)
993                 base_addr[CyTBPR] = info->tbpr;
994         if (base_addr[CyRCOR] != info->rco)
995                 base_addr[CyRCOR] = info->rco;
996         if (base_addr[CyRBPR] != info->rbpr)
997                 base_addr[CyRBPR] = info->rbpr;
998
999         /* set line characteristics  according configuration */
1000
1001         if (base_addr[CySCHR1] != START_CHAR(info->tty))
1002                 base_addr[CySCHR1] = START_CHAR(info->tty);
1003         if (base_addr[CySCHR2] != STOP_CHAR(info->tty))
1004                 base_addr[CySCHR2] = STOP_CHAR(info->tty);
1005         if (base_addr[CySCRL] != START_CHAR(info->tty))
1006                 base_addr[CySCRL] = START_CHAR(info->tty);
1007         if (base_addr[CySCRH] != START_CHAR(info->tty))
1008                 base_addr[CySCRH] = START_CHAR(info->tty);
1009         if (base_addr[CyCOR1] != info->cor1)
1010                 base_addr[CyCOR1] = info->cor1;
1011         if (base_addr[CyCOR2] != info->cor2)
1012                 base_addr[CyCOR2] = info->cor2;
1013         if (base_addr[CyCOR3] != info->cor3)
1014                 base_addr[CyCOR3] = info->cor3;
1015         if (base_addr[CyCOR4] != info->cor4)
1016                 base_addr[CyCOR4] = info->cor4;
1017         if (base_addr[CyCOR5] != info->cor5)
1018                 base_addr[CyCOR5] = info->cor5;
1019         if (base_addr[CyCOR6] != info->cor6)
1020                 base_addr[CyCOR6] = info->cor6;
1021         if (base_addr[CyCOR7] != info->cor7)
1022                 base_addr[CyCOR7] = info->cor7;
1023
1024         if (need_init_chan)
1025                 write_cy_cmd(base_addr, CyINIT_CHAN);
1026
1027         base_addr[CyCAR] = (u_char) channel;    /* !!! Is this needed? */
1028
1029         /* 2ms default rx timeout */
1030         ti = info->default_timeout ? info->default_timeout : 0x02;
1031         if (base_addr[CyRTPRL] != ti)
1032                 base_addr[CyRTPRL] = ti;
1033         if (base_addr[CyRTPRH] != 0)
1034                 base_addr[CyRTPRH] = 0;
1035
1036         /* Set up RTS here also ????? RGH 141095 */
1037         if (i == 0) {           /* baud rate is zero, turn off line */
1038                 if ((base_addr[CyMSVR2] & CyDTR) == CyDTR)
1039                         base_addr[CyMSVR2] = 0;
1040 #ifdef SERIAL_DEBUG_DTR
1041                 printk("cyc: %d: dropping DTR\n", __LINE__);
1042                 printk("     status: 0x%x, 0x%x\n", base_addr[CyMSVR1],
1043                        base_addr[CyMSVR2]);
1044 #endif
1045         } else {
1046                 if ((base_addr[CyMSVR2] & CyDTR) != CyDTR)
1047                         base_addr[CyMSVR2] = CyDTR;
1048 #ifdef SERIAL_DEBUG_DTR
1049                 printk("cyc: %d: raising DTR\n", __LINE__);
1050                 printk("     status: 0x%x, 0x%x\n", base_addr[CyMSVR1],
1051                        base_addr[CyMSVR2]);
1052 #endif
1053         }
1054
1055         if (info->tty) {
1056                 clear_bit(TTY_IO_ERROR, &info->tty->flags);
1057         }
1058
1059         local_irq_restore(flags);
1060
1061 }                               /* config_setup */
1062
1063 static void cy_put_char(struct tty_struct *tty, unsigned char ch)
1064 {
1065         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1066         unsigned long flags;
1067
1068 #ifdef SERIAL_DEBUG_IO
1069         printk("cy_put_char %s(0x%02x)\n", tty->name, ch);
1070 #endif
1071
1072         if (serial_paranoia_check(info, tty->name, "cy_put_char"))
1073                 return;
1074
1075         if (!info->xmit_buf)
1076                 return;
1077
1078         local_irq_save(flags);
1079         if (info->xmit_cnt >= PAGE_SIZE - 1) {
1080                 local_irq_restore(flags);
1081                 return;
1082         }
1083
1084         info->xmit_buf[info->xmit_head++] = ch;
1085         info->xmit_head &= PAGE_SIZE - 1;
1086         info->xmit_cnt++;
1087         local_irq_restore(flags);
1088 }                               /* cy_put_char */
1089
1090 static void cy_flush_chars(struct tty_struct *tty)
1091 {
1092         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1093         unsigned long flags;
1094         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
1095         int channel;
1096
1097 #ifdef SERIAL_DEBUG_IO
1098         printk("cy_flush_chars %s\n", tty->name);       /* */
1099 #endif
1100
1101         if (serial_paranoia_check(info, tty->name, "cy_flush_chars"))
1102                 return;
1103
1104         if (info->xmit_cnt <= 0 || tty->stopped
1105             || tty->hw_stopped || !info->xmit_buf)
1106                 return;
1107
1108         channel = info->line;
1109
1110         local_irq_save(flags);
1111         base_addr[CyCAR] = channel;
1112         base_addr[CyIER] |= CyTxMpty;
1113         local_irq_restore(flags);
1114 }                               /* cy_flush_chars */
1115
1116 /* This routine gets called when tty_write has put something into
1117     the write_queue.  If the port is not already transmitting stuff,
1118     start it off by enabling interrupts.  The interrupt service
1119     routine will then ensure that the characters are sent.  If the
1120     port is already active, there is no need to kick it.
1121  */
1122 static int cy_write(struct tty_struct *tty, const unsigned char *buf, int count)
1123 {
1124         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1125         unsigned long flags;
1126         int c, total = 0;
1127
1128 #ifdef SERIAL_DEBUG_IO
1129         printk("cy_write %s\n", tty->name);     /* */
1130 #endif
1131
1132         if (serial_paranoia_check(info, tty->name, "cy_write")) {
1133                 return 0;
1134         }
1135
1136         if (!info->xmit_buf) {
1137                 return 0;
1138         }
1139
1140         while (1) {
1141                 local_irq_save(flags);
1142                 c = min_t(int, count, min(SERIAL_XMIT_SIZE - info->xmit_cnt - 1,
1143                                           SERIAL_XMIT_SIZE - info->xmit_head));
1144                 if (c <= 0) {
1145                         local_irq_restore(flags);
1146                         break;
1147                 }
1148
1149                 memcpy(info->xmit_buf + info->xmit_head, buf, c);
1150                 info->xmit_head =
1151                     (info->xmit_head + c) & (SERIAL_XMIT_SIZE - 1);
1152                 info->xmit_cnt += c;
1153                 local_irq_restore(flags);
1154
1155                 buf += c;
1156                 count -= c;
1157                 total += c;
1158         }
1159
1160         if (info->xmit_cnt && !tty->stopped && !tty->hw_stopped) {
1161                 start_xmit(info);
1162         }
1163         return total;
1164 }                               /* cy_write */
1165
1166 static int cy_write_room(struct tty_struct *tty)
1167 {
1168         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1169         int ret;
1170
1171 #ifdef SERIAL_DEBUG_IO
1172         printk("cy_write_room %s\n", tty->name);        /* */
1173 #endif
1174
1175         if (serial_paranoia_check(info, tty->name, "cy_write_room"))
1176                 return 0;
1177         ret = PAGE_SIZE - info->xmit_cnt - 1;
1178         if (ret < 0)
1179                 ret = 0;
1180         return ret;
1181 }                               /* cy_write_room */
1182
1183 static int cy_chars_in_buffer(struct tty_struct *tty)
1184 {
1185         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1186
1187 #ifdef SERIAL_DEBUG_IO
1188         printk("cy_chars_in_buffer %s %d\n", tty->name, info->xmit_cnt);        /* */
1189 #endif
1190
1191         if (serial_paranoia_check(info, tty->name, "cy_chars_in_buffer"))
1192                 return 0;
1193
1194         return info->xmit_cnt;
1195 }                               /* cy_chars_in_buffer */
1196
1197 static void cy_flush_buffer(struct tty_struct *tty)
1198 {
1199         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1200         unsigned long flags;
1201
1202 #ifdef SERIAL_DEBUG_IO
1203         printk("cy_flush_buffer %s\n", tty->name);      /* */
1204 #endif
1205
1206         if (serial_paranoia_check(info, tty->name, "cy_flush_buffer"))
1207                 return;
1208         local_irq_save(flags);
1209         info->xmit_cnt = info->xmit_head = info->xmit_tail = 0;
1210         local_irq_restore(flags);
1211         tty_wakeup(tty);
1212 }                               /* cy_flush_buffer */
1213
1214 /* This routine is called by the upper-layer tty layer to signal
1215    that incoming characters should be throttled or that the
1216    throttle should be released.
1217  */
1218 static void cy_throttle(struct tty_struct *tty)
1219 {
1220         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1221         unsigned long flags;
1222         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
1223         int channel;
1224
1225 #ifdef SERIAL_DEBUG_THROTTLE
1226         char buf[64];
1227
1228         printk("throttle %s: %d....\n", tty_name(tty, buf),
1229                tty->ldisc.chars_in_buffer(tty));
1230         printk("cy_throttle %s\n", tty->name);
1231 #endif
1232
1233         if (serial_paranoia_check(info, tty->name, "cy_nthrottle")) {
1234                 return;
1235         }
1236
1237         if (I_IXOFF(tty)) {
1238                 info->x_char = STOP_CHAR(tty);
1239                 /* Should use the "Send Special Character" feature!!! */
1240         }
1241
1242         channel = info->line;
1243
1244         local_irq_save(flags);
1245         base_addr[CyCAR] = (u_char) channel;
1246         base_addr[CyMSVR1] = 0;
1247         local_irq_restore(flags);
1248 }                               /* cy_throttle */
1249
1250 static void cy_unthrottle(struct tty_struct *tty)
1251 {
1252         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1253         unsigned long flags;
1254         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
1255         int channel;
1256
1257 #ifdef SERIAL_DEBUG_THROTTLE
1258         char buf[64];
1259
1260         printk("throttle %s: %d....\n", tty_name(tty, buf),
1261                tty->ldisc.chars_in_buffer(tty));
1262         printk("cy_unthrottle %s\n", tty->name);
1263 #endif
1264
1265         if (serial_paranoia_check(info, tty->name, "cy_nthrottle")) {
1266                 return;
1267         }
1268
1269         if (I_IXOFF(tty)) {
1270                 info->x_char = START_CHAR(tty);
1271                 /* Should use the "Send Special Character" feature!!! */
1272         }
1273
1274         channel = info->line;
1275
1276         local_irq_save(flags);
1277         base_addr[CyCAR] = (u_char) channel;
1278         base_addr[CyMSVR1] = CyRTS;
1279         local_irq_restore(flags);
1280 }                               /* cy_unthrottle */
1281
1282 static int
1283 get_serial_info(struct cyclades_port *info,
1284                 struct serial_struct __user * retinfo)
1285 {
1286         struct serial_struct tmp;
1287
1288 /* CP('g'); */
1289         if (!retinfo)
1290                 return -EFAULT;
1291         memset(&tmp, 0, sizeof(tmp));
1292         tmp.type = info->type;
1293         tmp.line = info->line;
1294         tmp.port = info->line;
1295         tmp.irq = 0;
1296         tmp.flags = info->flags;
1297         tmp.baud_base = 0;      /*!!! */
1298         tmp.close_delay = info->close_delay;
1299         tmp.custom_divisor = 0; /*!!! */
1300         tmp.hub6 = 0;           /*!!! */
1301         return copy_to_user(retinfo, &tmp, sizeof(*retinfo)) ? -EFAULT : 0;
1302 }                               /* get_serial_info */
1303
1304 static int
1305 set_serial_info(struct cyclades_port *info,
1306                 struct serial_struct __user * new_info)
1307 {
1308         struct serial_struct new_serial;
1309         struct cyclades_port old_info;
1310
1311 /* CP('s'); */
1312         if (!new_info)
1313                 return -EFAULT;
1314         if (copy_from_user(&new_serial, new_info, sizeof(new_serial)))
1315                 return -EFAULT;
1316         old_info = *info;
1317
1318         if (!capable(CAP_SYS_ADMIN)) {
1319                 if ((new_serial.close_delay != info->close_delay) ||
1320                     ((new_serial.flags & ASYNC_FLAGS & ~ASYNC_USR_MASK) !=
1321                      (info->flags & ASYNC_FLAGS & ~ASYNC_USR_MASK)))
1322                         return -EPERM;
1323                 info->flags = ((info->flags & ~ASYNC_USR_MASK) |
1324                                (new_serial.flags & ASYNC_USR_MASK));
1325                 goto check_and_exit;
1326         }
1327
1328         /*
1329          * OK, past this point, all the error checking has been done.
1330          * At this point, we start making changes.....
1331          */
1332
1333         info->flags = ((info->flags & ~ASYNC_FLAGS) |
1334                        (new_serial.flags & ASYNC_FLAGS));
1335         info->close_delay = new_serial.close_delay;
1336
1337 check_and_exit:
1338         if (info->flags & ASYNC_INITIALIZED) {
1339                 config_setup(info);
1340                 return 0;
1341         }
1342         return startup(info);
1343 }                               /* set_serial_info */
1344
1345 static int cy_tiocmget(struct tty_struct *tty, struct file *file)
1346 {
1347         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1348         int channel;
1349         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
1350         unsigned long flags;
1351         unsigned char status;
1352
1353         channel = info->line;
1354
1355         local_irq_save(flags);
1356         base_addr[CyCAR] = (u_char) channel;
1357         status = base_addr[CyMSVR1] | base_addr[CyMSVR2];
1358         local_irq_restore(flags);
1359
1360         return ((status & CyRTS) ? TIOCM_RTS : 0)
1361             | ((status & CyDTR) ? TIOCM_DTR : 0)
1362             | ((status & CyDCD) ? TIOCM_CAR : 0)
1363             | ((status & CyDSR) ? TIOCM_DSR : 0)
1364             | ((status & CyCTS) ? TIOCM_CTS : 0);
1365 }                               /* cy_tiocmget */
1366
1367 static int
1368 cy_tiocmset(struct tty_struct *tty, struct file *file,
1369             unsigned int set, unsigned int clear)
1370 {
1371         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1372         int channel;
1373         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
1374         unsigned long flags;
1375
1376         channel = info->line;
1377
1378         if (set & TIOCM_RTS) {
1379                 local_irq_save(flags);
1380                 base_addr[CyCAR] = (u_char) channel;
1381                 base_addr[CyMSVR1] = CyRTS;
1382                 local_irq_restore(flags);
1383         }
1384         if (set & TIOCM_DTR) {
1385                 local_irq_save(flags);
1386                 base_addr[CyCAR] = (u_char) channel;
1387 /* CP('S');CP('2'); */
1388                 base_addr[CyMSVR2] = CyDTR;
1389 #ifdef SERIAL_DEBUG_DTR
1390                 printk("cyc: %d: raising DTR\n", __LINE__);
1391                 printk("     status: 0x%x, 0x%x\n", base_addr[CyMSVR1],
1392                        base_addr[CyMSVR2]);
1393 #endif
1394                 local_irq_restore(flags);
1395         }
1396
1397         if (clear & TIOCM_RTS) {
1398                 local_irq_save(flags);
1399                 base_addr[CyCAR] = (u_char) channel;
1400                 base_addr[CyMSVR1] = 0;
1401                 local_irq_restore(flags);
1402         }
1403         if (clear & TIOCM_DTR) {
1404                 local_irq_save(flags);
1405                 base_addr[CyCAR] = (u_char) channel;
1406 /* CP('C');CP('2'); */
1407                 base_addr[CyMSVR2] = 0;
1408 #ifdef SERIAL_DEBUG_DTR
1409                 printk("cyc: %d: dropping DTR\n", __LINE__);
1410                 printk("     status: 0x%x, 0x%x\n", base_addr[CyMSVR1],
1411                        base_addr[CyMSVR2]);
1412 #endif
1413                 local_irq_restore(flags);
1414         }
1415
1416         return 0;
1417 }                               /* set_modem_info */
1418
1419 static void send_break(struct cyclades_port *info, int duration)
1420 {                               /* Let the transmit ISR take care of this (since it
1421                                    requires stuffing characters into the output stream).
1422                                  */
1423         info->x_break = duration;
1424         if (!info->xmit_cnt) {
1425                 start_xmit(info);
1426         }
1427 }                               /* send_break */
1428
1429 static int
1430 get_mon_info(struct cyclades_port *info, struct cyclades_monitor __user * mon)
1431 {
1432
1433         if (copy_to_user(mon, &info->mon, sizeof(struct cyclades_monitor)))
1434                 return -EFAULT;
1435         info->mon.int_count = 0;
1436         info->mon.char_count = 0;
1437         info->mon.char_max = 0;
1438         info->mon.char_last = 0;
1439         return 0;
1440 }
1441
1442 static int set_threshold(struct cyclades_port *info, unsigned long __user * arg)
1443 {
1444         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
1445         unsigned long value;
1446         int channel;
1447
1448         if (get_user(value, arg))
1449                 return -EFAULT;
1450
1451         channel = info->line;
1452         info->cor4 &= ~CyREC_FIFO;
1453         info->cor4 |= value & CyREC_FIFO;
1454         base_addr[CyCOR4] = info->cor4;
1455         return 0;
1456 }
1457
1458 static int
1459 get_threshold(struct cyclades_port *info, unsigned long __user * value)
1460 {
1461         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
1462         int channel;
1463         unsigned long tmp;
1464
1465         channel = info->line;
1466
1467         tmp = base_addr[CyCOR4] & CyREC_FIFO;
1468         return put_user(tmp, value);
1469 }
1470
1471 static int
1472 set_default_threshold(struct cyclades_port *info, unsigned long __user * arg)
1473 {
1474         unsigned long value;
1475
1476         if (get_user(value, arg))
1477                 return -EFAULT;
1478
1479         info->default_threshold = value & 0x0f;
1480         return 0;
1481 }
1482
1483 static int
1484 get_default_threshold(struct cyclades_port *info, unsigned long __user * value)
1485 {
1486         return put_user(info->default_threshold, value);
1487 }
1488
1489 static int set_timeout(struct cyclades_port *info, unsigned long __user * arg)
1490 {
1491         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
1492         int channel;
1493         unsigned long value;
1494
1495         if (get_user(value, arg))
1496                 return -EFAULT;
1497
1498         channel = info->line;
1499
1500         base_addr[CyRTPRL] = value & 0xff;
1501         base_addr[CyRTPRH] = (value >> 8) & 0xff;
1502         return 0;
1503 }
1504
1505 static int get_timeout(struct cyclades_port *info, unsigned long __user * value)
1506 {
1507         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
1508         int channel;
1509         unsigned long tmp;
1510
1511         channel = info->line;
1512
1513         tmp = base_addr[CyRTPRL];
1514         return put_user(tmp, value);
1515 }
1516
1517 static int set_default_timeout(struct cyclades_port *info, unsigned long value)
1518 {
1519         info->default_timeout = value & 0xff;
1520         return 0;
1521 }
1522
1523 static int
1524 get_default_timeout(struct cyclades_port *info, unsigned long __user * value)
1525 {
1526         return put_user(info->default_timeout, value);
1527 }
1528
1529 static int
1530 cy_ioctl(struct tty_struct *tty, struct file *file,
1531          unsigned int cmd, unsigned long arg)
1532 {
1533         unsigned long val;
1534         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1535         int ret_val = 0;
1536         void __user *argp = (void __user *)arg;
1537
1538 #ifdef SERIAL_DEBUG_OTHER
1539         printk("cy_ioctl %s, cmd = %x arg = %lx\n", tty->name, cmd, arg);       /* */
1540 #endif
1541
1542         lock_kernel();
1543
1544         switch (cmd) {
1545         case CYGETMON:
1546                 ret_val = get_mon_info(info, argp);
1547                 break;
1548         case CYGETTHRESH:
1549                 ret_val = get_threshold(info, argp);
1550                 break;
1551         case CYSETTHRESH:
1552                 ret_val = set_threshold(info, argp);
1553                 break;
1554         case CYGETDEFTHRESH:
1555                 ret_val = get_default_threshold(info, argp);
1556                 break;
1557         case CYSETDEFTHRESH:
1558                 ret_val = set_default_threshold(info, argp);
1559                 break;
1560         case CYGETTIMEOUT:
1561                 ret_val = get_timeout(info, argp);
1562                 break;
1563         case CYSETTIMEOUT:
1564                 ret_val = set_timeout(info, argp);
1565                 break;
1566         case CYGETDEFTIMEOUT:
1567                 ret_val = get_default_timeout(info, argp);
1568                 break;
1569         case CYSETDEFTIMEOUT:
1570                 ret_val = set_default_timeout(info, (unsigned long)arg);
1571                 break;
1572         case TCSBRK:            /* SVID version: non-zero arg --> no break */
1573                 ret_val = tty_check_change(tty);
1574                 if (ret_val)
1575                         break;
1576                 tty_wait_until_sent(tty, 0);
1577                 if (!arg)
1578                         send_break(info, HZ / 4);       /* 1/4 second */
1579                 break;
1580         case TCSBRKP:           /* support for POSIX tcsendbreak() */
1581                 ret_val = tty_check_change(tty);
1582                 if (ret_val)
1583                         break;
1584                 tty_wait_until_sent(tty, 0);
1585                 send_break(info, arg ? arg * (HZ / 10) : HZ / 4);
1586                 break;
1587
1588 /* The following commands are incompletely implemented!!! */
1589         case TIOCGSERIAL:
1590                 ret_val = get_serial_info(info, argp);
1591                 break;
1592         case TIOCSSERIAL:
1593                 ret_val = set_serial_info(info, argp);
1594                 break;
1595         default:
1596                 ret_val = -ENOIOCTLCMD;
1597         }
1598         unlock_kernel();
1599
1600 #ifdef SERIAL_DEBUG_OTHER
1601         printk("cy_ioctl done\n");
1602 #endif
1603
1604         return ret_val;
1605 }                               /* cy_ioctl */
1606
1607 static void cy_set_termios(struct tty_struct *tty, struct ktermios *old_termios)
1608 {
1609         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1610
1611 #ifdef SERIAL_DEBUG_OTHER
1612         printk("cy_set_termios %s\n", tty->name);
1613 #endif
1614
1615         if (tty->termios->c_cflag == old_termios->c_cflag)
1616                 return;
1617         config_setup(info);
1618
1619         if ((old_termios->c_cflag & CRTSCTS) &&
1620             !(tty->termios->c_cflag & CRTSCTS)) {
1621                 tty->stopped = 0;
1622                 cy_start(tty);
1623         }
1624 #ifdef tytso_patch_94Nov25_1726
1625         if (!(old_termios->c_cflag & CLOCAL) &&
1626             (tty->termios->c_cflag & CLOCAL))
1627                 wake_up_interruptible(&info->open_wait);
1628 #endif
1629 }                               /* cy_set_termios */
1630
1631 static void cy_close(struct tty_struct *tty, struct file *filp)
1632 {
1633         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1634
1635 /* CP('C'); */
1636 #ifdef SERIAL_DEBUG_OTHER
1637         printk("cy_close %s\n", tty->name);
1638 #endif
1639
1640         if (!info || serial_paranoia_check(info, tty->name, "cy_close")) {
1641                 return;
1642         }
1643 #ifdef SERIAL_DEBUG_OPEN
1644         printk("cy_close %s, count = %d\n", tty->name, info->count);
1645 #endif
1646
1647         if ((tty->count == 1) && (info->count != 1)) {
1648                 /*
1649                  * Uh, oh.  tty->count is 1, which means that the tty
1650                  * structure will be freed.  Info->count should always
1651                  * be one in these conditions.  If it's greater than
1652                  * one, we've got real problems, since it means the
1653                  * serial port won't be shutdown.
1654                  */
1655                 printk("cy_close: bad serial port count; tty->count is 1, "
1656                        "info->count is %d\n", info->count);
1657                 info->count = 1;
1658         }
1659 #ifdef SERIAL_DEBUG_COUNT
1660         printk("cyc: %d: decrementing count to %d\n", __LINE__,
1661                info->count - 1);
1662 #endif
1663         if (--info->count < 0) {
1664                 printk("cy_close: bad serial port count for ttys%d: %d\n",
1665                        info->line, info->count);
1666 #ifdef SERIAL_DEBUG_COUNT
1667                 printk("cyc: %d: setting count to 0\n", __LINE__);
1668 #endif
1669                 info->count = 0;
1670         }
1671         if (info->count)
1672                 return;
1673         info->flags |= ASYNC_CLOSING;
1674         if (info->flags & ASYNC_INITIALIZED)
1675                 tty_wait_until_sent(tty, 3000); /* 30 seconds timeout */
1676         shutdown(info);
1677         cy_flush_buffer(tty);
1678         tty_ldisc_flush(tty);
1679         info->tty = NULL;
1680         if (info->blocked_open) {
1681                 if (info->close_delay) {
1682                         msleep_interruptible(jiffies_to_msecs
1683                                              (info->close_delay));
1684                 }
1685                 wake_up_interruptible(&info->open_wait);
1686         }
1687         info->flags &= ~(ASYNC_NORMAL_ACTIVE | ASYNC_CLOSING);
1688         wake_up_interruptible(&info->close_wait);
1689
1690 #ifdef SERIAL_DEBUG_OTHER
1691         printk("cy_close done\n");
1692 #endif
1693 }                               /* cy_close */
1694
1695 /*
1696  * cy_hangup() --- called by tty_hangup() when a hangup is signaled.
1697  */
1698 void cy_hangup(struct tty_struct *tty)
1699 {
1700         struct cyclades_port *info = (struct cyclades_port *)tty->driver_data;
1701
1702 #ifdef SERIAL_DEBUG_OTHER
1703         printk("cy_hangup %s\n", tty->name);    /* */
1704 #endif
1705
1706         if (serial_paranoia_check(info, tty->name, "cy_hangup"))
1707                 return;
1708
1709         shutdown(info);
1710 #if 0
1711         info->event = 0;
1712         info->count = 0;
1713 #ifdef SERIAL_DEBUG_COUNT
1714         printk("cyc: %d: setting count to 0\n", __LINE__);
1715 #endif
1716         info->tty = 0;
1717 #endif
1718         info->flags &= ~ASYNC_NORMAL_ACTIVE;
1719         wake_up_interruptible(&info->open_wait);
1720 }                               /* cy_hangup */
1721
1722 /*
1723  * ------------------------------------------------------------
1724  * cy_open() and friends
1725  * ------------------------------------------------------------
1726  */
1727
1728 static int
1729 block_til_ready(struct tty_struct *tty, struct file *filp,
1730                 struct cyclades_port *info)
1731 {
1732         DECLARE_WAITQUEUE(wait, current);
1733         unsigned long flags;
1734         int channel;
1735         int retval;
1736         volatile u_char *base_addr = (u_char *) BASE_ADDR;
1737
1738         /*
1739          * If the device is in the middle of being closed, then block
1740          * until it's done, and then try again.
1741          */
1742         if (info->flags & ASYNC_CLOSING) {
1743                 interruptible_sleep_on(&info->close_wait);
1744                 if (info->flags & ASYNC_HUP_NOTIFY) {
1745                         return -EAGAIN;
1746                 } else {
1747                         return -ERESTARTSYS;
1748                 }
1749         }
1750
1751         /*
1752          * If non-blocking mode is set, then make the check up front
1753          * and then exit.
1754          */
1755         if (filp->f_flags & O_NONBLOCK) {
1756                 info->flags |= ASYNC_NORMAL_ACTIVE;
1757                 return 0;
1758         }
1759
1760         /*
1761          * Block waiting for the carrier detect and the line to become
1762          * free (i.e., not in use by the callout).  While we are in
1763          * this loop, info->count is dropped by one, so that
1764          * cy_close() knows when to free things.  We restore it upon
1765          * exit, either normal or abnormal.
1766          */
1767         retval = 0;
1768         add_wait_queue(&info->open_wait, &wait);
1769 #ifdef SERIAL_DEBUG_OPEN
1770         printk("block_til_ready before block: %s, count = %d\n",
1771                tty->name, info->count);
1772         /**/
1773 #endif
1774             info->count--;
1775 #ifdef SERIAL_DEBUG_COUNT
1776         printk("cyc: %d: decrementing count to %d\n", __LINE__, info->count);
1777 #endif
1778         info->blocked_open++;
1779
1780         channel = info->line;
1781
1782         while (1) {
1783                 local_irq_save(flags);
1784                 base_addr[CyCAR] = (u_char) channel;
1785                 base_addr[CyMSVR1] = CyRTS;
1786 /* CP('S');CP('4'); */
1787                 base_addr[CyMSVR2] = CyDTR;
1788 #ifdef SERIAL_DEBUG_DTR
1789                 printk("cyc: %d: raising DTR\n", __LINE__);
1790                 printk("     status: 0x%x, 0x%x\n", base_addr[CyMSVR1],
1791                        base_addr[CyMSVR2]);
1792 #endif
1793                 local_irq_restore(flags);
1794                 set_current_state(TASK_INTERRUPTIBLE);
1795                 if (tty_hung_up_p(filp)
1796                     || !(info->flags & ASYNC_INITIALIZED)) {
1797                         if (info->flags & ASYNC_HUP_NOTIFY) {
1798                                 retval = -EAGAIN;
1799                         } else {
1800                                 retval = -ERESTARTSYS;
1801                         }
1802                         break;
1803                 }
1804                 local_irq_save(flags);
1805                 base_addr[CyCAR] = (u_char) channel;
1806 /* CP('L');CP1(1 && C_CLOCAL(tty)); CP1(1 && (base_addr[CyMSVR1] & CyDCD) ); */
1807                 if (!(info->flags & ASYNC_CLOSING)
1808                     && (C_CLOCAL(tty)
1809                         || (base_addr[CyMSVR1] & CyDCD))) {
1810                         local_irq_restore(flags);
1811                         break;
1812                 }
1813                 local_irq_restore(flags);
1814                 if (signal_pending(current)) {
1815                         retval = -ERESTARTSYS;
1816                         break;
1817                 }
1818 #ifdef SERIAL_DEBUG_OPEN
1819                 printk("block_til_ready blocking: %s, count = %d\n",
1820                        tty->name, info->count);
1821                 /**/
1822 #endif
1823                     schedule();
1824         }
1825         __set_current_state(TASK_RUNNING);
1826         remove_wait_queue(&info->open_wait, &wait);
1827         if (!tty_hung_up_p(filp)) {
1828                 info->count++;
1829 #ifdef SERIAL_DEBUG_COUNT
1830                 printk("cyc: %d: incrementing count to %d\n", __LINE__,
1831                        info->count);
1832 #endif
1833         }
1834         info->blocked_open--;
1835 #ifdef SERIAL_DEBUG_OPEN
1836         printk("block_til_ready after blocking: %s, count = %d\n",
1837                tty->name, info->count);
1838         /**/
1839 #endif
1840             if (retval)
1841                 return retval;
1842         info->flags |= ASYNC_NORMAL_ACTIVE;
1843         return 0;
1844 }                               /* block_til_ready */
1845
1846 /*
1847  * This routine is called whenever a serial port is opened.  It
1848  * performs the serial-specific initialization for the tty structure.
1849  */
1850 int cy_open(struct tty_struct *tty, struct file *filp)
1851 {
1852         struct cyclades_port *info;
1853         int retval, line;
1854
1855 /* CP('O'); */
1856         line = tty->index;
1857         if ((line < 0) || (NR_PORTS <= line)) {
1858                 return -ENODEV;
1859         }
1860         info = &cy_port[line];
1861         if (info->line < 0) {
1862                 return -ENODEV;
1863         }
1864 #ifdef SERIAL_DEBUG_OTHER
1865         printk("cy_open %s\n", tty->name);      /* */
1866 #endif
1867         if (serial_paranoia_check(info, tty->name, "cy_open")) {
1868                 return -ENODEV;
1869         }
1870 #ifdef SERIAL_DEBUG_OPEN
1871         printk("cy_open %s, count = %d\n", tty->name, info->count);
1872         /**/
1873 #endif
1874             info->count++;
1875 #ifdef SERIAL_DEBUG_COUNT
1876         printk("cyc: %d: incrementing count to %d\n", __LINE__, info->count);
1877 #endif
1878         tty->driver_data = info;
1879         info->tty = tty;
1880
1881         /*
1882          * Start up serial port
1883          */
1884         retval = startup(info);
1885         if (retval) {
1886                 return retval;
1887         }
1888
1889         retval = block_til_ready(tty, filp, info);
1890         if (retval) {
1891 #ifdef SERIAL_DEBUG_OPEN
1892                 printk("cy_open returning after block_til_ready with %d\n",
1893                        retval);
1894 #endif
1895                 return retval;
1896         }
1897 #ifdef SERIAL_DEBUG_OPEN
1898         printk("cy_open done\n");
1899         /**/
1900 #endif
1901             return 0;
1902 }                               /* cy_open */
1903
1904 /*
1905  * ---------------------------------------------------------------------
1906  * serial167_init() and friends
1907  *
1908  * serial167_init() is called at boot-time to initialize the serial driver.
1909  * ---------------------------------------------------------------------
1910  */
1911
1912 /*
1913  * This routine prints out the appropriate serial driver version
1914  * number, and identifies which options were configured into this
1915  * driver.
1916  */
1917 static void show_version(void)
1918 {
1919         printk("MVME166/167 cd2401 driver\n");
1920 }                               /* show_version */
1921
1922 /* initialize chips on card -- return number of valid
1923    chips (which is number of ports/4) */
1924
1925 /*
1926  * This initialises the hardware to a reasonable state.  It should
1927  * probe the chip first so as to copy 166-Bug setup as a default for
1928  * port 0.  It initialises CMR to CyASYNC; that is never done again, so
1929  * as to limit the number of CyINIT_CHAN commands in normal running.
1930  *
1931  * ... I wonder what I should do if this fails ...
1932  */
1933
1934 void mvme167_serial_console_setup(int cflag)
1935 {
1936         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
1937         int ch;
1938         u_char spd;
1939         u_char rcor, rbpr, badspeed = 0;
1940         unsigned long flags;
1941
1942         local_irq_save(flags);
1943
1944         /*
1945          * First probe channel zero of the chip, to see what speed has
1946          * been selected.
1947          */
1948
1949         base_addr[CyCAR] = 0;
1950
1951         rcor = base_addr[CyRCOR] << 5;
1952         rbpr = base_addr[CyRBPR];
1953
1954         for (spd = 0; spd < sizeof(baud_bpr); spd++)
1955                 if (rbpr == baud_bpr[spd] && rcor == baud_co[spd])
1956                         break;
1957         if (spd >= sizeof(baud_bpr)) {
1958                 spd = 14;       /* 19200 */
1959                 badspeed = 1;   /* Failed to identify speed */
1960         }
1961         initial_console_speed = spd;
1962
1963         /* OK, we have chosen a speed, now reset and reinitialise */
1964
1965         my_udelay(20000L);      /* Allow time for any active o/p to complete */
1966         if (base_addr[CyCCR] != 0x00) {
1967                 local_irq_restore(flags);
1968                 /* printk(" chip is never idle (CCR != 0)\n"); */
1969                 return;
1970         }
1971
1972         base_addr[CyCCR] = CyCHIP_RESET;        /* Reset the chip */
1973         my_udelay(1000L);
1974
1975         if (base_addr[CyGFRCR] == 0x00) {
1976                 local_irq_restore(flags);
1977                 /* printk(" chip is not responding (GFRCR stayed 0)\n"); */
1978                 return;
1979         }
1980
1981         /*
1982          * System clock is 20Mhz, divided by 2048, so divide by 10 for a 1.0ms
1983          * tick
1984          */
1985
1986         base_addr[CyTPR] = 10;
1987
1988         base_addr[CyPILR1] = 0x01;      /* Interrupt level for modem change */
1989         base_addr[CyPILR2] = 0x02;      /* Interrupt level for tx ints */
1990         base_addr[CyPILR3] = 0x03;      /* Interrupt level for rx ints */
1991
1992         /*
1993          * Attempt to set up all channels to something reasonable, and
1994          * bang out a INIT_CHAN command.  We should then be able to limit
1995          * the ammount of fiddling we have to do in normal running.
1996          */
1997
1998         for (ch = 3; ch >= 0; ch--) {
1999                 base_addr[CyCAR] = (u_char) ch;
2000                 base_addr[CyIER] = 0;
2001                 base_addr[CyCMR] = CyASYNC;
2002                 base_addr[CyLICR] = (u_char) ch << 2;
2003                 base_addr[CyLIVR] = 0x5c;
2004                 base_addr[CyTCOR] = baud_co[spd];
2005                 base_addr[CyTBPR] = baud_bpr[spd];
2006                 base_addr[CyRCOR] = baud_co[spd] >> 5;
2007                 base_addr[CyRBPR] = baud_bpr[spd];
2008                 base_addr[CySCHR1] = 'Q' & 0x1f;
2009                 base_addr[CySCHR2] = 'X' & 0x1f;
2010                 base_addr[CySCRL] = 0;
2011                 base_addr[CySCRH] = 0;
2012                 base_addr[CyCOR1] = Cy_8_BITS | CyPARITY_NONE;
2013                 base_addr[CyCOR2] = 0;
2014                 base_addr[CyCOR3] = Cy_1_STOP;
2015                 base_addr[CyCOR4] = baud_cor4[spd];
2016                 base_addr[CyCOR5] = 0;
2017                 base_addr[CyCOR6] = 0;
2018                 base_addr[CyCOR7] = 0;
2019                 base_addr[CyRTPRL] = 2;
2020                 base_addr[CyRTPRH] = 0;
2021                 base_addr[CyMSVR1] = 0;
2022                 base_addr[CyMSVR2] = 0;
2023                 write_cy_cmd(base_addr, CyINIT_CHAN | CyDIS_RCVR | CyDIS_XMTR);
2024         }
2025
2026         /*
2027          * Now do specials for channel zero....
2028          */
2029
2030         base_addr[CyMSVR1] = CyRTS;
2031         base_addr[CyMSVR2] = CyDTR;
2032         base_addr[CyIER] = CyRxData;
2033         write_cy_cmd(base_addr, CyENB_RCVR | CyENB_XMTR);
2034
2035         local_irq_restore(flags);
2036
2037         my_udelay(20000L);      /* Let it all settle down */
2038
2039         printk("CD2401 initialised,  chip is rev 0x%02x\n", base_addr[CyGFRCR]);
2040         if (badspeed)
2041                 printk
2042                     ("  WARNING:  Failed to identify line speed, rcor=%02x,rbpr=%02x\n",
2043                      rcor >> 5, rbpr);
2044 }                               /* serial_console_init */
2045
2046 static const struct tty_operations cy_ops = {
2047         .open = cy_open,
2048         .close = cy_close,
2049         .write = cy_write,
2050         .put_char = cy_put_char,
2051         .flush_chars = cy_flush_chars,
2052         .write_room = cy_write_room,
2053         .chars_in_buffer = cy_chars_in_buffer,
2054         .flush_buffer = cy_flush_buffer,
2055         .ioctl = cy_ioctl,
2056         .throttle = cy_throttle,
2057         .unthrottle = cy_unthrottle,
2058         .set_termios = cy_set_termios,
2059         .stop = cy_stop,
2060         .start = cy_start,
2061         .hangup = cy_hangup,
2062         .tiocmget = cy_tiocmget,
2063         .tiocmset = cy_tiocmset,
2064 };
2065
2066 /* The serial driver boot-time initialization code!
2067     Hardware I/O ports are mapped to character special devices on a
2068     first found, first allocated manner.  That is, this code searches
2069     for Cyclom cards in the system.  As each is found, it is probed
2070     to discover how many chips (and thus how many ports) are present.
2071     These ports are mapped to the tty ports 64 and upward in monotonic
2072     fashion.  If an 8-port card is replaced with a 16-port card, the
2073     port mapping on a following card will shift.
2074
2075     This approach is different from what is used in the other serial
2076     device driver because the Cyclom is more properly a multiplexer,
2077     not just an aggregation of serial ports on one card.
2078
2079     If there are more cards with more ports than have been statically
2080     allocated above, a warning is printed and the extra ports are ignored.
2081  */
2082 static int __init serial167_init(void)
2083 {
2084         struct cyclades_port *info;
2085         int ret = 0;
2086         int good_ports = 0;
2087         int port_num = 0;
2088         int index;
2089         int DefSpeed;
2090 #ifdef notyet
2091         struct sigaction sa;
2092 #endif
2093
2094         if (!(mvme16x_config & MVME16x_CONFIG_GOT_CD2401))
2095                 return 0;
2096
2097         cy_serial_driver = alloc_tty_driver(NR_PORTS);
2098         if (!cy_serial_driver)
2099                 return -ENOMEM;
2100
2101 #if 0
2102         scrn[1] = '\0';
2103 #endif
2104
2105         show_version();
2106
2107         /* Has "console=0,9600n8" been used in bootinfo to change speed? */
2108         if (serial_console_cflag)
2109                 DefSpeed = serial_console_cflag & 0017;
2110         else {
2111                 DefSpeed = initial_console_speed;
2112                 serial_console_info = &cy_port[0];
2113                 serial_console_cflag = DefSpeed | CS8;
2114 #if 0
2115                 serial_console = 64;    /*callout_driver.minor_start */
2116 #endif
2117         }
2118
2119         /* Initialize the tty_driver structure */
2120
2121         cy_serial_driver->owner = THIS_MODULE;
2122         cy_serial_driver->name = "ttyS";
2123         cy_serial_driver->major = TTY_MAJOR;
2124         cy_serial_driver->minor_start = 64;
2125         cy_serial_driver->type = TTY_DRIVER_TYPE_SERIAL;
2126         cy_serial_driver->subtype = SERIAL_TYPE_NORMAL;
2127         cy_serial_driver->init_termios = tty_std_termios;
2128         cy_serial_driver->init_termios.c_cflag =
2129             B9600 | CS8 | CREAD | HUPCL | CLOCAL;
2130         cy_serial_driver->flags = TTY_DRIVER_REAL_RAW;
2131         tty_set_operations(cy_serial_driver, &cy_ops);
2132
2133         ret = tty_register_driver(cy_serial_driver);
2134         if (ret) {
2135                 printk(KERN_ERR "Couldn't register MVME166/7 serial driver\n");
2136                 put_tty_driver(cy_serial_driver);
2137                 return ret;
2138         }
2139
2140         port_num = 0;
2141         info = cy_port;
2142         for (index = 0; index < 1; index++) {
2143
2144                 good_ports = 4;
2145
2146                 if (port_num < NR_PORTS) {
2147                         while (good_ports-- && port_num < NR_PORTS) {
2148                 /*** initialize port ***/
2149                                 info->magic = CYCLADES_MAGIC;
2150                                 info->type = PORT_CIRRUS;
2151                                 info->card = index;
2152                                 info->line = port_num;
2153                                 info->flags = STD_COM_FLAGS;
2154                                 info->tty = NULL;
2155                                 info->xmit_fifo_size = 12;
2156                                 info->cor1 = CyPARITY_NONE | Cy_8_BITS;
2157                                 info->cor2 = CyETC;
2158                                 info->cor3 = Cy_1_STOP;
2159                                 info->cor4 = 0x08;      /* _very_ small receive threshold */
2160                                 info->cor5 = 0;
2161                                 info->cor6 = 0;
2162                                 info->cor7 = 0;
2163                                 info->tbpr = baud_bpr[DefSpeed];        /* Tx BPR */
2164                                 info->tco = baud_co[DefSpeed];  /* Tx CO */
2165                                 info->rbpr = baud_bpr[DefSpeed];        /* Rx BPR */
2166                                 info->rco = baud_co[DefSpeed] >> 5;     /* Rx CO */
2167                                 info->close_delay = 0;
2168                                 info->x_char = 0;
2169                                 info->count = 0;
2170 #ifdef SERIAL_DEBUG_COUNT
2171                                 printk("cyc: %d: setting count to 0\n",
2172                                        __LINE__);
2173 #endif
2174                                 info->blocked_open = 0;
2175                                 info->default_threshold = 0;
2176                                 info->default_timeout = 0;
2177                                 init_waitqueue_head(&info->open_wait);
2178                                 init_waitqueue_head(&info->close_wait);
2179                                 /* info->session */
2180                                 /* info->pgrp */
2181 /*** !!!!!!!! this may expose new bugs !!!!!!!!! *********/
2182                                 info->read_status_mask =
2183                                     CyTIMEOUT | CySPECHAR | CyBREAK | CyPARITY |
2184                                     CyFRAME | CyOVERRUN;
2185                                 /* info->timeout */
2186
2187                                 printk("ttyS%d ", info->line);
2188                                 port_num++;
2189                                 info++;
2190                                 if (!(port_num & 7)) {
2191                                         printk("\n               ");
2192                                 }
2193                         }
2194                 }
2195                 printk("\n");
2196         }
2197         while (port_num < NR_PORTS) {
2198                 info->line = -1;
2199                 port_num++;
2200                 info++;
2201         }
2202 #ifdef CONFIG_REMOTE_DEBUG
2203         debug_setup();
2204 #endif
2205         ret = request_irq(MVME167_IRQ_SER_ERR, cd2401_rxerr_interrupt, 0,
2206                           "cd2401_errors", cd2401_rxerr_interrupt);
2207         if (ret) {
2208                 printk(KERN_ERR "Could't get cd2401_errors IRQ");
2209                 goto cleanup_serial_driver;
2210         }
2211
2212         ret = request_irq(MVME167_IRQ_SER_MODEM, cd2401_modem_interrupt, 0,
2213                           "cd2401_modem", cd2401_modem_interrupt);
2214         if (ret) {
2215                 printk(KERN_ERR "Could't get cd2401_modem IRQ");
2216                 goto cleanup_irq_cd2401_errors;
2217         }
2218
2219         ret = request_irq(MVME167_IRQ_SER_TX, cd2401_tx_interrupt, 0,
2220                           "cd2401_txints", cd2401_tx_interrupt);
2221         if (ret) {
2222                 printk(KERN_ERR "Could't get cd2401_txints IRQ");
2223                 goto cleanup_irq_cd2401_modem;
2224         }
2225
2226         ret = request_irq(MVME167_IRQ_SER_RX, cd2401_rx_interrupt, 0,
2227                           "cd2401_rxints", cd2401_rx_interrupt);
2228         if (ret) {
2229                 printk(KERN_ERR "Could't get cd2401_rxints IRQ");
2230                 goto cleanup_irq_cd2401_txints;
2231         }
2232
2233         /* Now we have registered the interrupt handlers, allow the interrupts */
2234
2235         pcc2chip[PccSCCMICR] = 0x15;    /* Serial ints are level 5 */
2236         pcc2chip[PccSCCTICR] = 0x15;
2237         pcc2chip[PccSCCRICR] = 0x15;
2238
2239         pcc2chip[PccIMLR] = 3;  /* Allow PCC2 ints above 3!? */
2240
2241         return 0;
2242 cleanup_irq_cd2401_txints:
2243         free_irq(MVME167_IRQ_SER_TX, cd2401_tx_interrupt);
2244 cleanup_irq_cd2401_modem:
2245         free_irq(MVME167_IRQ_SER_MODEM, cd2401_modem_interrupt);
2246 cleanup_irq_cd2401_errors:
2247         free_irq(MVME167_IRQ_SER_ERR, cd2401_rxerr_interrupt);
2248 cleanup_serial_driver:
2249         if (tty_unregister_driver(cy_serial_driver))
2250                 printk(KERN_ERR
2251                        "Couldn't unregister MVME166/7 serial driver\n");
2252         put_tty_driver(cy_serial_driver);
2253         return ret;
2254 }                               /* serial167_init */
2255
2256 module_init(serial167_init);
2257
2258 #ifdef CYCLOM_SHOW_STATUS
2259 static void show_status(int line_num)
2260 {
2261         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
2262         int channel;
2263         struct cyclades_port *info;
2264         unsigned long flags;
2265
2266         info = &cy_port[line_num];
2267         channel = info->line;
2268         printk("  channel %d\n", channel);
2269         /**/ printk(" cy_port\n");
2270         printk("  card line flags = %d %d %x\n",
2271                info->card, info->line, info->flags);
2272         printk
2273             ("  *tty read_status_mask timeout xmit_fifo_size = %lx %x %x %x\n",
2274              (long)info->tty, info->read_status_mask, info->timeout,
2275              info->xmit_fifo_size);
2276         printk("  cor1,cor2,cor3,cor4,cor5,cor6,cor7 = %x %x %x %x %x %x %x\n",
2277                info->cor1, info->cor2, info->cor3, info->cor4, info->cor5,
2278                info->cor6, info->cor7);
2279         printk("  tbpr,tco,rbpr,rco = %d %d %d %d\n", info->tbpr, info->tco,
2280                info->rbpr, info->rco);
2281         printk("  close_delay event count = %d %d %d\n", info->close_delay,
2282                info->event, info->count);
2283         printk("  x_char blocked_open = %x %x\n", info->x_char,
2284                info->blocked_open);
2285         printk("  open_wait = %lx %lx %lx\n", (long)info->open_wait);
2286
2287         local_irq_save(flags);
2288
2289 /* Global Registers */
2290
2291         printk(" CyGFRCR %x\n", base_addr[CyGFRCR]);
2292         printk(" CyCAR %x\n", base_addr[CyCAR]);
2293         printk(" CyRISR %x\n", base_addr[CyRISR]);
2294         printk(" CyTISR %x\n", base_addr[CyTISR]);
2295         printk(" CyMISR %x\n", base_addr[CyMISR]);
2296         printk(" CyRIR %x\n", base_addr[CyRIR]);
2297         printk(" CyTIR %x\n", base_addr[CyTIR]);
2298         printk(" CyMIR %x\n", base_addr[CyMIR]);
2299         printk(" CyTPR %x\n", base_addr[CyTPR]);
2300
2301         base_addr[CyCAR] = (u_char) channel;
2302
2303 /* Virtual Registers */
2304
2305 #if 0
2306         printk(" CyRIVR %x\n", base_addr[CyRIVR]);
2307         printk(" CyTIVR %x\n", base_addr[CyTIVR]);
2308         printk(" CyMIVR %x\n", base_addr[CyMIVR]);
2309         printk(" CyMISR %x\n", base_addr[CyMISR]);
2310 #endif
2311
2312 /* Channel Registers */
2313
2314         printk(" CyCCR %x\n", base_addr[CyCCR]);
2315         printk(" CyIER %x\n", base_addr[CyIER]);
2316         printk(" CyCOR1 %x\n", base_addr[CyCOR1]);
2317         printk(" CyCOR2 %x\n", base_addr[CyCOR2]);
2318         printk(" CyCOR3 %x\n", base_addr[CyCOR3]);
2319         printk(" CyCOR4 %x\n", base_addr[CyCOR4]);
2320         printk(" CyCOR5 %x\n", base_addr[CyCOR5]);
2321 #if 0
2322         printk(" CyCCSR %x\n", base_addr[CyCCSR]);
2323         printk(" CyRDCR %x\n", base_addr[CyRDCR]);
2324 #endif
2325         printk(" CySCHR1 %x\n", base_addr[CySCHR1]);
2326         printk(" CySCHR2 %x\n", base_addr[CySCHR2]);
2327 #if 0
2328         printk(" CySCHR3 %x\n", base_addr[CySCHR3]);
2329         printk(" CySCHR4 %x\n", base_addr[CySCHR4]);
2330         printk(" CySCRL %x\n", base_addr[CySCRL]);
2331         printk(" CySCRH %x\n", base_addr[CySCRH]);
2332         printk(" CyLNC %x\n", base_addr[CyLNC]);
2333         printk(" CyMCOR1 %x\n", base_addr[CyMCOR1]);
2334         printk(" CyMCOR2 %x\n", base_addr[CyMCOR2]);
2335 #endif
2336         printk(" CyRTPRL %x\n", base_addr[CyRTPRL]);
2337         printk(" CyRTPRH %x\n", base_addr[CyRTPRH]);
2338         printk(" CyMSVR1 %x\n", base_addr[CyMSVR1]);
2339         printk(" CyMSVR2 %x\n", base_addr[CyMSVR2]);
2340         printk(" CyRBPR %x\n", base_addr[CyRBPR]);
2341         printk(" CyRCOR %x\n", base_addr[CyRCOR]);
2342         printk(" CyTBPR %x\n", base_addr[CyTBPR]);
2343         printk(" CyTCOR %x\n", base_addr[CyTCOR]);
2344
2345         local_irq_restore(flags);
2346 }                               /* show_status */
2347 #endif
2348
2349 #if 0
2350 /* Dummy routine in mvme16x/config.c for now */
2351
2352 /* Serial console setup. Called from linux/init/main.c */
2353
2354 void console_setup(char *str, int *ints)
2355 {
2356         char *s;
2357         int baud, bits, parity;
2358         int cflag = 0;
2359
2360         /* Sanity check. */
2361         if (ints[0] > 3 || ints[1] > 3)
2362                 return;
2363
2364         /* Get baud, bits and parity */
2365         baud = 2400;
2366         bits = 8;
2367         parity = 'n';
2368         if (ints[2])
2369                 baud = ints[2];
2370         if ((s = strchr(str, ','))) {
2371                 do {
2372                         s++;
2373                 } while (*s >= '0' && *s <= '9');
2374                 if (*s)
2375                         parity = *s++;
2376                 if (*s)
2377                         bits = *s - '0';
2378         }
2379
2380         /* Now construct a cflag setting. */
2381         switch (baud) {
2382         case 1200:
2383                 cflag |= B1200;
2384                 break;
2385         case 9600:
2386                 cflag |= B9600;
2387                 break;
2388         case 19200:
2389                 cflag |= B19200;
2390                 break;
2391         case 38400:
2392                 cflag |= B38400;
2393                 break;
2394         case 2400:
2395         default:
2396                 cflag |= B2400;
2397                 break;
2398         }
2399         switch (bits) {
2400         case 7:
2401                 cflag |= CS7;
2402                 break;
2403         default:
2404         case 8:
2405                 cflag |= CS8;
2406                 break;
2407         }
2408         switch (parity) {
2409         case 'o':
2410         case 'O':
2411                 cflag |= PARODD;
2412                 break;
2413         case 'e':
2414         case 'E':
2415                 cflag |= PARENB;
2416                 break;
2417         }
2418
2419         serial_console_info = &cy_port[ints[1]];
2420         serial_console_cflag = cflag;
2421         serial_console = ints[1] + 64;  /*callout_driver.minor_start */
2422 }
2423 #endif
2424
2425 /*
2426  * The following is probably out of date for 2.1.x serial console stuff.
2427  *
2428  * The console is registered early on from arch/m68k/kernel/setup.c, and
2429  * it therefore relies on the chip being setup correctly by 166-Bug.  This
2430  * seems reasonable, as the serial port has been used to invoke the system
2431  * boot.  It also means that this function must not rely on any data
2432  * initialisation performed by serial167_init() etc.
2433  *
2434  * Of course, once the console has been registered, we had better ensure
2435  * that serial167_init() doesn't leave the chip non-functional.
2436  *
2437  * The console must be locked when we get here.
2438  */
2439
2440 void serial167_console_write(struct console *co, const char *str,
2441                              unsigned count)
2442 {
2443         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
2444         unsigned long flags;
2445         volatile u_char sink;
2446         u_char ier;
2447         int port;
2448         u_char do_lf = 0;
2449         int i = 0;
2450
2451         local_irq_save(flags);
2452
2453         /* Ensure transmitter is enabled! */
2454
2455         port = 0;
2456         base_addr[CyCAR] = (u_char) port;
2457         while (base_addr[CyCCR])
2458                 ;
2459         base_addr[CyCCR] = CyENB_XMTR;
2460
2461         ier = base_addr[CyIER];
2462         base_addr[CyIER] = CyTxMpty;
2463
2464         while (1) {
2465                 if (pcc2chip[PccSCCTICR] & 0x20) {
2466                         /* We have a Tx int. Acknowledge it */
2467                         sink = pcc2chip[PccTPIACKR];
2468                         if ((base_addr[CyLICR] >> 2) == port) {
2469                                 if (i == count) {
2470                                         /* Last char of string is now output */
2471                                         base_addr[CyTEOIR] = CyNOTRANS;
2472                                         break;
2473                                 }
2474                                 if (do_lf) {
2475                                         base_addr[CyTDR] = '\n';
2476                                         str++;
2477                                         i++;
2478                                         do_lf = 0;
2479                                 } else if (*str == '\n') {
2480                                         base_addr[CyTDR] = '\r';
2481                                         do_lf = 1;
2482                                 } else {
2483                                         base_addr[CyTDR] = *str++;
2484                                         i++;
2485                                 }
2486                                 base_addr[CyTEOIR] = 0;
2487                         } else
2488                                 base_addr[CyTEOIR] = CyNOTRANS;
2489                 }
2490         }
2491
2492         base_addr[CyIER] = ier;
2493
2494         local_irq_restore(flags);
2495 }
2496
2497 static struct tty_driver *serial167_console_device(struct console *c,
2498                                                    int *index)
2499 {
2500         *index = c->index;
2501         return cy_serial_driver;
2502 }
2503
2504 static struct console sercons = {
2505         .name = "ttyS",
2506         .write = serial167_console_write,
2507         .device = serial167_console_device,
2508         .flags = CON_PRINTBUFFER,
2509         .index = -1,
2510 };
2511
2512 static int __init serial167_console_init(void)
2513 {
2514         if (vme_brdtype == VME_TYPE_MVME166 ||
2515             vme_brdtype == VME_TYPE_MVME167 ||
2516             vme_brdtype == VME_TYPE_MVME177) {
2517                 mvme167_serial_console_setup(0);
2518                 register_console(&sercons);
2519         }
2520         return 0;
2521 }
2522
2523 console_initcall(serial167_console_init);
2524
2525 #ifdef CONFIG_REMOTE_DEBUG
2526 void putDebugChar(int c)
2527 {
2528         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
2529         unsigned long flags;
2530         volatile u_char sink;
2531         u_char ier;
2532         int port;
2533
2534         local_irq_save(flags);
2535
2536         /* Ensure transmitter is enabled! */
2537
2538         port = DEBUG_PORT;
2539         base_addr[CyCAR] = (u_char) port;
2540         while (base_addr[CyCCR])
2541                 ;
2542         base_addr[CyCCR] = CyENB_XMTR;
2543
2544         ier = base_addr[CyIER];
2545         base_addr[CyIER] = CyTxMpty;
2546
2547         while (1) {
2548                 if (pcc2chip[PccSCCTICR] & 0x20) {
2549                         /* We have a Tx int. Acknowledge it */
2550                         sink = pcc2chip[PccTPIACKR];
2551                         if ((base_addr[CyLICR] >> 2) == port) {
2552                                 base_addr[CyTDR] = c;
2553                                 base_addr[CyTEOIR] = 0;
2554                                 break;
2555                         } else
2556                                 base_addr[CyTEOIR] = CyNOTRANS;
2557                 }
2558         }
2559
2560         base_addr[CyIER] = ier;
2561
2562         local_irq_restore(flags);
2563 }
2564
2565 int getDebugChar()
2566 {
2567         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
2568         unsigned long flags;
2569         volatile u_char sink;
2570         u_char ier;
2571         int port;
2572         int i, c;
2573
2574         i = debugiq.out;
2575         if (i != debugiq.in) {
2576                 c = debugiq.buf[i];
2577                 if (++i == DEBUG_LEN)
2578                         i = 0;
2579                 debugiq.out = i;
2580                 return c;
2581         }
2582         /* OK, nothing in queue, wait in poll loop */
2583
2584         local_irq_save(flags);
2585
2586         /* Ensure receiver is enabled! */
2587
2588         port = DEBUG_PORT;
2589         base_addr[CyCAR] = (u_char) port;
2590 #if 0
2591         while (base_addr[CyCCR])
2592                 ;
2593         base_addr[CyCCR] = CyENB_RCVR;
2594 #endif
2595         ier = base_addr[CyIER];
2596         base_addr[CyIER] = CyRxData;
2597
2598         while (1) {
2599                 if (pcc2chip[PccSCCRICR] & 0x20) {
2600                         /* We have a Rx int. Acknowledge it */
2601                         sink = pcc2chip[PccRPIACKR];
2602                         if ((base_addr[CyLICR] >> 2) == port) {
2603                                 int cnt = base_addr[CyRFOC];
2604                                 while (cnt-- > 0) {
2605                                         c = base_addr[CyRDR];
2606                                         if (c == 0)
2607                                                 printk
2608                                                     ("!! debug char is null (cnt=%d) !!",
2609                                                      cnt);
2610                                         else
2611                                                 queueDebugChar(c);
2612                                 }
2613                                 base_addr[CyREOIR] = 0;
2614                                 i = debugiq.out;
2615                                 if (i == debugiq.in)
2616                                         panic("Debug input queue empty!");
2617                                 c = debugiq.buf[i];
2618                                 if (++i == DEBUG_LEN)
2619                                         i = 0;
2620                                 debugiq.out = i;
2621                                 break;
2622                         } else
2623                                 base_addr[CyREOIR] = CyNOTRANS;
2624                 }
2625         }
2626
2627         base_addr[CyIER] = ier;
2628
2629         local_irq_restore(flags);
2630
2631         return (c);
2632 }
2633
2634 void queueDebugChar(int c)
2635 {
2636         int i;
2637
2638         i = debugiq.in;
2639         debugiq.buf[i] = c;
2640         if (++i == DEBUG_LEN)
2641                 i = 0;
2642         if (i != debugiq.out)
2643                 debugiq.in = i;
2644 }
2645
2646 static void debug_setup()
2647 {
2648         unsigned long flags;
2649         volatile unsigned char *base_addr = (u_char *) BASE_ADDR;
2650         int i, cflag;
2651
2652         cflag = B19200;
2653
2654         local_irq_save(flags);
2655
2656         for (i = 0; i < 4; i++) {
2657                 base_addr[CyCAR] = i;
2658                 base_addr[CyLICR] = i << 2;
2659         }
2660
2661         debugiq.in = debugiq.out = 0;
2662
2663         base_addr[CyCAR] = DEBUG_PORT;
2664
2665         /* baud rate */
2666         i = cflag & CBAUD;
2667
2668         base_addr[CyIER] = 0;
2669
2670         base_addr[CyCMR] = CyASYNC;
2671         base_addr[CyLICR] = DEBUG_PORT << 2;
2672         base_addr[CyLIVR] = 0x5c;
2673
2674         /* tx and rx baud rate */
2675
2676         base_addr[CyTCOR] = baud_co[i];
2677         base_addr[CyTBPR] = baud_bpr[i];
2678         base_addr[CyRCOR] = baud_co[i] >> 5;
2679         base_addr[CyRBPR] = baud_bpr[i];
2680
2681         /* set line characteristics  according configuration */
2682
2683         base_addr[CySCHR1] = 0;
2684         base_addr[CySCHR2] = 0;
2685         base_addr[CySCRL] = 0;
2686         base_addr[CySCRH] = 0;
2687         base_addr[CyCOR1] = Cy_8_BITS | CyPARITY_NONE;
2688         base_addr[CyCOR2] = 0;
2689         base_addr[CyCOR3] = Cy_1_STOP;
2690         base_addr[CyCOR4] = baud_cor4[i];
2691         base_addr[CyCOR5] = 0;
2692         base_addr[CyCOR6] = 0;
2693         base_addr[CyCOR7] = 0;
2694
2695         write_cy_cmd(base_addr, CyINIT_CHAN);
2696         write_cy_cmd(base_addr, CyENB_RCVR);
2697
2698         base_addr[CyCAR] = DEBUG_PORT;  /* !!! Is this needed? */
2699
2700         base_addr[CyRTPRL] = 2;
2701         base_addr[CyRTPRH] = 0;
2702
2703         base_addr[CyMSVR1] = CyRTS;
2704         base_addr[CyMSVR2] = CyDTR;
2705
2706         base_addr[CyIER] = CyRxData;
2707
2708         local_irq_restore(flags);
2709
2710 }                               /* debug_setup */
2711
2712 #endif
2713
2714 MODULE_LICENSE("GPL");