On Tue, Jul 23, 2013 at 01:33:25PM +0000, Stoddard, Nate (GE Healthcare) wrote: > Hello, > > We are attempting to create a system that will support 8 full speed > USB devices each sending a 64-byte transfer every 1ms via interrupt > endpoints. When we connect 5 full speed USB devices our USB host use > 24% of the CPU, but when we connect a 6th device, the CPU goes to > 100%. Has anyone else seen this type of CPU jump or know what could > be causing it? > > Devices CPU Total Throughput > 1 7% 64 KB/s > 2 11% 128 KB/s > 3 15% 192 KB/s > 4 19% 256 KB/s > 5 24% 320 KB/s > 6 99% (should be 384 KB/s, but the iMX535 misses sending IN tokens in some SOF periods) > > We are using a Freescale iMX535 board running at 800 MHz as the USB > host. One of the iMX535 EHCI root controllers is connected to a high > speed USB hub which has two ports each connected to another high speed > USB hub (giving us 8 ports for USB devices). Each hub has multi-TT > support. The iMX535 is running Linux 2.6.35, and our test application > uses libUSB asynchronous I/O (v1.0.16). The libUSB callback function > do not process the data; rather the function only resubmits the > transfer. As you are using an old, obsolete, and unsupported-by-the-community kernel version, I am going to have to point you to the vendor that provided you with this kernel (that you are paying for), and ask that you get support from them, as there's really nothing we can do for you here. And that hardware is not the "best". What happens if you plug the same number of devices into a "real" EHCI host controller (i.e. a PCI one on a PC)? The EHCI driver should handle this just fine, odds are the issues are down in the iMX535 driver, or possibly, the silicon for that chip as I don't think it was designed to support that many devices (read the data sheet for specifics, but I thought I saw that years ago...) Best of luck, greg k-h -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html