2 * linux/drivers/char/riscom.c -- RISCom/8 multiport serial driver.
4 * Copyright (C) 1994-1996 Dmitry Gorodchanin (pgmdsg@ibi.com)
6 * This code is loosely based on the Linux serial driver, written by
7 * Linus Torvalds, Theodore T'so and others. The RISCom/8 card
8 * programming info was obtained from various drivers for other OSes
9 * (FreeBSD, ISC, etc), but no source code from those drivers were
10 * directly included in this driver.
13 * This program is free software; you can redistribute it and/or modify
14 * it under the terms of the GNU General Public License as published by
15 * the Free Software Foundation; either version 2 of the License, or
16 * (at your option) any later version.
18 * This program is distributed in the hope that it will be useful,
19 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
21 * GNU General Public License for more details.
23 * You should have received a copy of the GNU General Public License
24 * along with this program; if not, write to the Free Software
25 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
30 * Arnaldo Carvalho de Melo <acme@conectiva.com.br> - 27-Jun-2001
31 * - get rid of check_region and several cleanups
34 #include <linux/module.h>
37 #include <linux/kernel.h>
38 #include <linux/sched.h>
39 #include <linux/ioport.h>
40 #include <linux/interrupt.h>
41 #include <linux/errno.h>
42 #include <linux/tty.h>
44 #include <linux/serial.h>
45 #include <linux/fcntl.h>
46 #include <linux/major.h>
47 #include <linux/init.h>
48 #include <linux/delay.h>
49 #include <linux/tty_flip.h>
51 #include <asm/uaccess.h>
54 #include "riscom8_reg.h"
56 /* Am I paranoid or not ? ;-) */
57 #define RISCOM_PARANOIA_CHECK
60 * Crazy InteliCom/8 boards sometimes has swapped CTS & DSR signals.
61 * You can slightly speed up things by #undefing the following option,
62 * if you are REALLY sure that your board is correct one.
65 #define RISCOM_BRAIN_DAMAGED_CTS
68 * The following defines are mostly for testing purposes. But if you need
69 * some nice reporting in your syslog, you can define them also.
72 #undef RC_REPORT_OVERRUN
75 #define RISCOM_LEGAL_FLAGS \
76 (ASYNC_HUP_NOTIFY | ASYNC_SAK | ASYNC_SPLIT_TERMIOS | \
77 ASYNC_SPD_HI | ASYNC_SPEED_VHI | ASYNC_SESSION_LOCKOUT | \
78 ASYNC_PGRP_LOCKOUT | ASYNC_CALLOUT_NOHUP)
80 #define RS_EVENT_WRITE_WAKEUP 0
82 static struct riscom_board
* IRQ_to_board
[16];
83 static struct tty_driver
*riscom_driver
;
84 static unsigned char * tmp_buf
;
86 static unsigned long baud_table
[] = {
87 0, 50, 75, 110, 134, 150, 200, 300, 600, 1200, 1800, 2400, 4800,
88 9600, 19200, 38400, 57600, 76800, 0,
91 static struct riscom_board rc_board
[RC_NBOARD
] = {
106 static struct riscom_port rc_port
[RC_NBOARD
* RC_NPORT
];
108 /* RISCom/8 I/O ports addresses (without address translation) */
109 static unsigned short rc_ioport
[] = {
111 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x09, 0x0a, 0x0b, 0x0c,
113 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x09, 0x0a, 0x0b, 0x0c, 0x10,
114 0x11, 0x12, 0x18, 0x28, 0x31, 0x32, 0x39, 0x3a, 0x40, 0x41, 0x61, 0x62,
115 0x63, 0x64, 0x6b, 0x70, 0x71, 0x78, 0x7a, 0x7b, 0x7f, 0x100, 0x101
118 #define RC_NIOPORT ARRAY_SIZE(rc_ioport)
121 static inline int rc_paranoia_check(struct riscom_port
const * port
,
122 char *name
, const char *routine
)
124 #ifdef RISCOM_PARANOIA_CHECK
125 static const char badmagic
[] = KERN_INFO
126 "rc: Warning: bad riscom port magic number for device %s in %s\n";
127 static const char badinfo
[] = KERN_INFO
128 "rc: Warning: null riscom port for device %s in %s\n";
131 printk(badinfo
, name
, routine
);
134 if (port
->magic
!= RISCOM8_MAGIC
) {
135 printk(badmagic
, name
, routine
);
144 * Service functions for RISCom/8 driver.
148 /* Get board number from pointer */
149 static inline int board_No (struct riscom_board
const * bp
)
151 return bp
- rc_board
;
154 /* Get port number from pointer */
155 static inline int port_No (struct riscom_port
const * port
)
157 return RC_PORT(port
- rc_port
);
160 /* Get pointer to board from pointer to port */
161 static inline struct riscom_board
* port_Board(struct riscom_port
const * port
)
163 return &rc_board
[RC_BOARD(port
- rc_port
)];
166 /* Input Byte from CL CD180 register */
167 static inline unsigned char rc_in(struct riscom_board
const * bp
, unsigned short reg
)
169 return inb(bp
->base
+ RC_TO_ISA(reg
));
172 /* Output Byte to CL CD180 register */
173 static inline void rc_out(struct riscom_board
const * bp
, unsigned short reg
,
176 outb(val
, bp
->base
+ RC_TO_ISA(reg
));
179 /* Wait for Channel Command Register ready */
180 static inline void rc_wait_CCR(struct riscom_board
const * bp
)
184 /* FIXME: need something more descriptive then 100000 :) */
185 for (delay
= 100000; delay
; delay
--)
186 if (!rc_in(bp
, CD180_CCR
))
189 printk(KERN_INFO
"rc%d: Timeout waiting for CCR.\n", board_No(bp
));
193 * RISCom/8 probe functions.
196 static inline int rc_request_io_range(struct riscom_board
* const bp
)
200 for (i
= 0; i
< RC_NIOPORT
; i
++)
201 if (!request_region(RC_TO_ISA(rc_ioport
[i
]) + bp
->base
, 1,
207 printk(KERN_INFO
"rc%d: Skipping probe at 0x%03x. IO address in use.\n",
208 board_No(bp
), bp
->base
);
210 release_region(RC_TO_ISA(rc_ioport
[i
]) + bp
->base
, 1);
214 static inline void rc_release_io_range(struct riscom_board
* const bp
)
218 for (i
= 0; i
< RC_NIOPORT
; i
++)
219 release_region(RC_TO_ISA(rc_ioport
[i
]) + bp
->base
, 1);
222 /* Must be called with enabled interrupts */
223 static inline void rc_long_delay(unsigned long delay
)
227 for (i
= jiffies
+ delay
; time_after(i
,jiffies
); ) ;
230 /* Reset and setup CD180 chip */
231 static void __init
rc_init_CD180(struct riscom_board
const * bp
)
235 save_flags(flags
); cli();
236 rc_out(bp
, RC_CTOUT
, 0); /* Clear timeout */
237 rc_wait_CCR(bp
); /* Wait for CCR ready */
238 rc_out(bp
, CD180_CCR
, CCR_HARDRESET
); /* Reset CD180 chip */
240 rc_long_delay(HZ
/20); /* Delay 0.05 sec */
242 rc_out(bp
, CD180_GIVR
, RC_ID
); /* Set ID for this chip */
243 rc_out(bp
, CD180_GICR
, 0); /* Clear all bits */
244 rc_out(bp
, CD180_PILR1
, RC_ACK_MINT
); /* Prio for modem intr */
245 rc_out(bp
, CD180_PILR2
, RC_ACK_TINT
); /* Prio for transmitter intr */
246 rc_out(bp
, CD180_PILR3
, RC_ACK_RINT
); /* Prio for receiver intr */
248 /* Setting up prescaler. We need 4 ticks per 1 ms */
249 rc_out(bp
, CD180_PPRH
, (RC_OSCFREQ
/(1000000/RISCOM_TPS
)) >> 8);
250 rc_out(bp
, CD180_PPRL
, (RC_OSCFREQ
/(1000000/RISCOM_TPS
)) & 0xff);
252 restore_flags(flags
);
255 /* Main probing routine, also sets irq. */
256 static int __init
rc_probe(struct riscom_board
*bp
)
258 unsigned char val1
, val2
;
264 if (rc_request_io_range(bp
))
267 /* Are the I/O ports here ? */
268 rc_out(bp
, CD180_PPRL
, 0x5a);
270 val1
= rc_in(bp
, CD180_PPRL
);
271 rc_out(bp
, CD180_PPRL
, 0xa5);
273 val2
= rc_in(bp
, CD180_PPRL
);
275 if ((val1
!= 0x5a) || (val2
!= 0xa5)) {
276 printk(KERN_ERR
"rc%d: RISCom/8 Board at 0x%03x not found.\n",
277 board_No(bp
), bp
->base
);
281 /* It's time to find IRQ for this board */
282 for (retries
= 0; retries
< 5 && irqs
<= 0; retries
++) {
283 irqs
= probe_irq_on();
284 rc_init_CD180(bp
); /* Reset CD180 chip */
285 rc_out(bp
, CD180_CAR
, 2); /* Select port 2 */
287 rc_out(bp
, CD180_CCR
, CCR_TXEN
); /* Enable transmitter */
288 rc_out(bp
, CD180_IER
, IER_TXRDY
); /* Enable tx empty intr */
289 rc_long_delay(HZ
/20);
290 irqs
= probe_irq_off(irqs
);
291 val1
= rc_in(bp
, RC_BSR
); /* Get Board Status reg */
292 val2
= rc_in(bp
, RC_ACK_TINT
); /* ACK interrupt */
293 rc_init_CD180(bp
); /* Reset CD180 again */
295 if ((val1
& RC_BSR_TINT
) || (val2
!= (RC_ID
| GIVR_IT_TX
))) {
296 printk(KERN_ERR
"rc%d: RISCom/8 Board at 0x%03x not "
297 "found.\n", board_No(bp
), bp
->base
);
303 printk(KERN_ERR
"rc%d: Can't find IRQ for RISCom/8 board "
304 "at 0x%03x.\n", board_No(bp
), bp
->base
);
308 bp
->flags
|= RC_BOARD_PRESENT
;
310 printk(KERN_INFO
"rc%d: RISCom/8 Rev. %c board detected at "
313 (rc_in(bp
, CD180_GFRCR
) & 0x0f) + 'A', /* Board revision */
318 rc_release_io_range(bp
);
324 * Interrupt processing routines.
328 static inline void rc_mark_event(struct riscom_port
* port
, int event
)
330 set_bit(event
, &port
->event
);
331 schedule_work(&port
->tqueue
);
334 static inline struct riscom_port
* rc_get_port(struct riscom_board
const * bp
,
335 unsigned char const * what
)
337 unsigned char channel
;
338 struct riscom_port
* port
;
340 channel
= rc_in(bp
, CD180_GICR
) >> GICR_CHAN_OFF
;
341 if (channel
< CD180_NCH
) {
342 port
= &rc_port
[board_No(bp
) * RC_NPORT
+ channel
];
343 if (port
->flags
& ASYNC_INITIALIZED
) {
347 printk(KERN_ERR
"rc%d: %s interrupt from invalid port %d\n",
348 board_No(bp
), what
, channel
);
352 static inline void rc_receive_exc(struct riscom_board
const * bp
)
354 struct riscom_port
*port
;
355 struct tty_struct
*tty
;
356 unsigned char status
;
357 unsigned char ch
, flag
;
359 if (!(port
= rc_get_port(bp
, "Receive")))
364 #ifdef RC_REPORT_OVERRUN
365 status
= rc_in(bp
, CD180_RCSR
);
366 if (status
& RCSR_OE
)
368 status
&= port
->mark_mask
;
370 status
= rc_in(bp
, CD180_RCSR
) & port
->mark_mask
;
372 ch
= rc_in(bp
, CD180_RDR
);
376 if (status
& RCSR_TOUT
) {
377 printk(KERN_WARNING
"rc%d: port %d: Receiver timeout. "
378 "Hardware problems ?\n",
379 board_No(bp
), port_No(port
));
382 } else if (status
& RCSR_BREAK
) {
383 printk(KERN_INFO
"rc%d: port %d: Handling break...\n",
384 board_No(bp
), port_No(port
));
386 if (port
->flags
& ASYNC_SAK
)
389 } else if (status
& RCSR_PE
)
392 else if (status
& RCSR_FE
)
395 else if (status
& RCSR_OE
)
401 tty_insert_flip_char(tty
, ch
, flag
);
402 tty_flip_buffer_push(tty
);
405 static inline void rc_receive(struct riscom_board
const * bp
)
407 struct riscom_port
*port
;
408 struct tty_struct
*tty
;
411 if (!(port
= rc_get_port(bp
, "Receive")))
416 count
= rc_in(bp
, CD180_RDCR
);
418 #ifdef RC_REPORT_FIFO
419 port
->hits
[count
> 8 ? 9 : count
]++;
423 if (tty_buffer_request_room(tty
, 1) == 0) {
424 printk(KERN_WARNING
"rc%d: port %d: Working around "
425 "flip buffer overflow.\n",
426 board_No(bp
), port_No(port
));
429 tty_insert_flip_char(tty
, rc_in(bp
, CD180_RDR
), TTY_NORMAL
);
431 tty_flip_buffer_push(tty
);
434 static inline void rc_transmit(struct riscom_board
const * bp
)
436 struct riscom_port
*port
;
437 struct tty_struct
*tty
;
441 if (!(port
= rc_get_port(bp
, "Transmit")))
446 if (port
->IER
& IER_TXEMPTY
) {
448 rc_out(bp
, CD180_CAR
, port_No(port
));
449 port
->IER
&= ~IER_TXEMPTY
;
450 rc_out(bp
, CD180_IER
, port
->IER
);
454 if ((port
->xmit_cnt
<= 0 && !port
->break_length
)
455 || tty
->stopped
|| tty
->hw_stopped
) {
456 rc_out(bp
, CD180_CAR
, port_No(port
));
457 port
->IER
&= ~IER_TXRDY
;
458 rc_out(bp
, CD180_IER
, port
->IER
);
462 if (port
->break_length
) {
463 if (port
->break_length
> 0) {
464 if (port
->COR2
& COR2_ETC
) {
465 rc_out(bp
, CD180_TDR
, CD180_C_ESC
);
466 rc_out(bp
, CD180_TDR
, CD180_C_SBRK
);
467 port
->COR2
&= ~COR2_ETC
;
469 count
= min_t(int, port
->break_length
, 0xff);
470 rc_out(bp
, CD180_TDR
, CD180_C_ESC
);
471 rc_out(bp
, CD180_TDR
, CD180_C_DELAY
);
472 rc_out(bp
, CD180_TDR
, count
);
473 if (!(port
->break_length
-= count
))
474 port
->break_length
--;
476 rc_out(bp
, CD180_TDR
, CD180_C_ESC
);
477 rc_out(bp
, CD180_TDR
, CD180_C_EBRK
);
478 rc_out(bp
, CD180_COR2
, port
->COR2
);
480 rc_out(bp
, CD180_CCR
, CCR_CORCHG2
);
481 port
->break_length
= 0;
488 rc_out(bp
, CD180_TDR
, port
->xmit_buf
[port
->xmit_tail
++]);
489 port
->xmit_tail
= port
->xmit_tail
& (SERIAL_XMIT_SIZE
-1);
490 if (--port
->xmit_cnt
<= 0)
492 } while (--count
> 0);
494 if (port
->xmit_cnt
<= 0) {
495 rc_out(bp
, CD180_CAR
, port_No(port
));
496 port
->IER
&= ~IER_TXRDY
;
497 rc_out(bp
, CD180_IER
, port
->IER
);
499 if (port
->xmit_cnt
<= port
->wakeup_chars
)
500 rc_mark_event(port
, RS_EVENT_WRITE_WAKEUP
);
503 static inline void rc_check_modem(struct riscom_board
const * bp
)
505 struct riscom_port
*port
;
506 struct tty_struct
*tty
;
509 if (!(port
= rc_get_port(bp
, "Modem")))
514 mcr
= rc_in(bp
, CD180_MCR
);
515 if (mcr
& MCR_CDCHG
) {
516 if (rc_in(bp
, CD180_MSVR
) & MSVR_CD
)
517 wake_up_interruptible(&port
->open_wait
);
519 schedule_work(&port
->tqueue_hangup
);
522 #ifdef RISCOM_BRAIN_DAMAGED_CTS
523 if (mcr
& MCR_CTSCHG
) {
524 if (rc_in(bp
, CD180_MSVR
) & MSVR_CTS
) {
526 port
->IER
|= IER_TXRDY
;
527 if (port
->xmit_cnt
<= port
->wakeup_chars
)
528 rc_mark_event(port
, RS_EVENT_WRITE_WAKEUP
);
531 port
->IER
&= ~IER_TXRDY
;
533 rc_out(bp
, CD180_IER
, port
->IER
);
535 if (mcr
& MCR_DSRCHG
) {
536 if (rc_in(bp
, CD180_MSVR
) & MSVR_DSR
) {
538 port
->IER
|= IER_TXRDY
;
539 if (port
->xmit_cnt
<= port
->wakeup_chars
)
540 rc_mark_event(port
, RS_EVENT_WRITE_WAKEUP
);
543 port
->IER
&= ~IER_TXRDY
;
545 rc_out(bp
, CD180_IER
, port
->IER
);
547 #endif /* RISCOM_BRAIN_DAMAGED_CTS */
549 /* Clear change bits */
550 rc_out(bp
, CD180_MCR
, 0);
553 /* The main interrupt processing routine */
554 static irqreturn_t
rc_interrupt(int irq
, void * dev_id
, struct pt_regs
* regs
)
556 unsigned char status
;
558 struct riscom_board
*bp
;
559 unsigned long loop
= 0;
562 bp
= IRQ_to_board
[irq
];
564 if (!bp
|| !(bp
->flags
& RC_BOARD_ACTIVE
)) {
568 while ((++loop
< 16) && ((status
= ~(rc_in(bp
, RC_BSR
))) &
569 (RC_BSR_TOUT
| RC_BSR_TINT
|
570 RC_BSR_MINT
| RC_BSR_RINT
))) {
572 if (status
& RC_BSR_TOUT
)
573 printk(KERN_WARNING
"rc%d: Got timeout. Hardware "
574 "error?\n", board_No(bp
));
576 else if (status
& RC_BSR_RINT
) {
577 ack
= rc_in(bp
, RC_ACK_RINT
);
579 if (ack
== (RC_ID
| GIVR_IT_RCV
))
581 else if (ack
== (RC_ID
| GIVR_IT_REXC
))
584 printk(KERN_WARNING
"rc%d: Bad receive ack "
588 } else if (status
& RC_BSR_TINT
) {
589 ack
= rc_in(bp
, RC_ACK_TINT
);
591 if (ack
== (RC_ID
| GIVR_IT_TX
))
594 printk(KERN_WARNING
"rc%d: Bad transmit ack "
598 } else /* if (status & RC_BSR_MINT) */ {
599 ack
= rc_in(bp
, RC_ACK_MINT
);
601 if (ack
== (RC_ID
| GIVR_IT_MODEM
))
604 printk(KERN_WARNING
"rc%d: Bad modem ack "
610 rc_out(bp
, CD180_EOIR
, 0); /* Mark end of interrupt */
611 rc_out(bp
, RC_CTOUT
, 0); /* Clear timeout flag */
613 return IRQ_RETVAL(handled
);
617 * Routines for open & close processing.
620 /* Called with disabled interrupts */
621 static inline int rc_setup_board(struct riscom_board
* bp
)
625 if (bp
->flags
& RC_BOARD_ACTIVE
)
628 error
= request_irq(bp
->irq
, rc_interrupt
, IRQF_DISABLED
,
633 rc_out(bp
, RC_CTOUT
, 0); /* Just in case */
635 rc_out(bp
, RC_DTR
, bp
->DTR
); /* Drop DTR on all ports */
637 IRQ_to_board
[bp
->irq
] = bp
;
638 bp
->flags
|= RC_BOARD_ACTIVE
;
643 /* Called with disabled interrupts */
644 static inline void rc_shutdown_board(struct riscom_board
*bp
)
646 if (!(bp
->flags
& RC_BOARD_ACTIVE
))
649 bp
->flags
&= ~RC_BOARD_ACTIVE
;
651 free_irq(bp
->irq
, NULL
);
652 IRQ_to_board
[bp
->irq
] = NULL
;
655 rc_out(bp
, RC_DTR
, bp
->DTR
); /* Drop DTR on all ports */
660 * Setting up port characteristics.
661 * Must be called with disabled interrupts
663 static void rc_change_speed(struct riscom_board
*bp
, struct riscom_port
*port
)
665 struct tty_struct
*tty
;
668 unsigned char cor1
= 0, cor3
= 0;
669 unsigned char mcor1
= 0, mcor2
= 0;
671 if (!(tty
= port
->tty
) || !tty
->termios
)
676 port
->MSVR
= MSVR_RTS
;
680 if (baud
& CBAUDEX
) {
682 if (baud
< 1 || baud
> 2)
683 port
->tty
->termios
->c_cflag
&= ~CBAUDEX
;
688 if ((port
->flags
& ASYNC_SPD_MASK
) == ASYNC_SPD_HI
)
690 if ((port
->flags
& ASYNC_SPD_MASK
) == ASYNC_SPD_VHI
)
694 /* Select port on the board */
695 rc_out(bp
, CD180_CAR
, port_No(port
));
697 if (!baud_table
[baud
]) {
698 /* Drop DTR & exit */
699 bp
->DTR
|= (1u << port_No(port
));
700 rc_out(bp
, RC_DTR
, bp
->DTR
);
704 bp
->DTR
&= ~(1u << port_No(port
));
705 rc_out(bp
, RC_DTR
, bp
->DTR
);
709 * Now we must calculate some speed depended things
712 /* Set baud rate for port */
713 tmp
= (((RC_OSCFREQ
+ baud_table
[baud
]/2) / baud_table
[baud
] +
714 CD180_TPC
/2) / CD180_TPC
);
716 rc_out(bp
, CD180_RBPRH
, (tmp
>> 8) & 0xff);
717 rc_out(bp
, CD180_TBPRH
, (tmp
>> 8) & 0xff);
718 rc_out(bp
, CD180_RBPRL
, tmp
& 0xff);
719 rc_out(bp
, CD180_TBPRL
, tmp
& 0xff);
721 baud
= (baud_table
[baud
] + 5) / 10; /* Estimated CPS */
723 /* Two timer ticks seems enough to wakeup something like SLIP driver */
724 tmp
= ((baud
+ HZ
/2) / HZ
) * 2 - CD180_NFIFO
;
725 port
->wakeup_chars
= (tmp
< 0) ? 0 : ((tmp
>= SERIAL_XMIT_SIZE
) ?
726 SERIAL_XMIT_SIZE
- 1 : tmp
);
728 /* Receiver timeout will be transmission time for 1.5 chars */
729 tmp
= (RISCOM_TPS
+ RISCOM_TPS
/2 + baud
/2) / baud
;
730 tmp
= (tmp
> 0xff) ? 0xff : tmp
;
731 rc_out(bp
, CD180_RTPR
, tmp
);
733 switch (C_CSIZE(tty
)) {
753 cor1
|= COR1_NORMPAR
;
757 cor1
&= ~COR1_IGNORE
;
759 /* Set marking of some errors */
760 port
->mark_mask
= RCSR_OE
| RCSR_TOUT
;
762 port
->mark_mask
|= RCSR_FE
| RCSR_PE
;
763 if (I_BRKINT(tty
) || I_PARMRK(tty
))
764 port
->mark_mask
|= RCSR_BREAK
;
766 port
->mark_mask
&= ~(RCSR_FE
| RCSR_PE
);
768 port
->mark_mask
&= ~RCSR_BREAK
;
770 /* Real raw mode. Ignore all */
771 port
->mark_mask
&= ~RCSR_OE
;
773 /* Enable Hardware Flow Control */
774 if (C_CRTSCTS(tty
)) {
775 #ifdef RISCOM_BRAIN_DAMAGED_CTS
776 port
->IER
|= IER_DSR
| IER_CTS
;
777 mcor1
|= MCOR1_DSRZD
| MCOR1_CTSZD
;
778 mcor2
|= MCOR2_DSROD
| MCOR2_CTSOD
;
779 tty
->hw_stopped
= !(rc_in(bp
, CD180_MSVR
) & (MSVR_CTS
|MSVR_DSR
));
781 port
->COR2
|= COR2_CTSAE
;
784 /* Enable Software Flow Control. FIXME: I'm not sure about this */
785 /* Some people reported that it works, but I still doubt */
787 port
->COR2
|= COR2_TXIBE
;
788 cor3
|= (COR3_FCT
| COR3_SCDE
);
790 port
->COR2
|= COR2_IXM
;
791 rc_out(bp
, CD180_SCHR1
, START_CHAR(tty
));
792 rc_out(bp
, CD180_SCHR2
, STOP_CHAR(tty
));
793 rc_out(bp
, CD180_SCHR3
, START_CHAR(tty
));
794 rc_out(bp
, CD180_SCHR4
, STOP_CHAR(tty
));
796 if (!C_CLOCAL(tty
)) {
797 /* Enable CD check */
804 /* Enable receiver */
805 port
->IER
|= IER_RXD
;
807 /* Set input FIFO size (1-8 bytes) */
808 cor3
|= RISCOM_RXFIFO
;
809 /* Setting up CD180 channel registers */
810 rc_out(bp
, CD180_COR1
, cor1
);
811 rc_out(bp
, CD180_COR2
, port
->COR2
);
812 rc_out(bp
, CD180_COR3
, cor3
);
813 /* Make CD180 know about registers change */
815 rc_out(bp
, CD180_CCR
, CCR_CORCHG1
| CCR_CORCHG2
| CCR_CORCHG3
);
816 /* Setting up modem option registers */
817 rc_out(bp
, CD180_MCOR1
, mcor1
);
818 rc_out(bp
, CD180_MCOR2
, mcor2
);
819 /* Enable CD180 transmitter & receiver */
821 rc_out(bp
, CD180_CCR
, CCR_TXEN
| CCR_RXEN
);
822 /* Enable interrupts */
823 rc_out(bp
, CD180_IER
, port
->IER
);
824 /* And finally set RTS on */
825 rc_out(bp
, CD180_MSVR
, port
->MSVR
);
828 /* Must be called with interrupts enabled */
829 static int rc_setup_port(struct riscom_board
*bp
, struct riscom_port
*port
)
833 if (port
->flags
& ASYNC_INITIALIZED
)
836 if (!port
->xmit_buf
) {
837 /* We may sleep in get_zeroed_page() */
840 if (!(tmp
= get_zeroed_page(GFP_KERNEL
)))
843 if (port
->xmit_buf
) {
847 port
->xmit_buf
= (unsigned char *) tmp
;
850 save_flags(flags
); cli();
853 clear_bit(TTY_IO_ERROR
, &port
->tty
->flags
);
855 if (port
->count
== 1)
858 port
->xmit_cnt
= port
->xmit_head
= port
->xmit_tail
= 0;
859 rc_change_speed(bp
, port
);
860 port
->flags
|= ASYNC_INITIALIZED
;
862 restore_flags(flags
);
866 /* Must be called with interrupts disabled */
867 static void rc_shutdown_port(struct riscom_board
*bp
, struct riscom_port
*port
)
869 struct tty_struct
*tty
;
871 if (!(port
->flags
& ASYNC_INITIALIZED
))
874 #ifdef RC_REPORT_OVERRUN
875 printk(KERN_INFO
"rc%d: port %d: Total %ld overruns were detected.\n",
876 board_No(bp
), port_No(port
), port
->overrun
);
878 #ifdef RC_REPORT_FIFO
882 printk(KERN_INFO
"rc%d: port %d: FIFO hits [ ",
883 board_No(bp
), port_No(port
));
884 for (i
= 0; i
< 10; i
++) {
885 printk("%ld ", port
->hits
[i
]);
890 if (port
->xmit_buf
) {
891 free_page((unsigned long) port
->xmit_buf
);
892 port
->xmit_buf
= NULL
;
895 if (!(tty
= port
->tty
) || C_HUPCL(tty
)) {
897 bp
->DTR
|= (1u << port_No(port
));
898 rc_out(bp
, RC_DTR
, bp
->DTR
);
902 rc_out(bp
, CD180_CAR
, port_No(port
));
905 rc_out(bp
, CD180_CCR
, CCR_SOFTRESET
);
906 /* Disable all interrupts from this port */
908 rc_out(bp
, CD180_IER
, port
->IER
);
911 set_bit(TTY_IO_ERROR
, &tty
->flags
);
912 port
->flags
&= ~ASYNC_INITIALIZED
;
914 if (--bp
->count
< 0) {
915 printk(KERN_INFO
"rc%d: rc_shutdown_port: "
916 "bad board count: %d\n",
917 board_No(bp
), bp
->count
);
922 * If this is the last opened port on the board
923 * shutdown whole board
926 rc_shutdown_board(bp
);
930 static int block_til_ready(struct tty_struct
*tty
, struct file
* filp
,
931 struct riscom_port
*port
)
933 DECLARE_WAITQUEUE(wait
, current
);
934 struct riscom_board
*bp
= port_Board(port
);
940 * If the device is in the middle of being closed, then block
941 * until it's done, and then try again.
943 if (tty_hung_up_p(filp
) || port
->flags
& ASYNC_CLOSING
) {
944 interruptible_sleep_on(&port
->close_wait
);
945 if (port
->flags
& ASYNC_HUP_NOTIFY
)
952 * If non-blocking mode is set, or the port is not enabled,
953 * then make the check up front and then exit.
955 if ((filp
->f_flags
& O_NONBLOCK
) ||
956 (tty
->flags
& (1 << TTY_IO_ERROR
))) {
957 port
->flags
|= ASYNC_NORMAL_ACTIVE
;
965 * Block waiting for the carrier detect and the line to become
966 * free (i.e., not in use by the callout). While we are in
967 * this loop, info->count is dropped by one, so that
968 * rs_close() knows when to free things. We restore it upon
969 * exit, either normal or abnormal.
972 add_wait_queue(&port
->open_wait
, &wait
);
974 if (!tty_hung_up_p(filp
))
977 port
->blocked_open
++;
980 rc_out(bp
, CD180_CAR
, port_No(port
));
981 CD
= rc_in(bp
, CD180_MSVR
) & MSVR_CD
;
982 rc_out(bp
, CD180_MSVR
, MSVR_RTS
);
983 bp
->DTR
&= ~(1u << port_No(port
));
984 rc_out(bp
, RC_DTR
, bp
->DTR
);
986 set_current_state(TASK_INTERRUPTIBLE
);
987 if (tty_hung_up_p(filp
) ||
988 !(port
->flags
& ASYNC_INITIALIZED
)) {
989 if (port
->flags
& ASYNC_HUP_NOTIFY
)
992 retval
= -ERESTARTSYS
;
995 if (!(port
->flags
& ASYNC_CLOSING
) &&
998 if (signal_pending(current
)) {
999 retval
= -ERESTARTSYS
;
1004 current
->state
= TASK_RUNNING
;
1005 remove_wait_queue(&port
->open_wait
, &wait
);
1006 if (!tty_hung_up_p(filp
))
1008 port
->blocked_open
--;
1012 port
->flags
|= ASYNC_NORMAL_ACTIVE
;
1016 static int rc_open(struct tty_struct
* tty
, struct file
* filp
)
1020 struct riscom_port
* port
;
1021 struct riscom_board
* bp
;
1023 board
= RC_BOARD(tty
->index
);
1024 if (board
>= RC_NBOARD
|| !(rc_board
[board
].flags
& RC_BOARD_PRESENT
))
1027 bp
= &rc_board
[board
];
1028 port
= rc_port
+ board
* RC_NPORT
+ RC_PORT(tty
->index
);
1029 if (rc_paranoia_check(port
, tty
->name
, "rc_open"))
1032 if ((error
= rc_setup_board(bp
)))
1036 tty
->driver_data
= port
;
1039 if ((error
= rc_setup_port(bp
, port
)))
1042 if ((error
= block_til_ready(tty
, filp
, port
)))
1048 static void rc_close(struct tty_struct
* tty
, struct file
* filp
)
1050 struct riscom_port
*port
= (struct riscom_port
*) tty
->driver_data
;
1051 struct riscom_board
*bp
;
1052 unsigned long flags
;
1053 unsigned long timeout
;
1055 if (!port
|| rc_paranoia_check(port
, tty
->name
, "close"))
1058 save_flags(flags
); cli();
1059 if (tty_hung_up_p(filp
))
1062 bp
= port_Board(port
);
1063 if ((tty
->count
== 1) && (port
->count
!= 1)) {
1064 printk(KERN_INFO
"rc%d: rc_close: bad port count;"
1065 " tty->count is 1, port count is %d\n",
1066 board_No(bp
), port
->count
);
1069 if (--port
->count
< 0) {
1070 printk(KERN_INFO
"rc%d: rc_close: bad port count "
1072 board_No(bp
), port_No(port
), port
->count
);
1077 port
->flags
|= ASYNC_CLOSING
;
1079 * Now we wait for the transmit buffer to clear; and we notify
1080 * the line discipline to only process XON/XOFF characters.
1083 if (port
->closing_wait
!= ASYNC_CLOSING_WAIT_NONE
)
1084 tty_wait_until_sent(tty
, port
->closing_wait
);
1086 * At this point we stop accepting input. To do this, we
1087 * disable the receive line status interrupts, and tell the
1088 * interrupt driver to stop checking the data ready bit in the
1089 * line status register.
1091 port
->IER
&= ~IER_RXD
;
1092 if (port
->flags
& ASYNC_INITIALIZED
) {
1093 port
->IER
&= ~IER_TXRDY
;
1094 port
->IER
|= IER_TXEMPTY
;
1095 rc_out(bp
, CD180_CAR
, port_No(port
));
1096 rc_out(bp
, CD180_IER
, port
->IER
);
1098 * Before we drop DTR, make sure the UART transmitter
1099 * has completely drained; this is especially
1100 * important if there is a transmit FIFO!
1102 timeout
= jiffies
+HZ
;
1103 while(port
->IER
& IER_TXEMPTY
) {
1104 msleep_interruptible(jiffies_to_msecs(port
->timeout
));
1105 if (time_after(jiffies
, timeout
))
1109 rc_shutdown_port(bp
, port
);
1110 if (tty
->driver
->flush_buffer
)
1111 tty
->driver
->flush_buffer(tty
);
1112 tty_ldisc_flush(tty
);
1117 if (port
->blocked_open
) {
1118 if (port
->close_delay
) {
1119 msleep_interruptible(jiffies_to_msecs(port
->close_delay
));
1121 wake_up_interruptible(&port
->open_wait
);
1123 port
->flags
&= ~(ASYNC_NORMAL_ACTIVE
|ASYNC_CLOSING
);
1124 wake_up_interruptible(&port
->close_wait
);
1125 out
: restore_flags(flags
);
1128 static int rc_write(struct tty_struct
* tty
,
1129 const unsigned char *buf
, int count
)
1131 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1132 struct riscom_board
*bp
;
1134 unsigned long flags
;
1136 if (rc_paranoia_check(port
, tty
->name
, "rc_write"))
1139 bp
= port_Board(port
);
1141 if (!tty
|| !port
->xmit_buf
|| !tmp_buf
)
1147 c
= min_t(int, count
, min(SERIAL_XMIT_SIZE
- port
->xmit_cnt
- 1,
1148 SERIAL_XMIT_SIZE
- port
->xmit_head
));
1150 restore_flags(flags
);
1154 memcpy(port
->xmit_buf
+ port
->xmit_head
, buf
, c
);
1155 port
->xmit_head
= (port
->xmit_head
+ c
) & (SERIAL_XMIT_SIZE
-1);
1156 port
->xmit_cnt
+= c
;
1157 restore_flags(flags
);
1165 if (port
->xmit_cnt
&& !tty
->stopped
&& !tty
->hw_stopped
&&
1166 !(port
->IER
& IER_TXRDY
)) {
1167 port
->IER
|= IER_TXRDY
;
1168 rc_out(bp
, CD180_CAR
, port_No(port
));
1169 rc_out(bp
, CD180_IER
, port
->IER
);
1171 restore_flags(flags
);
1176 static void rc_put_char(struct tty_struct
* tty
, unsigned char ch
)
1178 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1179 unsigned long flags
;
1181 if (rc_paranoia_check(port
, tty
->name
, "rc_put_char"))
1184 if (!tty
|| !port
->xmit_buf
)
1187 save_flags(flags
); cli();
1189 if (port
->xmit_cnt
>= SERIAL_XMIT_SIZE
- 1)
1192 port
->xmit_buf
[port
->xmit_head
++] = ch
;
1193 port
->xmit_head
&= SERIAL_XMIT_SIZE
- 1;
1195 out
: restore_flags(flags
);
1198 static void rc_flush_chars(struct tty_struct
* tty
)
1200 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1201 unsigned long flags
;
1203 if (rc_paranoia_check(port
, tty
->name
, "rc_flush_chars"))
1206 if (port
->xmit_cnt
<= 0 || tty
->stopped
|| tty
->hw_stopped
||
1210 save_flags(flags
); cli();
1211 port
->IER
|= IER_TXRDY
;
1212 rc_out(port_Board(port
), CD180_CAR
, port_No(port
));
1213 rc_out(port_Board(port
), CD180_IER
, port
->IER
);
1214 restore_flags(flags
);
1217 static int rc_write_room(struct tty_struct
* tty
)
1219 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1222 if (rc_paranoia_check(port
, tty
->name
, "rc_write_room"))
1225 ret
= SERIAL_XMIT_SIZE
- port
->xmit_cnt
- 1;
1231 static int rc_chars_in_buffer(struct tty_struct
*tty
)
1233 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1235 if (rc_paranoia_check(port
, tty
->name
, "rc_chars_in_buffer"))
1238 return port
->xmit_cnt
;
1241 static void rc_flush_buffer(struct tty_struct
*tty
)
1243 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1244 unsigned long flags
;
1246 if (rc_paranoia_check(port
, tty
->name
, "rc_flush_buffer"))
1249 save_flags(flags
); cli();
1250 port
->xmit_cnt
= port
->xmit_head
= port
->xmit_tail
= 0;
1251 restore_flags(flags
);
1253 wake_up_interruptible(&tty
->write_wait
);
1257 static int rc_tiocmget(struct tty_struct
*tty
, struct file
*file
)
1259 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1260 struct riscom_board
* bp
;
1261 unsigned char status
;
1262 unsigned int result
;
1263 unsigned long flags
;
1265 if (rc_paranoia_check(port
, tty
->name
, __FUNCTION__
))
1268 bp
= port_Board(port
);
1269 save_flags(flags
); cli();
1270 rc_out(bp
, CD180_CAR
, port_No(port
));
1271 status
= rc_in(bp
, CD180_MSVR
);
1272 result
= rc_in(bp
, RC_RI
) & (1u << port_No(port
)) ? 0 : TIOCM_RNG
;
1273 restore_flags(flags
);
1274 result
|= ((status
& MSVR_RTS
) ? TIOCM_RTS
: 0)
1275 | ((status
& MSVR_DTR
) ? TIOCM_DTR
: 0)
1276 | ((status
& MSVR_CD
) ? TIOCM_CAR
: 0)
1277 | ((status
& MSVR_DSR
) ? TIOCM_DSR
: 0)
1278 | ((status
& MSVR_CTS
) ? TIOCM_CTS
: 0);
1282 static int rc_tiocmset(struct tty_struct
*tty
, struct file
*file
,
1283 unsigned int set
, unsigned int clear
)
1285 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1286 unsigned long flags
;
1287 struct riscom_board
*bp
;
1289 if (rc_paranoia_check(port
, tty
->name
, __FUNCTION__
))
1292 bp
= port_Board(port
);
1294 save_flags(flags
); cli();
1295 if (set
& TIOCM_RTS
)
1296 port
->MSVR
|= MSVR_RTS
;
1297 if (set
& TIOCM_DTR
)
1298 bp
->DTR
&= ~(1u << port_No(port
));
1300 if (clear
& TIOCM_RTS
)
1301 port
->MSVR
&= ~MSVR_RTS
;
1302 if (clear
& TIOCM_DTR
)
1303 bp
->DTR
|= (1u << port_No(port
));
1305 rc_out(bp
, CD180_CAR
, port_No(port
));
1306 rc_out(bp
, CD180_MSVR
, port
->MSVR
);
1307 rc_out(bp
, RC_DTR
, bp
->DTR
);
1308 restore_flags(flags
);
1312 static inline void rc_send_break(struct riscom_port
* port
, unsigned long length
)
1314 struct riscom_board
*bp
= port_Board(port
);
1315 unsigned long flags
;
1317 save_flags(flags
); cli();
1318 port
->break_length
= RISCOM_TPS
/ HZ
* length
;
1319 port
->COR2
|= COR2_ETC
;
1320 port
->IER
|= IER_TXRDY
;
1321 rc_out(bp
, CD180_CAR
, port_No(port
));
1322 rc_out(bp
, CD180_COR2
, port
->COR2
);
1323 rc_out(bp
, CD180_IER
, port
->IER
);
1325 rc_out(bp
, CD180_CCR
, CCR_CORCHG2
);
1327 restore_flags(flags
);
1330 static inline int rc_set_serial_info(struct riscom_port
* port
,
1331 struct serial_struct __user
* newinfo
)
1333 struct serial_struct tmp
;
1334 struct riscom_board
*bp
= port_Board(port
);
1336 unsigned long flags
;
1338 if (copy_from_user(&tmp
, newinfo
, sizeof(tmp
)))
1342 if ((tmp
.irq
!= bp
->irq
) ||
1343 (tmp
.port
!= bp
->base
) ||
1344 (tmp
.type
!= PORT_CIRRUS
) ||
1345 (tmp
.baud_base
!= (RC_OSCFREQ
+ CD180_TPC
/2) / CD180_TPC
) ||
1346 (tmp
.custom_divisor
!= 0) ||
1347 (tmp
.xmit_fifo_size
!= CD180_NFIFO
) ||
1348 (tmp
.flags
& ~RISCOM_LEGAL_FLAGS
))
1352 change_speed
= ((port
->flags
& ASYNC_SPD_MASK
) !=
1353 (tmp
.flags
& ASYNC_SPD_MASK
));
1355 if (!capable(CAP_SYS_ADMIN
)) {
1356 if ((tmp
.close_delay
!= port
->close_delay
) ||
1357 (tmp
.closing_wait
!= port
->closing_wait
) ||
1358 ((tmp
.flags
& ~ASYNC_USR_MASK
) !=
1359 (port
->flags
& ~ASYNC_USR_MASK
)))
1361 port
->flags
= ((port
->flags
& ~ASYNC_USR_MASK
) |
1362 (tmp
.flags
& ASYNC_USR_MASK
));
1364 port
->flags
= ((port
->flags
& ~ASYNC_FLAGS
) |
1365 (tmp
.flags
& ASYNC_FLAGS
));
1366 port
->close_delay
= tmp
.close_delay
;
1367 port
->closing_wait
= tmp
.closing_wait
;
1370 save_flags(flags
); cli();
1371 rc_change_speed(bp
, port
);
1372 restore_flags(flags
);
1377 static inline int rc_get_serial_info(struct riscom_port
* port
,
1378 struct serial_struct __user
*retinfo
)
1380 struct serial_struct tmp
;
1381 struct riscom_board
*bp
= port_Board(port
);
1383 memset(&tmp
, 0, sizeof(tmp
));
1384 tmp
.type
= PORT_CIRRUS
;
1385 tmp
.line
= port
- rc_port
;
1386 tmp
.port
= bp
->base
;
1388 tmp
.flags
= port
->flags
;
1389 tmp
.baud_base
= (RC_OSCFREQ
+ CD180_TPC
/2) / CD180_TPC
;
1390 tmp
.close_delay
= port
->close_delay
* HZ
/100;
1391 tmp
.closing_wait
= port
->closing_wait
* HZ
/100;
1392 tmp
.xmit_fifo_size
= CD180_NFIFO
;
1393 return copy_to_user(retinfo
, &tmp
, sizeof(tmp
)) ? -EFAULT
: 0;
1396 static int rc_ioctl(struct tty_struct
* tty
, struct file
* filp
,
1397 unsigned int cmd
, unsigned long arg
)
1400 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1401 void __user
*argp
= (void __user
*)arg
;
1404 if (rc_paranoia_check(port
, tty
->name
, "rc_ioctl"))
1408 case TCSBRK
: /* SVID version: non-zero arg --> no break */
1409 retval
= tty_check_change(tty
);
1412 tty_wait_until_sent(tty
, 0);
1414 rc_send_break(port
, HZ
/4); /* 1/4 second */
1416 case TCSBRKP
: /* support for POSIX tcsendbreak() */
1417 retval
= tty_check_change(tty
);
1420 tty_wait_until_sent(tty
, 0);
1421 rc_send_break(port
, arg
? arg
*(HZ
/10) : HZ
/4);
1424 return put_user(C_CLOCAL(tty
) ? 1 : 0, (unsigned __user
*)argp
);
1426 if (get_user(arg
,(unsigned __user
*) argp
))
1428 tty
->termios
->c_cflag
=
1429 ((tty
->termios
->c_cflag
& ~CLOCAL
) |
1430 (arg
? CLOCAL
: 0));
1433 return rc_get_serial_info(port
, argp
);
1435 return rc_set_serial_info(port
, argp
);
1437 return -ENOIOCTLCMD
;
1442 static void rc_throttle(struct tty_struct
* tty
)
1444 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1445 struct riscom_board
*bp
;
1446 unsigned long flags
;
1448 if (rc_paranoia_check(port
, tty
->name
, "rc_throttle"))
1451 bp
= port_Board(port
);
1453 save_flags(flags
); cli();
1454 port
->MSVR
&= ~MSVR_RTS
;
1455 rc_out(bp
, CD180_CAR
, port_No(port
));
1458 rc_out(bp
, CD180_CCR
, CCR_SSCH2
);
1461 rc_out(bp
, CD180_MSVR
, port
->MSVR
);
1462 restore_flags(flags
);
1465 static void rc_unthrottle(struct tty_struct
* tty
)
1467 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1468 struct riscom_board
*bp
;
1469 unsigned long flags
;
1471 if (rc_paranoia_check(port
, tty
->name
, "rc_unthrottle"))
1474 bp
= port_Board(port
);
1476 save_flags(flags
); cli();
1477 port
->MSVR
|= MSVR_RTS
;
1478 rc_out(bp
, CD180_CAR
, port_No(port
));
1481 rc_out(bp
, CD180_CCR
, CCR_SSCH1
);
1484 rc_out(bp
, CD180_MSVR
, port
->MSVR
);
1485 restore_flags(flags
);
1488 static void rc_stop(struct tty_struct
* tty
)
1490 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1491 struct riscom_board
*bp
;
1492 unsigned long flags
;
1494 if (rc_paranoia_check(port
, tty
->name
, "rc_stop"))
1497 bp
= port_Board(port
);
1499 save_flags(flags
); cli();
1500 port
->IER
&= ~IER_TXRDY
;
1501 rc_out(bp
, CD180_CAR
, port_No(port
));
1502 rc_out(bp
, CD180_IER
, port
->IER
);
1503 restore_flags(flags
);
1506 static void rc_start(struct tty_struct
* tty
)
1508 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1509 struct riscom_board
*bp
;
1510 unsigned long flags
;
1512 if (rc_paranoia_check(port
, tty
->name
, "rc_start"))
1515 bp
= port_Board(port
);
1517 save_flags(flags
); cli();
1518 if (port
->xmit_cnt
&& port
->xmit_buf
&& !(port
->IER
& IER_TXRDY
)) {
1519 port
->IER
|= IER_TXRDY
;
1520 rc_out(bp
, CD180_CAR
, port_No(port
));
1521 rc_out(bp
, CD180_IER
, port
->IER
);
1523 restore_flags(flags
);
1527 * This routine is called from the work queue when the interrupt
1528 * routine has signalled that a hangup has occurred. The path of
1529 * hangup processing is:
1531 * serial interrupt routine -> (workqueue) ->
1532 * do_rc_hangup() -> tty->hangup() -> rc_hangup()
1535 static void do_rc_hangup(void *private_
)
1537 struct riscom_port
*port
= (struct riscom_port
*) private_
;
1538 struct tty_struct
*tty
;
1542 tty_hangup(tty
); /* FIXME: module removal race still here */
1545 static void rc_hangup(struct tty_struct
* tty
)
1547 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1548 struct riscom_board
*bp
;
1550 if (rc_paranoia_check(port
, tty
->name
, "rc_hangup"))
1553 bp
= port_Board(port
);
1555 rc_shutdown_port(bp
, port
);
1558 port
->flags
&= ~ASYNC_NORMAL_ACTIVE
;
1560 wake_up_interruptible(&port
->open_wait
);
1563 static void rc_set_termios(struct tty_struct
* tty
, struct termios
* old_termios
)
1565 struct riscom_port
*port
= (struct riscom_port
*)tty
->driver_data
;
1566 unsigned long flags
;
1568 if (rc_paranoia_check(port
, tty
->name
, "rc_set_termios"))
1571 if (tty
->termios
->c_cflag
== old_termios
->c_cflag
&&
1572 tty
->termios
->c_iflag
== old_termios
->c_iflag
)
1575 save_flags(flags
); cli();
1576 rc_change_speed(port_Board(port
), port
);
1577 restore_flags(flags
);
1579 if ((old_termios
->c_cflag
& CRTSCTS
) &&
1580 !(tty
->termios
->c_cflag
& CRTSCTS
)) {
1581 tty
->hw_stopped
= 0;
1586 static void do_softint(void *private_
)
1588 struct riscom_port
*port
= (struct riscom_port
*) private_
;
1589 struct tty_struct
*tty
;
1591 if(!(tty
= port
->tty
))
1594 if (test_and_clear_bit(RS_EVENT_WRITE_WAKEUP
, &port
->event
)) {
1596 wake_up_interruptible(&tty
->write_wait
);
1600 static struct tty_operations riscom_ops
= {
1604 .put_char
= rc_put_char
,
1605 .flush_chars
= rc_flush_chars
,
1606 .write_room
= rc_write_room
,
1607 .chars_in_buffer
= rc_chars_in_buffer
,
1608 .flush_buffer
= rc_flush_buffer
,
1610 .throttle
= rc_throttle
,
1611 .unthrottle
= rc_unthrottle
,
1612 .set_termios
= rc_set_termios
,
1615 .hangup
= rc_hangup
,
1616 .tiocmget
= rc_tiocmget
,
1617 .tiocmset
= rc_tiocmset
,
1620 static inline int rc_init_drivers(void)
1625 riscom_driver
= alloc_tty_driver(RC_NBOARD
* RC_NPORT
);
1629 if (!(tmp_buf
= (unsigned char *) get_zeroed_page(GFP_KERNEL
))) {
1630 printk(KERN_ERR
"rc: Couldn't get free page.\n");
1631 put_tty_driver(riscom_driver
);
1634 memset(IRQ_to_board
, 0, sizeof(IRQ_to_board
));
1635 riscom_driver
->owner
= THIS_MODULE
;
1636 riscom_driver
->name
= "ttyL";
1637 riscom_driver
->major
= RISCOM8_NORMAL_MAJOR
;
1638 riscom_driver
->type
= TTY_DRIVER_TYPE_SERIAL
;
1639 riscom_driver
->subtype
= SERIAL_TYPE_NORMAL
;
1640 riscom_driver
->init_termios
= tty_std_termios
;
1641 riscom_driver
->init_termios
.c_cflag
=
1642 B9600
| CS8
| CREAD
| HUPCL
| CLOCAL
;
1643 riscom_driver
->flags
= TTY_DRIVER_REAL_RAW
;
1644 tty_set_operations(riscom_driver
, &riscom_ops
);
1645 if ((error
= tty_register_driver(riscom_driver
))) {
1646 free_page((unsigned long)tmp_buf
);
1647 put_tty_driver(riscom_driver
);
1648 printk(KERN_ERR
"rc: Couldn't register RISCom/8 driver, "
1654 memset(rc_port
, 0, sizeof(rc_port
));
1655 for (i
= 0; i
< RC_NPORT
* RC_NBOARD
; i
++) {
1656 rc_port
[i
].magic
= RISCOM8_MAGIC
;
1657 INIT_WORK(&rc_port
[i
].tqueue
, do_softint
, &rc_port
[i
]);
1658 INIT_WORK(&rc_port
[i
].tqueue_hangup
, do_rc_hangup
, &rc_port
[i
]);
1659 rc_port
[i
].close_delay
= 50 * HZ
/100;
1660 rc_port
[i
].closing_wait
= 3000 * HZ
/100;
1661 init_waitqueue_head(&rc_port
[i
].open_wait
);
1662 init_waitqueue_head(&rc_port
[i
].close_wait
);
1668 static void rc_release_drivers(void)
1670 unsigned long flags
;
1674 free_page((unsigned long)tmp_buf
);
1675 tty_unregister_driver(riscom_driver
);
1676 put_tty_driver(riscom_driver
);
1677 restore_flags(flags
);
1682 * Called at boot time.
1684 * You can specify IO base for up to RC_NBOARD cards,
1685 * using line "riscom8=0xiobase1,0xiobase2,.." at LILO prompt.
1686 * Note that there will be no probing at default
1687 * addresses in this case.
1690 static int __init
riscom8_setup(char *str
)
1692 int ints
[RC_NBOARD
];
1695 str
= get_options(str
, ARRAY_SIZE(ints
), ints
);
1697 for (i
= 0; i
< RC_NBOARD
; i
++) {
1699 rc_board
[i
].base
= ints
[i
+1];
1701 rc_board
[i
].base
= 0;
1706 __setup("riscom8=", riscom8_setup
);
1709 static char banner
[] __initdata
=
1710 KERN_INFO
"rc: SDL RISCom/8 card driver v1.1, (c) D.Gorodchanin "
1712 static char no_boards_msg
[] __initdata
=
1713 KERN_INFO
"rc: No RISCom/8 boards detected.\n";
1716 * This routine must be called by kernel at boot time
1718 static int __init
riscom8_init(void)
1725 if (rc_init_drivers())
1728 for (i
= 0; i
< RC_NBOARD
; i
++)
1729 if (rc_board
[i
].base
&& !rc_probe(&rc_board
[i
]))
1733 rc_release_drivers();
1734 printk(no_boards_msg
);
1745 module_param(iobase
, int, 0);
1746 module_param(iobase1
, int, 0);
1747 module_param(iobase2
, int, 0);
1748 module_param(iobase3
, int, 0);
1750 MODULE_LICENSE("GPL");
1754 * You can setup up to 4 boards (current value of RC_NBOARD)
1755 * by specifying "iobase=0xXXX iobase1=0xXXX ..." as insmod parameter.
1758 static int __init
riscom8_init_module (void)
1763 if (iobase
|| iobase1
|| iobase2
|| iobase3
) {
1764 for(i
= 0; i
< RC_NBOARD
; i
++)
1765 rc_board
[0].base
= 0;
1769 rc_board
[0].base
= iobase
;
1771 rc_board
[1].base
= iobase1
;
1773 rc_board
[2].base
= iobase2
;
1775 rc_board
[3].base
= iobase3
;
1778 return riscom8_init();
1781 static void __exit
riscom8_exit_module (void)
1785 rc_release_drivers();
1786 for (i
= 0; i
< RC_NBOARD
; i
++)
1787 if (rc_board
[i
].flags
& RC_BOARD_PRESENT
)
1788 rc_release_io_range(&rc_board
[i
]);
1792 module_init(riscom8_init_module
);
1793 module_exit(riscom8_exit_module
);