PERFORCE change 146797 for review
Hans Petter Selasky
hselasky at FreeBSD.org
Wed Aug 6 19:49:11 UTC 2008
http://perforce.freebsd.org/chv.cgi?CH=146797
Change 146797 by hselasky at hselasky_laptop001 on 2008/08/06 19:48:16
Sort some variables by size to
reduce stack consumption on embedded
platforms.
Bugfix: If we do not have room for an
USB transfer, then set the length to
zero instead of clearing the ACTIVE
bit, hence the latter solution would
lead to an infinite loop.
Affected files ...
.. //depot/projects/usb/src/sys/dev/usb2/controller/ehci2.c#9 edit
Differences ...
==== //depot/projects/usb/src/sys/dev/usb2/controller/ehci2.c#9 (text+ko) ====
@@ -2410,23 +2410,23 @@
struct usb2_fs_isoc_schedule *fss_start;
struct usb2_fs_isoc_schedule *fss_end;
struct usb2_fs_isoc_schedule *fss;
+ ehci_sitd_t *td;
+ ehci_sitd_t *td_last = NULL;
+ ehci_sitd_t **pp_last;
+ uint32_t *plen;
uint32_t buf_offset;
uint32_t nframes;
uint32_t temp;
uint32_t sitd_mask;
- uint32_t *plen;
uint16_t tlen;
+ uint8_t sa;
+ uint8_t sb;
+ uint8_t error;
#ifdef USB_DEBUG
uint8_t once = 1;
#endif
- uint8_t sa;
- uint8_t sb;
- uint8_t error;
- ehci_sitd_t *td;
- ehci_sitd_t *td_last = NULL;
- ehci_sitd_t **pp_last;
DPRINTFN(6, "xfer=%p next=%d nframes=%d\n",
xfer, xfer->pipe->isoc_next, xfer->nframes);
@@ -2523,7 +2523,13 @@
* full!
*/
error = usb2_fs_isoc_schedule_alloc(fss, &sa, *plen);
-
+ if (error) {
+ /*
+ * The FULL speed schedule is FULL! Set length
+ * to zero.
+ */
+ *plen = 0;
+ }
if (*plen) {
/*
* only call "usb2_get_page()" when we have a
@@ -2536,7 +2542,8 @@
* NOTE: We need to subtract one from the offset so
* that we are on a valid page!
*/
- usb2_get_page(xfer->frbuffers, buf_offset - 1, &buf_res);
+ usb2_get_page(xfer->frbuffers, buf_offset - 1,
+ &buf_res);
temp = buf_res.physaddr & ~0xFFF;
} else {
td->sitd_bp[0] = 0;
@@ -2588,15 +2595,6 @@
(EHCI_SITD_ACTIVE |
EHCI_SITD_SET_LEN(*plen));
}
- if (error) {
- /*
- * The FULL speed schedule is FULL! Pretend that the
- * transaction has been executed. The IOC bit should
- * be active even if the ACTIVE bit is zero.
- */
- td->sitd_status &=
- ~htole32(EHCI_SITD_ACTIVE);
- }
usb2_pc_cpu_flush(td->page_cache);
#ifdef USB_DEBUG
@@ -2704,11 +2702,14 @@
{
struct usb2_page_search buf_res;
ehci_softc_t *sc = xfer->usb2_sc;
+ ehci_itd_t *td;
+ ehci_itd_t *td_last = NULL;
+ ehci_itd_t **pp_last;
bus_size_t page_addr;
+ uint32_t *plen;
uint32_t status;
uint32_t buf_offset;
uint32_t nframes;
- uint32_t *plen;
uint32_t itd_offset[8 + 1];
uint8_t x;
uint8_t td_no;
@@ -2718,9 +2719,6 @@
uint8_t once = 1;
#endif
- ehci_itd_t *td;
- ehci_itd_t *td_last = NULL;
- ehci_itd_t **pp_last;
DPRINTFN(6, "xfer=%p next=%d nframes=%d\n",
xfer, xfer->pipe->isoc_next, xfer->nframes);
More information about the p4-projects
mailing list