aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/char/isicom.c41
-rw-r--r--include/linux/isicom.h1
2 files changed, 12 insertions, 30 deletions
diff --git a/drivers/char/isicom.c b/drivers/char/isicom.c
index e7be3ec6d21c..1e91c302ee42 100644
--- a/drivers/char/isicom.c
+++ b/drivers/char/isicom.c
@@ -793,21 +793,19 @@ static inline void isicom_setup_board(struct isi_board *bp)
793{ 793{
794 int channel; 794 int channel;
795 struct isi_port *port; 795 struct isi_port *port;
796 unsigned long flags;
797 796
798 spin_lock_irqsave(&bp->card_lock, flags);
799 if (bp->status & BOARD_ACTIVE) {
800 spin_unlock_irqrestore(&bp->card_lock, flags);
801 return;
802 }
803 port = bp->ports;
804 bp->status |= BOARD_ACTIVE;
805 for (channel = 0; channel < bp->port_count; channel++, port++)
806 drop_dtr_rts(port);
807 bp->count++; 797 bp->count++;
808 spin_unlock_irqrestore(&bp->card_lock, flags); 798 if (!(bp->status & BOARD_INIT)) {
799 port = bp->ports;
800 for (channel = 0; channel < bp->port_count; channel++, port++)
801 drop_dtr_rts(port);
802 }
803 bp->status |= BOARD_ACTIVE | BOARD_INIT;
809} 804}
810 805
806/* Activate and thus setup board are protected from races against shutdown
807 by the tty_port mutex */
808
811static int isicom_activate(struct tty_port *tport, struct tty_struct *tty) 809static int isicom_activate(struct tty_port *tport, struct tty_struct *tty)
812{ 810{
813 struct isi_port *port = container_of(tport, struct isi_port, port); 811 struct isi_port *port = container_of(tport, struct isi_port, port);
@@ -884,19 +882,10 @@ static int isicom_open(struct tty_struct *tty, struct file *filp)
884 882
885/* close et all */ 883/* close et all */
886 884
887static inline void isicom_shutdown_board(struct isi_board *bp)
888{
889 if (bp->status & BOARD_ACTIVE)
890 bp->status &= ~BOARD_ACTIVE;
891}
892
893/* card->lock HAS to be held */ 885/* card->lock HAS to be held */
894static void isicom_shutdown_port(struct isi_port *port) 886static void isicom_shutdown_port(struct isi_port *port)
895{ 887{
896 struct isi_board *card = port->card; 888 struct isi_board *card = port->card;
897 struct tty_struct *tty;
898
899 tty = tty_port_tty_get(&port->port);
900 889
901 tty_port_free_xmit_buf(&port->port); 890 tty_port_free_xmit_buf(&port->port);
902 if (--card->count < 0) { 891 if (--card->count < 0) {
@@ -904,17 +893,9 @@ static void isicom_shutdown_port(struct isi_port *port)
904 card->base, card->count); 893 card->base, card->count);
905 card->count = 0; 894 card->count = 0;
906 } 895 }
907
908 /* last port was closed, shutdown that board too */ 896 /* last port was closed, shutdown that board too */
909 if (tty && C_HUPCL(tty)) { 897 if (!card->count)
910 /* FIXME: this logic is bogus - it's the old logic that was 898 card->status &= BOARD_ACTIVE;
911 bogus before but it still wants fixing */
912 if (!card->count) {
913 if (card->status & BOARD_ACTIVE)
914 card->status &= ~BOARD_ACTIVE;
915 }
916 }
917 tty_kref_put(tty);
918} 899}
919 900
920static void isicom_flush_buffer(struct tty_struct *tty) 901static void isicom_flush_buffer(struct tty_struct *tty)
diff --git a/include/linux/isicom.h b/include/linux/isicom.h
index bbd42197298f..b92e05650639 100644
--- a/include/linux/isicom.h
+++ b/include/linux/isicom.h
@@ -67,6 +67,7 @@
67 67
68#define FIRMWARE_LOADED 0x0001 68#define FIRMWARE_LOADED 0x0001
69#define BOARD_ACTIVE 0x0002 69#define BOARD_ACTIVE 0x0002
70#define BOARD_INIT 0x0004
70 71
71 /* isi_port status bitmap */ 72 /* isi_port status bitmap */
72 73