aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSarah Sharp <sarah.a.sharp@linux.intel.com>2009-12-09 18:59:06 -0500
committerGreg Kroah-Hartman <gregkh@suse.de>2010-03-02 17:53:10 -0500
commitb45b506911247008f694dcaf1d8220a4942ebc4f (patch)
tree63dbdca8d1e755d890aa8fb4f6be2a0bfcfd9bde
parenta1d78c16bd31a715785e21967ac6110b386a3c1f (diff)
USB: xhci: Refactor test for vendor-specific completion codes.
All commands that can be issued to the xHCI hardware can come back with vendor-specific "informational" completion codes. These are to be treated like a successful completion code. Refactor out the code to test for the range of these codes and print debugging messages. Signed-off-by: Sarah Sharp <sarah.a.sharp@linux.intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-rw-r--r--drivers/usb/host/xhci-ring.c22
-rw-r--r--drivers/usb/host/xhci.h1
2 files changed, 16 insertions, 7 deletions
diff --git a/drivers/usb/host/xhci-ring.c b/drivers/usb/host/xhci-ring.c
index ee7bc7ecbc59..f43e073dee96 100644
--- a/drivers/usb/host/xhci-ring.c
+++ b/drivers/usb/host/xhci-ring.c
@@ -1080,6 +1080,20 @@ static int xhci_requires_manual_halt_cleanup(struct xhci_hcd *xhci,
1080 return 0; 1080 return 0;
1081} 1081}
1082 1082
1083int xhci_is_vendor_info_code(struct xhci_hcd *xhci, unsigned int trb_comp_code)
1084{
1085 if (trb_comp_code >= 224 && trb_comp_code <= 255) {
1086 /* Vendor defined "informational" completion code,
1087 * treat as not-an-error.
1088 */
1089 xhci_dbg(xhci, "Vendor defined info completion code %u\n",
1090 trb_comp_code);
1091 xhci_dbg(xhci, "Treating code as success.\n");
1092 return 1;
1093 }
1094 return 0;
1095}
1096
1083/* 1097/*
1084 * If this function returns an error condition, it means it got a Transfer 1098 * If this function returns an error condition, it means it got a Transfer
1085 * event with a corrupted Slot ID, Endpoint ID, or TRB DMA address. 1099 * event with a corrupted Slot ID, Endpoint ID, or TRB DMA address.
@@ -1196,13 +1210,7 @@ static int handle_tx_event(struct xhci_hcd *xhci,
1196 status = -ENOSR; 1210 status = -ENOSR;
1197 break; 1211 break;
1198 default: 1212 default:
1199 if (trb_comp_code >= 224 && trb_comp_code <= 255) { 1213 if (xhci_is_vendor_info_code(xhci, trb_comp_code)) {
1200 /* Vendor defined "informational" completion code,
1201 * treat as not-an-error.
1202 */
1203 xhci_dbg(xhci, "Vendor defined info completion code %u\n",
1204 trb_comp_code);
1205 xhci_dbg(xhci, "Treating code as success.\n");
1206 status = 0; 1214 status = 0;
1207 break; 1215 break;
1208 } 1216 }
diff --git a/drivers/usb/host/xhci.h b/drivers/usb/host/xhci.h
index 902be9647c60..20122ec75d94 100644
--- a/drivers/usb/host/xhci.h
+++ b/drivers/usb/host/xhci.h
@@ -1276,6 +1276,7 @@ dma_addr_t xhci_trb_virt_to_dma(struct xhci_segment *seg, union xhci_trb *trb);
1276struct xhci_segment *trb_in_td(struct xhci_segment *start_seg, 1276struct xhci_segment *trb_in_td(struct xhci_segment *start_seg,
1277 union xhci_trb *start_trb, union xhci_trb *end_trb, 1277 union xhci_trb *start_trb, union xhci_trb *end_trb,
1278 dma_addr_t suspect_dma); 1278 dma_addr_t suspect_dma);
1279int xhci_is_vendor_info_code(struct xhci_hcd *xhci, unsigned int trb_comp_code);
1279void xhci_ring_cmd_db(struct xhci_hcd *xhci); 1280void xhci_ring_cmd_db(struct xhci_hcd *xhci);
1280void *xhci_setup_one_noop(struct xhci_hcd *xhci); 1281void *xhci_setup_one_noop(struct xhci_hcd *xhci);
1281void xhci_handle_event(struct xhci_hcd *xhci); 1282void xhci_handle_event(struct xhci_hcd *xhci);