diff options
Diffstat (limited to 'drivers/net/hamradio/6pack.c')
-rw-r--r-- | drivers/net/hamradio/6pack.c | 36 |
1 files changed, 19 insertions, 17 deletions
diff --git a/drivers/net/hamradio/6pack.c b/drivers/net/hamradio/6pack.c index 1da55dd2a5a0..82a36266dfc9 100644 --- a/drivers/net/hamradio/6pack.c +++ b/drivers/net/hamradio/6pack.c | |||
@@ -148,13 +148,13 @@ static void sp_xmit_on_air(unsigned long channel) | |||
148 | 148 | ||
149 | if (((sp->status1 & SIXP_DCD_MASK) == 0) && (random < sp->persistence)) { | 149 | if (((sp->status1 & SIXP_DCD_MASK) == 0) && (random < sp->persistence)) { |
150 | sp->led_state = 0x70; | 150 | sp->led_state = 0x70; |
151 | sp->tty->driver->write(sp->tty, &sp->led_state, 1); | 151 | sp->tty->ops->write(sp->tty, &sp->led_state, 1); |
152 | sp->tx_enable = 1; | 152 | sp->tx_enable = 1; |
153 | actual = sp->tty->driver->write(sp->tty, sp->xbuff, sp->status2); | 153 | actual = sp->tty->ops->write(sp->tty, sp->xbuff, sp->status2); |
154 | sp->xleft -= actual; | 154 | sp->xleft -= actual; |
155 | sp->xhead += actual; | 155 | sp->xhead += actual; |
156 | sp->led_state = 0x60; | 156 | sp->led_state = 0x60; |
157 | sp->tty->driver->write(sp->tty, &sp->led_state, 1); | 157 | sp->tty->ops->write(sp->tty, &sp->led_state, 1); |
158 | sp->status2 = 0; | 158 | sp->status2 = 0; |
159 | } else | 159 | } else |
160 | mod_timer(&sp->tx_t, jiffies + ((when + 1) * HZ) / 100); | 160 | mod_timer(&sp->tx_t, jiffies + ((when + 1) * HZ) / 100); |
@@ -220,13 +220,13 @@ static void sp_encaps(struct sixpack *sp, unsigned char *icp, int len) | |||
220 | */ | 220 | */ |
221 | if (sp->duplex == 1) { | 221 | if (sp->duplex == 1) { |
222 | sp->led_state = 0x70; | 222 | sp->led_state = 0x70; |
223 | sp->tty->driver->write(sp->tty, &sp->led_state, 1); | 223 | sp->tty->ops->write(sp->tty, &sp->led_state, 1); |
224 | sp->tx_enable = 1; | 224 | sp->tx_enable = 1; |
225 | actual = sp->tty->driver->write(sp->tty, sp->xbuff, count); | 225 | actual = sp->tty->ops->write(sp->tty, sp->xbuff, count); |
226 | sp->xleft = count - actual; | 226 | sp->xleft = count - actual; |
227 | sp->xhead = sp->xbuff + actual; | 227 | sp->xhead = sp->xbuff + actual; |
228 | sp->led_state = 0x60; | 228 | sp->led_state = 0x60; |
229 | sp->tty->driver->write(sp->tty, &sp->led_state, 1); | 229 | sp->tty->ops->write(sp->tty, &sp->led_state, 1); |
230 | } else { | 230 | } else { |
231 | sp->xleft = count; | 231 | sp->xleft = count; |
232 | sp->xhead = sp->xbuff; | 232 | sp->xhead = sp->xbuff; |
@@ -444,7 +444,7 @@ static void sixpack_write_wakeup(struct tty_struct *tty) | |||
444 | } | 444 | } |
445 | 445 | ||
446 | if (sp->tx_enable) { | 446 | if (sp->tx_enable) { |
447 | actual = tty->driver->write(tty, sp->xhead, sp->xleft); | 447 | actual = tty->ops->write(tty, sp->xhead, sp->xleft); |
448 | sp->xleft -= actual; | 448 | sp->xleft -= actual; |
449 | sp->xhead += actual; | 449 | sp->xhead += actual; |
450 | } | 450 | } |
@@ -492,8 +492,8 @@ static void sixpack_receive_buf(struct tty_struct *tty, | |||
492 | 492 | ||
493 | sp_put(sp); | 493 | sp_put(sp); |
494 | if (test_and_clear_bit(TTY_THROTTLED, &tty->flags) | 494 | if (test_and_clear_bit(TTY_THROTTLED, &tty->flags) |
495 | && tty->driver->unthrottle) | 495 | && tty->ops->unthrottle) |
496 | tty->driver->unthrottle(tty); | 496 | tty->ops->unthrottle(tty); |
497 | } | 497 | } |
498 | 498 | ||
499 | /* | 499 | /* |
@@ -554,8 +554,8 @@ static void resync_tnc(unsigned long channel) | |||
554 | /* resync the TNC */ | 554 | /* resync the TNC */ |
555 | 555 | ||
556 | sp->led_state = 0x60; | 556 | sp->led_state = 0x60; |
557 | sp->tty->driver->write(sp->tty, &sp->led_state, 1); | 557 | sp->tty->ops->write(sp->tty, &sp->led_state, 1); |
558 | sp->tty->driver->write(sp->tty, &resync_cmd, 1); | 558 | sp->tty->ops->write(sp->tty, &resync_cmd, 1); |
559 | 559 | ||
560 | 560 | ||
561 | /* Start resync timer again -- the TNC might be still absent */ | 561 | /* Start resync timer again -- the TNC might be still absent */ |
@@ -573,7 +573,7 @@ static inline int tnc_init(struct sixpack *sp) | |||
573 | 573 | ||
574 | tnc_set_sync_state(sp, TNC_UNSYNC_STARTUP); | 574 | tnc_set_sync_state(sp, TNC_UNSYNC_STARTUP); |
575 | 575 | ||
576 | sp->tty->driver->write(sp->tty, &inbyte, 1); | 576 | sp->tty->ops->write(sp->tty, &inbyte, 1); |
577 | 577 | ||
578 | del_timer(&sp->resync_t); | 578 | del_timer(&sp->resync_t); |
579 | sp->resync_t.data = (unsigned long) sp; | 579 | sp->resync_t.data = (unsigned long) sp; |
@@ -601,6 +601,8 @@ static int sixpack_open(struct tty_struct *tty) | |||
601 | 601 | ||
602 | if (!capable(CAP_NET_ADMIN)) | 602 | if (!capable(CAP_NET_ADMIN)) |
603 | return -EPERM; | 603 | return -EPERM; |
604 | if (tty->ops->write == NULL) | ||
605 | return -EOPNOTSUPP; | ||
604 | 606 | ||
605 | dev = alloc_netdev(sizeof(struct sixpack), "sp%d", sp_setup); | 607 | dev = alloc_netdev(sizeof(struct sixpack), "sp%d", sp_setup); |
606 | if (!dev) { | 608 | if (!dev) { |
@@ -914,9 +916,9 @@ static void decode_prio_command(struct sixpack *sp, unsigned char cmd) | |||
914 | } else { /* output watchdog char if idle */ | 916 | } else { /* output watchdog char if idle */ |
915 | if ((sp->status2 != 0) && (sp->duplex == 1)) { | 917 | if ((sp->status2 != 0) && (sp->duplex == 1)) { |
916 | sp->led_state = 0x70; | 918 | sp->led_state = 0x70; |
917 | sp->tty->driver->write(sp->tty, &sp->led_state, 1); | 919 | sp->tty->ops->write(sp->tty, &sp->led_state, 1); |
918 | sp->tx_enable = 1; | 920 | sp->tx_enable = 1; |
919 | actual = sp->tty->driver->write(sp->tty, sp->xbuff, sp->status2); | 921 | actual = sp->tty->ops->write(sp->tty, sp->xbuff, sp->status2); |
920 | sp->xleft -= actual; | 922 | sp->xleft -= actual; |
921 | sp->xhead += actual; | 923 | sp->xhead += actual; |
922 | sp->led_state = 0x60; | 924 | sp->led_state = 0x60; |
@@ -926,7 +928,7 @@ static void decode_prio_command(struct sixpack *sp, unsigned char cmd) | |||
926 | } | 928 | } |
927 | 929 | ||
928 | /* needed to trigger the TNC watchdog */ | 930 | /* needed to trigger the TNC watchdog */ |
929 | sp->tty->driver->write(sp->tty, &sp->led_state, 1); | 931 | sp->tty->ops->write(sp->tty, &sp->led_state, 1); |
930 | 932 | ||
931 | /* if the state byte has been received, the TNC is present, | 933 | /* if the state byte has been received, the TNC is present, |
932 | so the resync timer can be reset. */ | 934 | so the resync timer can be reset. */ |
@@ -956,12 +958,12 @@ static void decode_std_command(struct sixpack *sp, unsigned char cmd) | |||
956 | if ((sp->status & SIXP_RX_DCD_MASK) == | 958 | if ((sp->status & SIXP_RX_DCD_MASK) == |
957 | SIXP_RX_DCD_MASK) { | 959 | SIXP_RX_DCD_MASK) { |
958 | sp->led_state = 0x68; | 960 | sp->led_state = 0x68; |
959 | sp->tty->driver->write(sp->tty, &sp->led_state, 1); | 961 | sp->tty->ops->write(sp->tty, &sp->led_state, 1); |
960 | } | 962 | } |
961 | } else { | 963 | } else { |
962 | sp->led_state = 0x60; | 964 | sp->led_state = 0x60; |
963 | /* fill trailing bytes with zeroes */ | 965 | /* fill trailing bytes with zeroes */ |
964 | sp->tty->driver->write(sp->tty, &sp->led_state, 1); | 966 | sp->tty->ops->write(sp->tty, &sp->led_state, 1); |
965 | rest = sp->rx_count; | 967 | rest = sp->rx_count; |
966 | if (rest != 0) | 968 | if (rest != 0) |
967 | for (i = rest; i <= 3; i++) | 969 | for (i = rest; i <= 3; i++) |