aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorSarah Sharp <sarah.a.sharp@linux.intel.com>2009-08-27 17:35:53 -0400
committerGreg Kroah-Hartman <gregkh@suse.de>2009-09-23 09:46:17 -0400
commit66d1eebce5cca916e0b08d961690bb01c64751ef (patch)
tree333a0b1e99541b9219bf69fe1a1f3a2f6489ea57 /drivers
parentac9d8fe7c6a8041cca5a0738915d2c4e21381421 (diff)
USB: xhci: Make TRB completion code comparison readable.
Use trb_comp_code instead of getting the completion code from the transfer event every time. Signed-off-by: Sarah Sharp <sarah.a.sharp@linux.intel.com> Cc: stable <stable@kernel.org> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/usb/host/xhci-ring.c16
1 files changed, 9 insertions, 7 deletions
diff --git a/drivers/usb/host/xhci-ring.c b/drivers/usb/host/xhci-ring.c
index 35374ddc31c1..e876fd372dd1 100644
--- a/drivers/usb/host/xhci-ring.c
+++ b/drivers/usb/host/xhci-ring.c
@@ -874,6 +874,7 @@ static int handle_tx_event(struct xhci_hcd *xhci,
874 struct urb *urb = 0; 874 struct urb *urb = 0;
875 int status = -EINPROGRESS; 875 int status = -EINPROGRESS;
876 struct xhci_ep_ctx *ep_ctx; 876 struct xhci_ep_ctx *ep_ctx;
877 u32 trb_comp_code;
877 878
878 xhci_dbg(xhci, "In %s\n", __func__); 879 xhci_dbg(xhci, "In %s\n", __func__);
879 slot_id = TRB_TO_SLOT_ID(event->flags); 880 slot_id = TRB_TO_SLOT_ID(event->flags);
@@ -931,7 +932,8 @@ static int handle_tx_event(struct xhci_hcd *xhci,
931 (unsigned int) event->flags); 932 (unsigned int) event->flags);
932 933
933 /* Look for common error cases */ 934 /* Look for common error cases */
934 switch (GET_COMP_CODE(event->transfer_len)) { 935 trb_comp_code = GET_COMP_CODE(event->transfer_len);
936 switch (trb_comp_code) {
935 /* Skip codes that require special handling depending on 937 /* Skip codes that require special handling depending on
936 * transfer type 938 * transfer type
937 */ 939 */
@@ -974,7 +976,7 @@ static int handle_tx_event(struct xhci_hcd *xhci,
974 /* Was this a control transfer? */ 976 /* Was this a control transfer? */
975 if (usb_endpoint_xfer_control(&td->urb->ep->desc)) { 977 if (usb_endpoint_xfer_control(&td->urb->ep->desc)) {
976 xhci_debug_trb(xhci, xhci->event_ring->dequeue); 978 xhci_debug_trb(xhci, xhci->event_ring->dequeue);
977 switch (GET_COMP_CODE(event->transfer_len)) { 979 switch (trb_comp_code) {
978 case COMP_SUCCESS: 980 case COMP_SUCCESS:
979 if (event_trb == ep_ring->dequeue) { 981 if (event_trb == ep_ring->dequeue) {
980 xhci_warn(xhci, "WARN: Success on ctrl setup TRB without IOC set??\n"); 982 xhci_warn(xhci, "WARN: Success on ctrl setup TRB without IOC set??\n");
@@ -1031,7 +1033,7 @@ static int handle_tx_event(struct xhci_hcd *xhci,
1031 } 1033 }
1032 } else { 1034 } else {
1033 /* Maybe the event was for the data stage? */ 1035 /* Maybe the event was for the data stage? */
1034 if (GET_COMP_CODE(event->transfer_len) != COMP_STOP_INVAL) { 1036 if (trb_comp_code != COMP_STOP_INVAL) {
1035 /* We didn't stop on a link TRB in the middle */ 1037 /* We didn't stop on a link TRB in the middle */
1036 td->urb->actual_length = 1038 td->urb->actual_length =
1037 td->urb->transfer_buffer_length - 1039 td->urb->transfer_buffer_length -
@@ -1043,7 +1045,7 @@ static int handle_tx_event(struct xhci_hcd *xhci,
1043 } 1045 }
1044 } 1046 }
1045 } else { 1047 } else {
1046 switch (GET_COMP_CODE(event->transfer_len)) { 1048 switch (trb_comp_code) {
1047 case COMP_SUCCESS: 1049 case COMP_SUCCESS:
1048 /* Double check that the HW transferred everything. */ 1050 /* Double check that the HW transferred everything. */
1049 if (event_trb != td->last_trb) { 1051 if (event_trb != td->last_trb) {
@@ -1120,14 +1122,14 @@ static int handle_tx_event(struct xhci_hcd *xhci,
1120 /* If the ring didn't stop on a Link or No-op TRB, add 1122 /* If the ring didn't stop on a Link or No-op TRB, add
1121 * in the actual bytes transferred from the Normal TRB 1123 * in the actual bytes transferred from the Normal TRB
1122 */ 1124 */
1123 if (GET_COMP_CODE(event->transfer_len) != COMP_STOP_INVAL) 1125 if (trb_comp_code != COMP_STOP_INVAL)
1124 td->urb->actual_length += 1126 td->urb->actual_length +=
1125 TRB_LEN(cur_trb->generic.field[2]) - 1127 TRB_LEN(cur_trb->generic.field[2]) -
1126 TRB_LEN(event->transfer_len); 1128 TRB_LEN(event->transfer_len);
1127 } 1129 }
1128 } 1130 }
1129 if (GET_COMP_CODE(event->transfer_len) == COMP_STOP_INVAL || 1131 if (trb_comp_code == COMP_STOP_INVAL ||
1130 GET_COMP_CODE(event->transfer_len) == COMP_STOP) { 1132 trb_comp_code == COMP_STOP) {
1131 /* The Endpoint Stop Command completion will take care of any 1133 /* The Endpoint Stop Command completion will take care of any
1132 * stopped TDs. A stopped TD may be restarted, so don't update 1134 * stopped TDs. A stopped TD may be restarted, so don't update
1133 * the ring dequeue pointer or take this TD off any lists yet. 1135 * the ring dequeue pointer or take this TD off any lists yet.