diff options
Diffstat (limited to 'drivers/isdn/gigaset/bas-gigaset.c')
-rw-r--r-- | drivers/isdn/gigaset/bas-gigaset.c | 84 |
1 files changed, 48 insertions, 36 deletions
diff --git a/drivers/isdn/gigaset/bas-gigaset.c b/drivers/isdn/gigaset/bas-gigaset.c index af7648274b38..0302c40a27ea 100644 --- a/drivers/isdn/gigaset/bas-gigaset.c +++ b/drivers/isdn/gigaset/bas-gigaset.c | |||
@@ -248,12 +248,12 @@ static inline void dump_urb(enum debuglevel level, const char *tag, | |||
248 | if (urb) { | 248 | if (urb) { |
249 | gig_dbg(level, | 249 | gig_dbg(level, |
250 | " dev=0x%08lx, pipe=%s:EP%d/DV%d:%s, " | 250 | " dev=0x%08lx, pipe=%s:EP%d/DV%d:%s, " |
251 | "status=%d, hcpriv=0x%08lx, transfer_flags=0x%x,", | 251 | "hcpriv=0x%08lx, transfer_flags=0x%x,", |
252 | (unsigned long) urb->dev, | 252 | (unsigned long) urb->dev, |
253 | usb_pipetype_str(urb->pipe), | 253 | usb_pipetype_str(urb->pipe), |
254 | usb_pipeendpoint(urb->pipe), usb_pipedevice(urb->pipe), | 254 | usb_pipeendpoint(urb->pipe), usb_pipedevice(urb->pipe), |
255 | usb_pipein(urb->pipe) ? "in" : "out", | 255 | usb_pipein(urb->pipe) ? "in" : "out", |
256 | urb->status, (unsigned long) urb->hcpriv, | 256 | (unsigned long) urb->hcpriv, |
257 | urb->transfer_flags); | 257 | urb->transfer_flags); |
258 | gig_dbg(level, | 258 | gig_dbg(level, |
259 | " transfer_buffer=0x%08lx[%d], actual_length=%d, " | 259 | " transfer_buffer=0x%08lx[%d], actual_length=%d, " |
@@ -459,6 +459,7 @@ static void read_ctrl_callback(struct urb *urb) | |||
459 | struct inbuf_t *inbuf = urb->context; | 459 | struct inbuf_t *inbuf = urb->context; |
460 | struct cardstate *cs = inbuf->cs; | 460 | struct cardstate *cs = inbuf->cs; |
461 | struct bas_cardstate *ucs = cs->hw.bas; | 461 | struct bas_cardstate *ucs = cs->hw.bas; |
462 | int status = urb->status; | ||
462 | int have_data = 0; | 463 | int have_data = 0; |
463 | unsigned numbytes; | 464 | unsigned numbytes; |
464 | int rc; | 465 | int rc; |
@@ -472,7 +473,7 @@ static void read_ctrl_callback(struct urb *urb) | |||
472 | 473 | ||
473 | del_timer(&ucs->timer_cmd_in); | 474 | del_timer(&ucs->timer_cmd_in); |
474 | 475 | ||
475 | switch (urb->status) { | 476 | switch (status) { |
476 | case 0: /* normal completion */ | 477 | case 0: /* normal completion */ |
477 | numbytes = urb->actual_length; | 478 | numbytes = urb->actual_length; |
478 | if (unlikely(numbytes != ucs->rcvbuf_size)) { | 479 | if (unlikely(numbytes != ucs->rcvbuf_size)) { |
@@ -506,12 +507,12 @@ static void read_ctrl_callback(struct urb *urb) | |||
506 | case -ESHUTDOWN: /* device shut down */ | 507 | case -ESHUTDOWN: /* device shut down */ |
507 | /* no action necessary */ | 508 | /* no action necessary */ |
508 | gig_dbg(DEBUG_USBREQ, "%s: %s", | 509 | gig_dbg(DEBUG_USBREQ, "%s: %s", |
509 | __func__, get_usb_statmsg(urb->status)); | 510 | __func__, get_usb_statmsg(status)); |
510 | break; | 511 | break; |
511 | 512 | ||
512 | default: /* severe trouble */ | 513 | default: /* severe trouble */ |
513 | dev_warn(cs->dev, "control read: %s\n", | 514 | dev_warn(cs->dev, "control read: %s\n", |
514 | get_usb_statmsg(urb->status)); | 515 | get_usb_statmsg(status)); |
515 | if (ucs->retry_cmd_in++ < BAS_RETRY) { | 516 | if (ucs->retry_cmd_in++ < BAS_RETRY) { |
516 | dev_notice(cs->dev, "control read: retry %d\n", | 517 | dev_notice(cs->dev, "control read: retry %d\n", |
517 | ucs->retry_cmd_in); | 518 | ucs->retry_cmd_in); |
@@ -601,12 +602,13 @@ static void read_int_callback(struct urb *urb) | |||
601 | struct cardstate *cs = urb->context; | 602 | struct cardstate *cs = urb->context; |
602 | struct bas_cardstate *ucs = cs->hw.bas; | 603 | struct bas_cardstate *ucs = cs->hw.bas; |
603 | struct bc_state *bcs; | 604 | struct bc_state *bcs; |
605 | int status = urb->status; | ||
604 | unsigned long flags; | 606 | unsigned long flags; |
605 | int rc; | 607 | int rc; |
606 | unsigned l; | 608 | unsigned l; |
607 | int channel; | 609 | int channel; |
608 | 610 | ||
609 | switch (urb->status) { | 611 | switch (status) { |
610 | case 0: /* success */ | 612 | case 0: /* success */ |
611 | break; | 613 | break; |
612 | case -ENOENT: /* cancelled */ | 614 | case -ENOENT: /* cancelled */ |
@@ -614,7 +616,7 @@ static void read_int_callback(struct urb *urb) | |||
614 | case -EINPROGRESS: /* pending */ | 616 | case -EINPROGRESS: /* pending */ |
615 | /* ignore silently */ | 617 | /* ignore silently */ |
616 | gig_dbg(DEBUG_USBREQ, "%s: %s", | 618 | gig_dbg(DEBUG_USBREQ, "%s: %s", |
617 | __func__, get_usb_statmsg(urb->status)); | 619 | __func__, get_usb_statmsg(status)); |
618 | return; | 620 | return; |
619 | case -ENODEV: /* device removed */ | 621 | case -ENODEV: /* device removed */ |
620 | case -ESHUTDOWN: /* device shut down */ | 622 | case -ESHUTDOWN: /* device shut down */ |
@@ -623,7 +625,7 @@ static void read_int_callback(struct urb *urb) | |||
623 | return; | 625 | return; |
624 | default: /* severe trouble */ | 626 | default: /* severe trouble */ |
625 | dev_warn(cs->dev, "interrupt read: %s\n", | 627 | dev_warn(cs->dev, "interrupt read: %s\n", |
626 | get_usb_statmsg(urb->status)); | 628 | get_usb_statmsg(status)); |
627 | //FIXME corrective action? resubmission always ok? | 629 | //FIXME corrective action? resubmission always ok? |
628 | goto resubmit; | 630 | goto resubmit; |
629 | } | 631 | } |
@@ -766,17 +768,18 @@ static void read_iso_callback(struct urb *urb) | |||
766 | { | 768 | { |
767 | struct bc_state *bcs; | 769 | struct bc_state *bcs; |
768 | struct bas_bc_state *ubc; | 770 | struct bas_bc_state *ubc; |
771 | int status = urb->status; | ||
769 | unsigned long flags; | 772 | unsigned long flags; |
770 | int i, rc; | 773 | int i, rc; |
771 | 774 | ||
772 | /* status codes not worth bothering the tasklet with */ | 775 | /* status codes not worth bothering the tasklet with */ |
773 | if (unlikely(urb->status == -ENOENT || | 776 | if (unlikely(status == -ENOENT || |
774 | urb->status == -ECONNRESET || | 777 | status == -ECONNRESET || |
775 | urb->status == -EINPROGRESS || | 778 | status == -EINPROGRESS || |
776 | urb->status == -ENODEV || | 779 | status == -ENODEV || |
777 | urb->status == -ESHUTDOWN)) { | 780 | status == -ESHUTDOWN)) { |
778 | gig_dbg(DEBUG_ISO, "%s: %s", | 781 | gig_dbg(DEBUG_ISO, "%s: %s", |
779 | __func__, get_usb_statmsg(urb->status)); | 782 | __func__, get_usb_statmsg(status)); |
780 | return; | 783 | return; |
781 | } | 784 | } |
782 | 785 | ||
@@ -787,10 +790,11 @@ static void read_iso_callback(struct urb *urb) | |||
787 | if (likely(ubc->isoindone == NULL)) { | 790 | if (likely(ubc->isoindone == NULL)) { |
788 | /* pass URB to tasklet */ | 791 | /* pass URB to tasklet */ |
789 | ubc->isoindone = urb; | 792 | ubc->isoindone = urb; |
793 | ubc->isoinstatus = status; | ||
790 | tasklet_schedule(&ubc->rcvd_tasklet); | 794 | tasklet_schedule(&ubc->rcvd_tasklet); |
791 | } else { | 795 | } else { |
792 | /* tasklet still busy, drop data and resubmit URB */ | 796 | /* tasklet still busy, drop data and resubmit URB */ |
793 | ubc->loststatus = urb->status; | 797 | ubc->loststatus = status; |
794 | for (i = 0; i < BAS_NUMFRAMES; i++) { | 798 | for (i = 0; i < BAS_NUMFRAMES; i++) { |
795 | ubc->isoinlost += urb->iso_frame_desc[i].actual_length; | 799 | ubc->isoinlost += urb->iso_frame_desc[i].actual_length; |
796 | if (unlikely(urb->iso_frame_desc[i].status != 0 && | 800 | if (unlikely(urb->iso_frame_desc[i].status != 0 && |
@@ -831,22 +835,24 @@ static void write_iso_callback(struct urb *urb) | |||
831 | { | 835 | { |
832 | struct isow_urbctx_t *ucx; | 836 | struct isow_urbctx_t *ucx; |
833 | struct bas_bc_state *ubc; | 837 | struct bas_bc_state *ubc; |
838 | int status = urb->status; | ||
834 | unsigned long flags; | 839 | unsigned long flags; |
835 | 840 | ||
836 | /* status codes not worth bothering the tasklet with */ | 841 | /* status codes not worth bothering the tasklet with */ |
837 | if (unlikely(urb->status == -ENOENT || | 842 | if (unlikely(status == -ENOENT || |
838 | urb->status == -ECONNRESET || | 843 | status == -ECONNRESET || |
839 | urb->status == -EINPROGRESS || | 844 | status == -EINPROGRESS || |
840 | urb->status == -ENODEV || | 845 | status == -ENODEV || |
841 | urb->status == -ESHUTDOWN)) { | 846 | status == -ESHUTDOWN)) { |
842 | gig_dbg(DEBUG_ISO, "%s: %s", | 847 | gig_dbg(DEBUG_ISO, "%s: %s", |
843 | __func__, get_usb_statmsg(urb->status)); | 848 | __func__, get_usb_statmsg(status)); |
844 | return; | 849 | return; |
845 | } | 850 | } |
846 | 851 | ||
847 | /* pass URB context to tasklet */ | 852 | /* pass URB context to tasklet */ |
848 | ucx = urb->context; | 853 | ucx = urb->context; |
849 | ubc = ucx->bcs->hw.bas; | 854 | ubc = ucx->bcs->hw.bas; |
855 | ucx->status = status; | ||
850 | 856 | ||
851 | spin_lock_irqsave(&ubc->isooutlock, flags); | 857 | spin_lock_irqsave(&ubc->isooutlock, flags); |
852 | ubc->isooutovfl = ubc->isooutdone; | 858 | ubc->isooutovfl = ubc->isooutdone; |
@@ -1070,6 +1076,7 @@ static void write_iso_tasklet(unsigned long data) | |||
1070 | struct cardstate *cs = bcs->cs; | 1076 | struct cardstate *cs = bcs->cs; |
1071 | struct isow_urbctx_t *done, *next, *ovfl; | 1077 | struct isow_urbctx_t *done, *next, *ovfl; |
1072 | struct urb *urb; | 1078 | struct urb *urb; |
1079 | int status; | ||
1073 | struct usb_iso_packet_descriptor *ifd; | 1080 | struct usb_iso_packet_descriptor *ifd; |
1074 | int offset; | 1081 | int offset; |
1075 | unsigned long flags; | 1082 | unsigned long flags; |
@@ -1126,7 +1133,8 @@ static void write_iso_tasklet(unsigned long data) | |||
1126 | 1133 | ||
1127 | /* process completed URB */ | 1134 | /* process completed URB */ |
1128 | urb = done->urb; | 1135 | urb = done->urb; |
1129 | switch (urb->status) { | 1136 | status = done->status; |
1137 | switch (status) { | ||
1130 | case -EXDEV: /* partial completion */ | 1138 | case -EXDEV: /* partial completion */ |
1131 | gig_dbg(DEBUG_ISO, "%s: URB partially completed", | 1139 | gig_dbg(DEBUG_ISO, "%s: URB partially completed", |
1132 | __func__); | 1140 | __func__); |
@@ -1179,7 +1187,7 @@ static void write_iso_tasklet(unsigned long data) | |||
1179 | break; | 1187 | break; |
1180 | default: /* severe trouble */ | 1188 | default: /* severe trouble */ |
1181 | dev_warn(cs->dev, "isochronous write: %s\n", | 1189 | dev_warn(cs->dev, "isochronous write: %s\n", |
1182 | get_usb_statmsg(urb->status)); | 1190 | get_usb_statmsg(status)); |
1183 | } | 1191 | } |
1184 | 1192 | ||
1185 | /* mark the write buffer area covered by this URB as free */ | 1193 | /* mark the write buffer area covered by this URB as free */ |
@@ -1233,6 +1241,7 @@ static void read_iso_tasklet(unsigned long data) | |||
1233 | struct bas_bc_state *ubc = bcs->hw.bas; | 1241 | struct bas_bc_state *ubc = bcs->hw.bas; |
1234 | struct cardstate *cs = bcs->cs; | 1242 | struct cardstate *cs = bcs->cs; |
1235 | struct urb *urb; | 1243 | struct urb *urb; |
1244 | int status; | ||
1236 | char *rcvbuf; | 1245 | char *rcvbuf; |
1237 | unsigned long flags; | 1246 | unsigned long flags; |
1238 | int totleft, numbytes, offset, frame, rc; | 1247 | int totleft, numbytes, offset, frame, rc; |
@@ -1245,6 +1254,7 @@ static void read_iso_tasklet(unsigned long data) | |||
1245 | spin_unlock_irqrestore(&ubc->isoinlock, flags); | 1254 | spin_unlock_irqrestore(&ubc->isoinlock, flags); |
1246 | return; | 1255 | return; |
1247 | } | 1256 | } |
1257 | status = ubc->isoinstatus; | ||
1248 | ubc->isoindone = NULL; | 1258 | ubc->isoindone = NULL; |
1249 | if (unlikely(ubc->loststatus != -EINPROGRESS)) { | 1259 | if (unlikely(ubc->loststatus != -EINPROGRESS)) { |
1250 | dev_warn(cs->dev, | 1260 | dev_warn(cs->dev, |
@@ -1260,11 +1270,11 @@ static void read_iso_tasklet(unsigned long data) | |||
1260 | gig_dbg(DEBUG_ISO, | 1270 | gig_dbg(DEBUG_ISO, |
1261 | "%s: channel not running, " | 1271 | "%s: channel not running, " |
1262 | "dropped URB with status: %s", | 1272 | "dropped URB with status: %s", |
1263 | __func__, get_usb_statmsg(urb->status)); | 1273 | __func__, get_usb_statmsg(status)); |
1264 | return; | 1274 | return; |
1265 | } | 1275 | } |
1266 | 1276 | ||
1267 | switch (urb->status) { | 1277 | switch (status) { |
1268 | case 0: /* normal completion */ | 1278 | case 0: /* normal completion */ |
1269 | break; | 1279 | break; |
1270 | case -EXDEV: /* inspect individual frames | 1280 | case -EXDEV: /* inspect individual frames |
@@ -1276,7 +1286,7 @@ static void read_iso_tasklet(unsigned long data) | |||
1276 | case -ECONNRESET: | 1286 | case -ECONNRESET: |
1277 | case -EINPROGRESS: | 1287 | case -EINPROGRESS: |
1278 | gig_dbg(DEBUG_ISO, "%s: %s", | 1288 | gig_dbg(DEBUG_ISO, "%s: %s", |
1279 | __func__, get_usb_statmsg(urb->status)); | 1289 | __func__, get_usb_statmsg(status)); |
1280 | continue; /* -> skip */ | 1290 | continue; /* -> skip */ |
1281 | case -EPIPE: | 1291 | case -EPIPE: |
1282 | dev_err(cs->dev, "isochronous read stalled\n"); | 1292 | dev_err(cs->dev, "isochronous read stalled\n"); |
@@ -1284,7 +1294,7 @@ static void read_iso_tasklet(unsigned long data) | |||
1284 | continue; /* -> skip */ | 1294 | continue; /* -> skip */ |
1285 | default: /* severe trouble */ | 1295 | default: /* severe trouble */ |
1286 | dev_warn(cs->dev, "isochronous read: %s\n", | 1296 | dev_warn(cs->dev, "isochronous read: %s\n", |
1287 | get_usb_statmsg(urb->status)); | 1297 | get_usb_statmsg(status)); |
1288 | goto error; | 1298 | goto error; |
1289 | } | 1299 | } |
1290 | 1300 | ||
@@ -1418,11 +1428,12 @@ static void req_timeout(unsigned long data) | |||
1418 | static void write_ctrl_callback(struct urb *urb) | 1428 | static void write_ctrl_callback(struct urb *urb) |
1419 | { | 1429 | { |
1420 | struct bas_cardstate *ucs = urb->context; | 1430 | struct bas_cardstate *ucs = urb->context; |
1431 | int status = urb->status; | ||
1421 | int rc; | 1432 | int rc; |
1422 | unsigned long flags; | 1433 | unsigned long flags; |
1423 | 1434 | ||
1424 | /* check status */ | 1435 | /* check status */ |
1425 | switch (urb->status) { | 1436 | switch (status) { |
1426 | case 0: /* normal completion */ | 1437 | case 0: /* normal completion */ |
1427 | spin_lock_irqsave(&ucs->lock, flags); | 1438 | spin_lock_irqsave(&ucs->lock, flags); |
1428 | switch (ucs->pending) { | 1439 | switch (ucs->pending) { |
@@ -1441,7 +1452,7 @@ static void write_ctrl_callback(struct urb *urb) | |||
1441 | case -ESHUTDOWN: /* device shut down */ | 1452 | case -ESHUTDOWN: /* device shut down */ |
1442 | /* ignore silently */ | 1453 | /* ignore silently */ |
1443 | gig_dbg(DEBUG_USBREQ, "%s: %s", | 1454 | gig_dbg(DEBUG_USBREQ, "%s: %s", |
1444 | __func__, get_usb_statmsg(urb->status)); | 1455 | __func__, get_usb_statmsg(status)); |
1445 | break; | 1456 | break; |
1446 | 1457 | ||
1447 | default: /* any failure */ | 1458 | default: /* any failure */ |
@@ -1449,12 +1460,12 @@ static void write_ctrl_callback(struct urb *urb) | |||
1449 | dev_err(&ucs->interface->dev, | 1460 | dev_err(&ucs->interface->dev, |
1450 | "control request 0x%02x failed: %s\n", | 1461 | "control request 0x%02x failed: %s\n", |
1451 | ucs->dr_ctrl.bRequest, | 1462 | ucs->dr_ctrl.bRequest, |
1452 | get_usb_statmsg(urb->status)); | 1463 | get_usb_statmsg(status)); |
1453 | break; /* give up */ | 1464 | break; /* give up */ |
1454 | } | 1465 | } |
1455 | dev_notice(&ucs->interface->dev, | 1466 | dev_notice(&ucs->interface->dev, |
1456 | "control request 0x%02x: %s, retry %d\n", | 1467 | "control request 0x%02x: %s, retry %d\n", |
1457 | ucs->dr_ctrl.bRequest, get_usb_statmsg(urb->status), | 1468 | ucs->dr_ctrl.bRequest, get_usb_statmsg(status), |
1458 | ucs->retry_ctrl); | 1469 | ucs->retry_ctrl); |
1459 | /* urb->dev is clobbered by USB subsystem */ | 1470 | /* urb->dev is clobbered by USB subsystem */ |
1460 | urb->dev = ucs->udev; | 1471 | urb->dev = ucs->udev; |
@@ -1665,12 +1676,13 @@ static void write_command_callback(struct urb *urb) | |||
1665 | { | 1676 | { |
1666 | struct cardstate *cs = urb->context; | 1677 | struct cardstate *cs = urb->context; |
1667 | struct bas_cardstate *ucs = cs->hw.bas; | 1678 | struct bas_cardstate *ucs = cs->hw.bas; |
1679 | int status = urb->status; | ||
1668 | unsigned long flags; | 1680 | unsigned long flags; |
1669 | 1681 | ||
1670 | update_basstate(ucs, 0, BS_ATWRPEND); | 1682 | update_basstate(ucs, 0, BS_ATWRPEND); |
1671 | 1683 | ||
1672 | /* check status */ | 1684 | /* check status */ |
1673 | switch (urb->status) { | 1685 | switch (status) { |
1674 | case 0: /* normal completion */ | 1686 | case 0: /* normal completion */ |
1675 | break; | 1687 | break; |
1676 | case -ENOENT: /* cancelled */ | 1688 | case -ENOENT: /* cancelled */ |
@@ -1680,14 +1692,14 @@ static void write_command_callback(struct urb *urb) | |||
1680 | case -ESHUTDOWN: /* device shut down */ | 1692 | case -ESHUTDOWN: /* device shut down */ |
1681 | /* ignore silently */ | 1693 | /* ignore silently */ |
1682 | gig_dbg(DEBUG_USBREQ, "%s: %s", | 1694 | gig_dbg(DEBUG_USBREQ, "%s: %s", |
1683 | __func__, get_usb_statmsg(urb->status)); | 1695 | __func__, get_usb_statmsg(status)); |
1684 | return; | 1696 | return; |
1685 | default: /* any failure */ | 1697 | default: /* any failure */ |
1686 | if (++ucs->retry_cmd_out > BAS_RETRY) { | 1698 | if (++ucs->retry_cmd_out > BAS_RETRY) { |
1687 | dev_warn(cs->dev, | 1699 | dev_warn(cs->dev, |
1688 | "command write: %s, " | 1700 | "command write: %s, " |
1689 | "giving up after %d retries\n", | 1701 | "giving up after %d retries\n", |
1690 | get_usb_statmsg(urb->status), | 1702 | get_usb_statmsg(status), |
1691 | ucs->retry_cmd_out); | 1703 | ucs->retry_cmd_out); |
1692 | break; | 1704 | break; |
1693 | } | 1705 | } |
@@ -1695,11 +1707,11 @@ static void write_command_callback(struct urb *urb) | |||
1695 | dev_warn(cs->dev, | 1707 | dev_warn(cs->dev, |
1696 | "command write: %s, " | 1708 | "command write: %s, " |
1697 | "cannot retry - cmdbuf gone\n", | 1709 | "cannot retry - cmdbuf gone\n", |
1698 | get_usb_statmsg(urb->status)); | 1710 | get_usb_statmsg(status)); |
1699 | break; | 1711 | break; |
1700 | } | 1712 | } |
1701 | dev_notice(cs->dev, "command write: %s, retry %d\n", | 1713 | dev_notice(cs->dev, "command write: %s, retry %d\n", |
1702 | get_usb_statmsg(urb->status), ucs->retry_cmd_out); | 1714 | get_usb_statmsg(status), ucs->retry_cmd_out); |
1703 | if (atwrite_submit(cs, cs->cmdbuf->buf, cs->cmdbuf->len) >= 0) | 1715 | if (atwrite_submit(cs, cs->cmdbuf->buf, cs->cmdbuf->len) >= 0) |
1704 | /* resubmitted - bypass regular exit block */ | 1716 | /* resubmitted - bypass regular exit block */ |
1705 | return; | 1717 | return; |