diff options
Diffstat (limited to 'drivers/char/esp.c')
-rw-r--r-- | drivers/char/esp.c | 58 |
1 files changed, 5 insertions, 53 deletions
diff --git a/drivers/char/esp.c b/drivers/char/esp.c index b5df2dc40491..c01e26d9ee5e 100644 --- a/drivers/char/esp.c +++ b/drivers/char/esp.c | |||
@@ -242,17 +242,6 @@ static void rs_start(struct tty_struct *tty) | |||
242 | * ----------------------------------------------------------------------- | 242 | * ----------------------------------------------------------------------- |
243 | */ | 243 | */ |
244 | 244 | ||
245 | /* | ||
246 | * This routine is used by the interrupt handler to schedule | ||
247 | * processing in the software interrupt portion of the driver. | ||
248 | */ | ||
249 | static inline void rs_sched_event(struct esp_struct *info, | ||
250 | int event) | ||
251 | { | ||
252 | info->event |= 1 << event; | ||
253 | schedule_work(&info->tqueue); | ||
254 | } | ||
255 | |||
256 | static DEFINE_SPINLOCK(pio_lock); | 245 | static DEFINE_SPINLOCK(pio_lock); |
257 | 246 | ||
258 | static inline struct esp_pio_buffer *get_pio_buffer(void) | 247 | static inline struct esp_pio_buffer *get_pio_buffer(void) |
@@ -474,7 +463,8 @@ static inline void transmit_chars_pio(struct esp_struct *info, | |||
474 | } | 463 | } |
475 | 464 | ||
476 | if (info->xmit_cnt < WAKEUP_CHARS) { | 465 | if (info->xmit_cnt < WAKEUP_CHARS) { |
477 | rs_sched_event(info, ESP_EVENT_WRITE_WAKEUP); | 466 | if (info->tty) |
467 | tty_wakeup(info->tty); | ||
478 | 468 | ||
479 | #ifdef SERIAL_DEBUG_INTR | 469 | #ifdef SERIAL_DEBUG_INTR |
480 | printk("THRE..."); | 470 | printk("THRE..."); |
@@ -512,7 +502,8 @@ static inline void transmit_chars_dma(struct esp_struct *info, int num_bytes) | |||
512 | info->xmit_tail = (info->xmit_tail + dma_bytes) & (ESP_XMIT_SIZE - 1); | 502 | info->xmit_tail = (info->xmit_tail + dma_bytes) & (ESP_XMIT_SIZE - 1); |
513 | 503 | ||
514 | if (info->xmit_cnt < WAKEUP_CHARS) { | 504 | if (info->xmit_cnt < WAKEUP_CHARS) { |
515 | rs_sched_event(info, ESP_EVENT_WRITE_WAKEUP); | 505 | if (info->tty) |
506 | tty_wakeup(info->tty); | ||
516 | 507 | ||
517 | #ifdef SERIAL_DEBUG_INTR | 508 | #ifdef SERIAL_DEBUG_INTR |
518 | printk("THRE..."); | 509 | printk("THRE..."); |
@@ -604,7 +595,7 @@ static inline void check_modem_status(struct esp_struct *info) | |||
604 | #ifdef SERIAL_DEBUG_OPEN | 595 | #ifdef SERIAL_DEBUG_OPEN |
605 | printk("scheduling hangup..."); | 596 | printk("scheduling hangup..."); |
606 | #endif | 597 | #endif |
607 | schedule_work(&info->tqueue_hangup); | 598 | tty_hangup(info->tty); |
608 | } | 599 | } |
609 | } | 600 | } |
610 | } | 601 | } |
@@ -720,41 +711,6 @@ static irqreturn_t rs_interrupt_single(int irq, void *dev_id) | |||
720 | * ------------------------------------------------------------------- | 711 | * ------------------------------------------------------------------- |
721 | */ | 712 | */ |
722 | 713 | ||
723 | static void do_softint(struct work_struct *work) | ||
724 | { | ||
725 | struct esp_struct *info = | ||
726 | container_of(work, struct esp_struct, tqueue); | ||
727 | struct tty_struct *tty; | ||
728 | |||
729 | tty = info->tty; | ||
730 | if (!tty) | ||
731 | return; | ||
732 | |||
733 | if (test_and_clear_bit(ESP_EVENT_WRITE_WAKEUP, &info->event)) { | ||
734 | tty_wakeup(tty); | ||
735 | } | ||
736 | } | ||
737 | |||
738 | /* | ||
739 | * This routine is called from the scheduler tqueue when the interrupt | ||
740 | * routine has signalled that a hangup has occurred. The path of | ||
741 | * hangup processing is: | ||
742 | * | ||
743 | * serial interrupt routine -> (scheduler tqueue) -> | ||
744 | * do_serial_hangup() -> tty->hangup() -> esp_hangup() | ||
745 | * | ||
746 | */ | ||
747 | static void do_serial_hangup(struct work_struct *work) | ||
748 | { | ||
749 | struct esp_struct *info = | ||
750 | container_of(work, struct esp_struct, tqueue_hangup); | ||
751 | struct tty_struct *tty; | ||
752 | |||
753 | tty = info->tty; | ||
754 | if (tty) | ||
755 | tty_hangup(tty); | ||
756 | } | ||
757 | |||
758 | /* | 714 | /* |
759 | * --------------------------------------------------------------- | 715 | * --------------------------------------------------------------- |
760 | * Low level utility subroutines for the serial driver: routines to | 716 | * Low level utility subroutines for the serial driver: routines to |
@@ -2038,7 +1994,6 @@ static void rs_close(struct tty_struct *tty, struct file * filp) | |||
2038 | tty->driver->flush_buffer(tty); | 1994 | tty->driver->flush_buffer(tty); |
2039 | tty_ldisc_flush(tty); | 1995 | tty_ldisc_flush(tty); |
2040 | tty->closing = 0; | 1996 | tty->closing = 0; |
2041 | info->event = 0; | ||
2042 | info->tty = NULL; | 1997 | info->tty = NULL; |
2043 | 1998 | ||
2044 | if (info->blocked_open) { | 1999 | if (info->blocked_open) { |
@@ -2106,7 +2061,6 @@ static void esp_hangup(struct tty_struct *tty) | |||
2106 | 2061 | ||
2107 | rs_flush_buffer(tty); | 2062 | rs_flush_buffer(tty); |
2108 | shutdown(info); | 2063 | shutdown(info); |
2109 | info->event = 0; | ||
2110 | info->count = 0; | 2064 | info->count = 0; |
2111 | info->flags &= ~ASYNC_NORMAL_ACTIVE; | 2065 | info->flags &= ~ASYNC_NORMAL_ACTIVE; |
2112 | info->tty = NULL; | 2066 | info->tty = NULL; |
@@ -2492,8 +2446,6 @@ static int __init espserial_init(void) | |||
2492 | info->magic = ESP_MAGIC; | 2446 | info->magic = ESP_MAGIC; |
2493 | info->close_delay = 5*HZ/10; | 2447 | info->close_delay = 5*HZ/10; |
2494 | info->closing_wait = 30*HZ; | 2448 | info->closing_wait = 30*HZ; |
2495 | INIT_WORK(&info->tqueue, do_softint); | ||
2496 | INIT_WORK(&info->tqueue_hangup, do_serial_hangup); | ||
2497 | info->config.rx_timeout = rx_timeout; | 2449 | info->config.rx_timeout = rx_timeout; |
2498 | info->config.flow_on = flow_on; | 2450 | info->config.flow_on = flow_on; |
2499 | info->config.flow_off = flow_off; | 2451 | info->config.flow_off = flow_off; |