提交 7ea0a2bc 编写于 作者: A Alan Stern 提交者: Greg Kroah-Hartman

USB: uhci: don't use pseudo negative values

The code in uhci-q.c doesn't have to use pseudo-negative values.  I did
it that way because it was easy and because it would give the expected
output during debugging.  But it doesn't have to work that way.  Here's
another approach.
Signed-off-by: NAlan Stern <stern@rowland.harvard.edu>
Cc: Roel Kluin <roel.kluin@gmail.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@suse.de>
上级 66760169
...@@ -118,7 +118,9 @@ static int uhci_show_urbp(struct urb_priv *urbp, char *buf, int len, int space) ...@@ -118,7 +118,9 @@ static int uhci_show_urbp(struct urb_priv *urbp, char *buf, int len, int space)
} }
out += sprintf(out, "%s%s", ptype, (urbp->fsbr ? " FSBR" : "")); out += sprintf(out, "%s%s", ptype, (urbp->fsbr ? " FSBR" : ""));
out += sprintf(out, " Actlen=%d", urbp->urb->actual_length); out += sprintf(out, " Actlen=%d%s", urbp->urb->actual_length,
(urbp->qh->type == USB_ENDPOINT_XFER_CONTROL ?
"-8" : ""));
if (urbp->urb->unlinked) if (urbp->urb->unlinked)
out += sprintf(out, " Unlinked=%d", urbp->urb->unlinked); out += sprintf(out, " Unlinked=%d", urbp->urb->unlinked);
......
...@@ -899,8 +899,6 @@ static int uhci_submit_control(struct uhci_hcd *uhci, struct urb *urb, ...@@ -899,8 +899,6 @@ static int uhci_submit_control(struct uhci_hcd *uhci, struct urb *urb,
} }
if (qh->state != QH_STATE_ACTIVE) if (qh->state != QH_STATE_ACTIVE)
qh->skel = skel; qh->skel = skel;
urb->actual_length = -8; /* Account for the SETUP packet */
return 0; return 0;
nomem: nomem:
...@@ -1494,11 +1492,10 @@ __acquires(uhci->lock) ...@@ -1494,11 +1492,10 @@ __acquires(uhci->lock)
if (qh->type == USB_ENDPOINT_XFER_CONTROL) { if (qh->type == USB_ENDPOINT_XFER_CONTROL) {
/* urb->actual_length < 0 means the setup transaction didn't /* Subtract off the length of the SETUP packet from
* complete successfully. Either it failed or the URB was * urb->actual_length.
* unlinked first. Regardless, don't confuse people with a */
* negative length. */ urb->actual_length -= min_t(u32, 8, urb->actual_length);
urb->actual_length = max(urb->actual_length, 0);
} }
/* When giving back the first URB in an Isochronous queue, /* When giving back the first URB in an Isochronous queue,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册