arch/arm/src/stm32/stm32_otg[fs|hs]host.c: STM32 host only initiates transfer if buflenl > 0.
This commit is contained in:
parent
5707d01cc3
commit
5b4516d291
@ -2201,6 +2201,7 @@ static ssize_t stm32_out_transfer(FAR struct stm32_usbhost_s *priv, int chidx,
|
|||||||
size_t xfrlen;
|
size_t xfrlen;
|
||||||
ssize_t xfrd;
|
ssize_t xfrd;
|
||||||
int ret;
|
int ret;
|
||||||
|
bool zlp;
|
||||||
|
|
||||||
/* Loop until the transfer completes (i.e., buflen is decremented to zero)
|
/* Loop until the transfer completes (i.e., buflen is decremented to zero)
|
||||||
* or a fatal error occurs (any error other than a simple NAK)
|
* or a fatal error occurs (any error other than a simple NAK)
|
||||||
@ -2209,8 +2210,9 @@ static ssize_t stm32_out_transfer(FAR struct stm32_usbhost_s *priv, int chidx,
|
|||||||
chan = &priv->chan[chidx];
|
chan = &priv->chan[chidx];
|
||||||
start = clock_systimer();
|
start = clock_systimer();
|
||||||
xfrd = 0;
|
xfrd = 0;
|
||||||
|
zlp = (buflen == 0);
|
||||||
|
|
||||||
while (buflen > 0)
|
while (buflen > 0 || zlp)
|
||||||
{
|
{
|
||||||
/* Transfer one packet at a time. The hardware is capable of queueing
|
/* Transfer one packet at a time. The hardware is capable of queueing
|
||||||
* multiple OUT packets, but I just haven't figured out how to handle
|
* multiple OUT packets, but I just haven't figured out how to handle
|
||||||
@ -2287,6 +2289,7 @@ static ssize_t stm32_out_transfer(FAR struct stm32_usbhost_s *priv, int chidx,
|
|||||||
buffer += xfrlen;
|
buffer += xfrlen;
|
||||||
buflen -= xfrlen;
|
buflen -= xfrlen;
|
||||||
xfrd += chan->xfrd;
|
xfrd += chan->xfrd;
|
||||||
|
zlp = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2206,6 +2206,7 @@ static ssize_t stm32_out_transfer(FAR struct stm32_usbhost_s *priv, int chidx,
|
|||||||
size_t xfrlen;
|
size_t xfrlen;
|
||||||
ssize_t xfrd;
|
ssize_t xfrd;
|
||||||
int ret;
|
int ret;
|
||||||
|
bool zlp;
|
||||||
|
|
||||||
/* Loop until the transfer completes (i.e., buflen is decremented to zero)
|
/* Loop until the transfer completes (i.e., buflen is decremented to zero)
|
||||||
* or a fatal error occurs (any error other than a simple NAK)
|
* or a fatal error occurs (any error other than a simple NAK)
|
||||||
@ -2214,9 +2215,11 @@ static ssize_t stm32_out_transfer(FAR struct stm32_usbhost_s *priv, int chidx,
|
|||||||
chan = &priv->chan[chidx];
|
chan = &priv->chan[chidx];
|
||||||
start = clock_systimer();
|
start = clock_systimer();
|
||||||
xfrd = 0;
|
xfrd = 0;
|
||||||
|
zlp = (buflen == 0);
|
||||||
|
|
||||||
while (buflen > 0)
|
while (buflen > 0 || zlp)
|
||||||
{
|
{
|
||||||
|
|
||||||
/* Transfer one packet at a time. The hardware is capable of queueing
|
/* Transfer one packet at a time. The hardware is capable of queueing
|
||||||
* multiple OUT packets, but I just haven't figured out how to handle
|
* multiple OUT packets, but I just haven't figured out how to handle
|
||||||
* the case where a single OUT packet in the group is NAKed.
|
* the case where a single OUT packet in the group is NAKed.
|
||||||
@ -2292,6 +2295,7 @@ static ssize_t stm32_out_transfer(FAR struct stm32_usbhost_s *priv, int chidx,
|
|||||||
buffer += xfrlen;
|
buffer += xfrlen;
|
||||||
buflen -= xfrlen;
|
buflen -= xfrlen;
|
||||||
xfrd += chan->xfrd;
|
xfrd += chan->xfrd;
|
||||||
|
zlp = false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user