diff options
Diffstat (limited to 'drivers/isdn')
-rw-r--r-- | drivers/isdn/capi/capi.c | 22 |
1 files changed, 9 insertions, 13 deletions
diff --git a/drivers/isdn/capi/capi.c b/drivers/isdn/capi/capi.c index 40b81b460e81..ee5837522f5a 100644 --- a/drivers/isdn/capi/capi.c +++ b/drivers/isdn/capi/capi.c | |||
@@ -516,25 +516,24 @@ static void handle_minor_recv(struct capiminor *mp) | |||
516 | } | 516 | } |
517 | } | 517 | } |
518 | 518 | ||
519 | static int handle_minor_send(struct capiminor *mp) | 519 | static void handle_minor_send(struct capiminor *mp) |
520 | { | 520 | { |
521 | struct tty_struct *tty; | 521 | struct tty_struct *tty; |
522 | struct sk_buff *skb; | 522 | struct sk_buff *skb; |
523 | u16 len; | 523 | u16 len; |
524 | int count = 0; | ||
525 | u16 errcode; | 524 | u16 errcode; |
526 | u16 datahandle; | 525 | u16 datahandle; |
527 | 526 | ||
528 | tty = tty_port_tty_get(&mp->port); | 527 | tty = tty_port_tty_get(&mp->port); |
529 | if (!tty) | 528 | if (!tty) |
530 | return 0; | 529 | return; |
531 | 530 | ||
532 | if (mp->ttyoutstop) { | 531 | if (mp->ttyoutstop) { |
533 | #if defined(_DEBUG_DATAFLOW) || defined(_DEBUG_TTYFUNCS) | 532 | #if defined(_DEBUG_DATAFLOW) || defined(_DEBUG_TTYFUNCS) |
534 | printk(KERN_DEBUG "capi: send: tty stopped\n"); | 533 | printk(KERN_DEBUG "capi: send: tty stopped\n"); |
535 | #endif | 534 | #endif |
536 | tty_kref_put(tty); | 535 | tty_kref_put(tty); |
537 | return 0; | 536 | return; |
538 | } | 537 | } |
539 | 538 | ||
540 | while (1) { | 539 | while (1) { |
@@ -570,12 +569,10 @@ static int handle_minor_send(struct capiminor *mp) | |||
570 | mp->outbytes += len; | 569 | mp->outbytes += len; |
571 | spin_unlock_bh(&mp->outlock); | 570 | spin_unlock_bh(&mp->outlock); |
572 | 571 | ||
573 | tty_kref_put(tty); | 572 | break; |
574 | return count; | ||
575 | } | 573 | } |
576 | errcode = capi20_put_message(mp->ap, skb); | 574 | errcode = capi20_put_message(mp->ap, skb); |
577 | if (errcode == CAPI_NOERROR) { | 575 | if (errcode == CAPI_NOERROR) { |
578 | count++; | ||
579 | #ifdef _DEBUG_DATAFLOW | 576 | #ifdef _DEBUG_DATAFLOW |
580 | printk(KERN_DEBUG "capi: DATA_B3_REQ %u len=%u\n", | 577 | printk(KERN_DEBUG "capi: DATA_B3_REQ %u len=%u\n", |
581 | datahandle, len); | 578 | datahandle, len); |
@@ -600,7 +597,6 @@ static int handle_minor_send(struct capiminor *mp) | |||
600 | kfree_skb(skb); | 597 | kfree_skb(skb); |
601 | } | 598 | } |
602 | tty_kref_put(tty); | 599 | tty_kref_put(tty); |
603 | return count; | ||
604 | } | 600 | } |
605 | 601 | ||
606 | #endif /* CONFIG_ISDN_CAPI_MIDDLEWARE */ | 602 | #endif /* CONFIG_ISDN_CAPI_MIDDLEWARE */ |
@@ -677,7 +673,7 @@ static void capi_recv_message(struct capi20_appl *ap, struct sk_buff *skb) | |||
677 | tty_wakeup(tty); | 673 | tty_wakeup(tty); |
678 | tty_kref_put(tty); | 674 | tty_kref_put(tty); |
679 | } | 675 | } |
680 | (void)handle_minor_send(mp); | 676 | handle_minor_send(mp); |
681 | 677 | ||
682 | } else { | 678 | } else { |
683 | /* ups, let capi application handle it :-) */ | 679 | /* ups, let capi application handle it :-) */ |
@@ -1114,7 +1110,7 @@ static int capinc_tty_write(struct tty_struct *tty, | |||
1114 | mp->outbytes += skb->len; | 1110 | mp->outbytes += skb->len; |
1115 | spin_unlock_bh(&mp->outlock); | 1111 | spin_unlock_bh(&mp->outlock); |
1116 | 1112 | ||
1117 | (void)handle_minor_send(mp); | 1113 | handle_minor_send(mp); |
1118 | 1114 | ||
1119 | return count; | 1115 | return count; |
1120 | } | 1116 | } |
@@ -1157,7 +1153,7 @@ unlock_out: | |||
1157 | spin_unlock_bh(&mp->outlock); | 1153 | spin_unlock_bh(&mp->outlock); |
1158 | 1154 | ||
1159 | if (invoke_send) | 1155 | if (invoke_send) |
1160 | (void)handle_minor_send(mp); | 1156 | handle_minor_send(mp); |
1161 | 1157 | ||
1162 | return ret; | 1158 | return ret; |
1163 | } | 1159 | } |
@@ -1179,7 +1175,7 @@ static void capinc_tty_flush_chars(struct tty_struct *tty) | |||
1179 | mp->outbytes += skb->len; | 1175 | mp->outbytes += skb->len; |
1180 | spin_unlock_bh(&mp->outlock); | 1176 | spin_unlock_bh(&mp->outlock); |
1181 | 1177 | ||
1182 | (void)handle_minor_send(mp); | 1178 | handle_minor_send(mp); |
1183 | } else | 1179 | } else |
1184 | spin_unlock_bh(&mp->outlock); | 1180 | spin_unlock_bh(&mp->outlock); |
1185 | 1181 | ||
@@ -1269,7 +1265,7 @@ static void capinc_tty_start(struct tty_struct *tty) | |||
1269 | printk(KERN_DEBUG "capinc_tty_start\n"); | 1265 | printk(KERN_DEBUG "capinc_tty_start\n"); |
1270 | #endif | 1266 | #endif |
1271 | mp->ttyoutstop = 0; | 1267 | mp->ttyoutstop = 0; |
1272 | (void)handle_minor_send(mp); | 1268 | handle_minor_send(mp); |
1273 | } | 1269 | } |
1274 | 1270 | ||
1275 | static void capinc_tty_hangup(struct tty_struct *tty) | 1271 | static void capinc_tty_hangup(struct tty_struct *tty) |