From: Stefan Bruens <stefan.bruens@rwth-aachen.de>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH 2/6] usb: dwc2: Handle NAK during CONTROL DATA and STATUS stage
Date: Thu, 17 Dec 2015 04:09:23 +0100 [thread overview]
Message-ID: <1792651.fb6GzQulBA@pebbles.site> (raw)
In-Reply-To: <5670D56E.5080108@wwwdotorg.org>
On Tuesday 15 December 2015 20:07:26 Stephen Warren wrote:
> On 12/12/2015 09:17 PM, Stefan Br?ns wrote:
> > A function is allowed to return NAKs during the DATA stage to control
> > data flow control. NAKs during the STATUS stage signal the function
> > is still processing the request.
>
> For my own education, do you have a link to the part of the spec that
> states that? I'd naively expect the control stage to give a NAK, but
> once a control transaction was accepted, the function would have to deal
> with it without NAKs? Still, I don't think this change would cause any
> issue either way.
"8.5.3 Control Transfers"
"The Data stage, if present, of a control transfer consists of one or more IN
or OUT transactions and follows the same protocol rules as bulk transfers."
This can also be inferred from the flow charts/state diagrams which state NAKs
and stalls are not allowed for for "control *setup* transaction" (emphasize
mine), e.g. Figure 8-31.
"8.5.3.1 Reporting Status Results"
"NAK indicates that the function is still processing the command and that the
host should continue the Status stage."
I have at least one USB LS mouse which responds with NAKs during control
transfers, Sigrok LA traces available here:
http://sigrok.org/gitweb/?p=sigrok-dumps.git;a=tree;f=usb/setup
> > diff --git a/drivers/usb/host/dwc2.c b/drivers/usb/host/dwc2.c
> >
> > @@ -907,26 +907,37 @@ static int _submit_control_msg(struct dwc2_priv
> > *priv, struct usb_device *dev,>
> > if (ret)
> >
> > return ret;
> >
> > + timeout = get_timer(0) + USB_TIMEOUT_MS(pipe);
> >
> > if (buffer) {
> >
> > + /* DATA stage */
>
> I'd suggest putting that new comment right before the "timeout = ..."
> line, since that's the start of DATA stage processing.
>
> If you're adding comments for the stages, perhaps add one at the start
> of the CONTROL stage too?
Good idea, will do.
> > pid = DWC2_HC_PID_DATA1;
> >
> > - ret = chunk_msg(priv, dev, pipe, &pid, usb_pipein(pipe), buffer,
> > - len, false);
> > + act_len = 0;
>
> I don't think you need that assignment because...
>
> > + do {
> > + if (get_timer(0) > timeout) {
> > + printf("Timeout during CONTROL DATA stage\n");
> > + return -ETIMEDOUT;
> > + }
> > + ret = chunk_msg(priv, dev, pipe, &pid, usb_pipein(pipe),
> > + buffer, len, false);
> > + act_len += dev->act_len;
> > + buffer += dev->act_len;
> > + len -= dev->act_len;
>
> Shouldn't those all be = not += or -=-, just like in the original code?
> There's no chunking loop here, so the entire length either happens in
> one go or not at all.
No, as each NAK will cause a return from chunk_msg. I see e.g. the following
interrupt flags in combination with CHHLTD (for GET_DEVICE_DESCRIPTOR):
- SETUP (SSPLIT) -> ACK
SETUP (CSPLIT) -> NYET NYET ACK
- DATA IN (SSPLIT) > ACK
DATA IN (CSPLIT) > NYET NYET NACK
- DATA IN (SSPLIT) > ACK
DATA IN (CSPLIT) > NYET NYET ACK
- DATA IN (SSPLIT) > ACK
DATA IN (CSPLIT) > NYET NYET NACK
- DATA IN (SSPLIT) > ACK
DATA IN (CSPLIT) > NYET NYET ACK
- STATUS (SSPLIT) -> ACK
STATUS (CSPLIT) -> NYET NYET ACK
On the first DATA-IN ACK, 8 bytes are returned, the second returns the final
9th byte.
The NAK handling could be moved into the loop in chunk_msg, but this would
break INTERRUPT transactions.
A different possibility is to move the timeout check into the chunk_msg loop,
i.e.
---
xfer_timeout = get_timer(0) + USB_TIMEOUT_MS(pipe);
do {
...
ret = wait_for_bit(CHHLTD, timeout=1ms)
if (ret == -EINTR)
break;
if (get_timer(0) > xfer_timeout) {
printf("Timeout\n");
ret = -ETIMEDOUT;
break;
}
...
} while ((done < len) && !stop_transfer);
---
This would also simplify both the INTERRUPT and CONTROL submit functions, and
BULK submit would finally honour the specified timeout.
> > pid = DWC2_HC_PID_DATA1;
> >
> > - ret = chunk_msg(priv, dev, pipe, &pid, status_direction,
> > - priv->status_buffer, 0, false);
> > + do {
> > + ret = chunk_msg(priv, dev, pipe, &pid, status_direction,
> > + priv->status_buffer, 0, false);
> > + } while (ret == -EAGAIN);
> >
> > if (ret)
> >
> > return ret;
>
> Shouldn't that last loop have a timeout too?
Correct, but see above.
Kind regards,
Stefan
--
Stefan Br?ns / Bergstra?e 21 / 52062 Aachen
home: +49 241 53809034 mobile: +49 151 50412019
work: +49 2405 49936-424
next prev parent reply other threads:[~2015-12-17 3:09 UTC|newest]
Thread overview: 41+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-12-13 4:17 [U-Boot] [PATCH 0/6] usb: dwc2: add SPLIT transaction support Stefan Brüns
2015-12-13 4:17 ` [U-Boot] [PATCH 1/6] usb: dwc2: avoid out of bounds access Stefan Brüns
2015-12-13 4:41 ` Marek Vasut
2015-12-16 2:58 ` Stephen Warren
2015-12-16 10:29 ` Marek Vasut
2015-12-17 1:44 ` Stefan Bruens
2015-12-13 4:17 ` [U-Boot] [PATCH 2/6] usb: dwc2: Handle NAK during CONTROL DATA and STATUS stage Stefan Brüns
2015-12-13 4:46 ` Marek Vasut
2015-12-16 3:07 ` Stephen Warren
2015-12-17 3:09 ` Stefan Bruens [this message]
2015-12-13 4:17 ` [U-Boot] [PATCH 3/6] usb: dwc2: determine TT hub address and port for split transactions Stefan Brüns
2015-12-13 4:43 ` Marek Vasut
2015-12-16 3:17 ` Stephen Warren
2015-12-17 3:16 ` Stefan Bruens
2015-12-18 1:11 ` [U-Boot] [PATCH] usb: Move determination of TT hub address/port into seperate function Stefan Brüns
2015-12-18 2:35 ` Marek Vasut
2015-12-18 10:00 ` Hans de Goede
2015-12-19 17:17 ` Stefan Bruens
2015-12-19 18:27 ` Hans de Goede
2015-12-19 20:16 ` [U-Boot] [PATCH 1/2 v2] " Stefan Brüns
2015-12-19 20:16 ` [U-Boot] [PATCH 2/2 v2] usb: musb: Fix hub port number for SPLIT transactions Stefan Brüns
2015-12-21 19:33 ` Hans de Goede
2015-12-21 20:27 ` Marek Vasut
2015-12-21 23:02 ` Stefan Bruens
2015-12-21 23:08 ` Marek Vasut
2015-12-19 20:26 ` [U-Boot] [PATCH 1/2 v3] usb: Move determination of TT hub address/port into seperate function Stefan Brüns
2015-12-20 19:12 ` Hans de Goede
2015-12-21 19:32 ` Hans de Goede
2015-12-13 4:17 ` [U-Boot] [PATCH 4/6] usb: dwc2: add helper function for setting SPLIT HC registers Stefan Brüns
2015-12-13 4:44 ` Marek Vasut
2015-12-16 3:19 ` Stephen Warren
2015-12-13 4:17 ` [U-Boot] [PATCH 5/6] usb: dwc2: add support for SPLIT transactions Stefan Brüns
2015-12-13 4:48 ` Marek Vasut
2015-12-16 3:36 ` Stephen Warren
2015-12-20 0:17 ` Stefan Bruens
2015-12-20 0:41 ` Marek Vasut
2015-12-13 4:17 ` [U-Boot] [PATCH 6/6] usb: dwc2: remove no longer used wait_for_chhltd() Stefan Brüns
2015-12-13 4:48 ` Marek Vasut
2015-12-16 3:36 ` Stephen Warren
2015-12-13 4:41 ` [U-Boot] [PATCH 0/6] usb: dwc2: add SPLIT transaction support Marek Vasut
2015-12-16 2:53 ` Stephen Warren
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1792651.fb6GzQulBA@pebbles.site \
--to=stefan.bruens@rwth-aachen.de \
--cc=u-boot@lists.denx.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.