From 2760b554ea88d46fe4bae9596b8c2a3d03701c26 Mon Sep 17 00:00:00 2001 From: patacongo Date: Tue, 21 Dec 2010 12:26:34 +0000 Subject: [PATCH] Init TDSTATUS git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@3211 42af7a65-404d-4744-a932-0658087f49c3 --- arch/arm/src/lpc17xx/lpc17_usbhost.c | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/arch/arm/src/lpc17xx/lpc17_usbhost.c b/arch/arm/src/lpc17xx/lpc17_usbhost.c index ed79e4e3cf..d1d64ea126 100755 --- a/arch/arm/src/lpc17xx/lpc17_usbhost.c +++ b/arch/arm/src/lpc17xx/lpc17_usbhost.c @@ -653,6 +653,7 @@ static int lpc17_ctrltd(struct lpc17_usbhost_s *priv, uint32_t dirpid, /* Then enqueue the transfer */ + priv->tdstatus = 0; lpc17_enqueuetd(EDCTRL, dirpid, toggle, buffer, buflen); lpc17_putreg(LPC17_EDCTRL_ADDR, LPC17_USBHOST_CTRLHEADED); @@ -1386,12 +1387,22 @@ static int lpc17_transfer(FAR struct usbhost_driver_s *drvr, if ((uintptr_t)buffer < LPC17_SRAM_BANK0 || (uintptr_t)buffer >= (LPC17_SRAM_BANK0 + LPC17_SRAM_BANK0 + LPC17_SRAM_BANK0)) { + /* Will the transfer fit in an IO buffer? */ + + if (buflen > CONFIG_USBHOST_IOBUFSIZE) + { + uvdbg("buflen (%d) > IO buffer size (%d)\n", + buflen, CONFIG_USBHOST_IOBUFSIZE); + goto errout; + } + /* Allocate an IO buffer in AHB SRAM */ origbuf = buffer; buffer = lpc17_ioalloc(priv); if (!buffer) { + uvdbg("IO buffer allocation failed\n"); goto errout; } @@ -1409,6 +1420,7 @@ static int lpc17_transfer(FAR struct usbhost_driver_s *drvr, ed = lpc17_edalloc(priv); if (!ed) { + uvdbg("ED allocation failed\n"); goto errout; } @@ -1433,6 +1445,7 @@ static int lpc17_transfer(FAR struct usbhost_driver_s *drvr, /* Then enqueue the transfer */ + priv->tdstatus = 0; lpc17_enqueuetd(ed, dirpid, GTD_STATUS_T_TOGGLE, buffer, buflen); lpc17_putreg((uint32_t)ed, LPC17_USBHOST_BULKHEADED); @@ -1457,6 +1470,7 @@ static int lpc17_transfer(FAR struct usbhost_driver_s *drvr, } else { + uvdbg("Bad TD completion status: %d\n", priv->tdstatus); ret = -EIO; } @@ -1657,7 +1671,7 @@ FAR struct usbhost_driver_s *usbhost_initialize(int controller) buffer = IOFREE; for (i = 0; i < LPC17_IOBUFFERS; i++) { - /* Put the TD buffer in a free list */ + /* Put the IO buffer in a free list */ lpc17_iofree(priv, buffer); buffer += CONFIG_USBHOST_IOBUFSIZE;