summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorDale Rahn <drahn@cvs.openbsd.org>2007-02-15 06:28:12 +0000
committerDale Rahn <drahn@cvs.openbsd.org>2007-02-15 06:28:12 +0000
commit8a0446f54a3bde41a902d769367ba9c04b6bdaf6 (patch)
tree792e3b9df3a23e163e8919b23fd6c2dc5ffdae47 /sys/arch
parentef793607391e2d87c2b44d5d2ed394638574ab3a (diff)
Fix transmit packet termination. odd length and 64 byte multiple packets
were not sending the last data correctly before.
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/arm/xscale/pxa27x_udc.c24
1 files changed, 15 insertions, 9 deletions
diff --git a/sys/arch/arm/xscale/pxa27x_udc.c b/sys/arch/arm/xscale/pxa27x_udc.c
index c479a4c0a52..0352d723845 100644
--- a/sys/arch/arm/xscale/pxa27x_udc.c
+++ b/sys/arch/arm/xscale/pxa27x_udc.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pxa27x_udc.c,v 1.12 2007/02/13 20:54:10 drahn Exp $ */
+/* $OpenBSD: pxa27x_udc.c,v 1.13 2007/02/15 06:28:11 drahn Exp $ */
/*
* Copyright (c) 2005 David Gwynne <dlg@openbsd.org>
@@ -581,9 +581,6 @@ again:
}
count -= 4;
}
-#ifdef DEBUG_RX
- printf(" remain %x\n", len);
-#endif
CSR_SET_4(sc, USBDC_UDCCSR(ep), USBDC_UDCCSR_PC);
@@ -668,10 +665,13 @@ pxaudc_write(struct pxaudc_softc *sc, usbf_xfer_handle xfer)
int tlen = 0;
if (xfer->actlen == xfer->length) {
-#if 0
- if ((xfer->actlen % 64) != 0)
+ /*
+ * if the packet's last bytes are in the 'word'
+ * send a zero packet to indicate termiation
+ if ((((xfer->actlen+3)>>2) % (64>>2)) == 0)
+ */
+ if ((xfer->actlen % 64) == 0)
CSR_SET_4(sc, USBDC_UDCCSR(ep), USBDC_UDCCSR_SP);
-#endif
xfer->status = USBF_NORMAL_COMPLETION;
usbf_transfer_complete(xfer);
return;
@@ -690,9 +690,15 @@ pxaudc_write(struct pxaudc_softc *sc, usbf_xfer_handle xfer)
while (CSR_READ_4(sc, USBDC_UDCCSR(ep)) & USBDC_UDCCSR_BNF) {
u_int32_t v;
- if (xfer->actlen >= xfer->length)
+ if (xfer->length - xfer->actlen < 4) {
+ while (xfer->actlen < xfer->length) {
+ CSR_WRITE_1(sc, USBDC_UDCDR(ep), *p);
+ p++;
+ xfer->actlen++;
+ tlen++;
+ }
break;
-
+ }
if (((unsigned)p & 0x3) == 0)
v = *(u_int32_t *)p;
else {