help finding entry point of USB data in the kernel, not drivers/usb/core/devio.c?
From: George Nychis
Date: Tue Sep 30 2008 - 01:05:27 EST
Hi all,
I am trying to find the entry point of USB data in the kernel. I have a
USB device and I would like to find the latency between the time the
data enters the kernel, and I read it in userspace. My first goal is to
find where it actually enters the kernel.
The host device driver obtains a URB and reads the data from urb->buffer.
From digging around the kernel code, I had assumed the entry point for
all USB data was in drivers/usb/core/devio.c::usbdev_read() ... but it
seems as though that is not the case.
Right after the device is locked in this function, I added a simple
printk: printk("Reading %d bytes\n", nbytes); // Line 135
Then around line 154 after it reads the usb device descriptor, I added:
if(temp_desc.idVendor==0xfffe && temp_desc.idProduct==0x0002) {
printk("...Data from USRP\n");
}
That gives me an idea that the data is coming from the device I am
looking for.
But, it seems as though this method is only related to control
information to/from the USB device? Whenever I start my application, I
get about 1614 total bytes read from my first printout, and I see only
one of my second printout messages. Whereas, I am reading a total of
about 8MB from the USB device over the period of time. So I think I am
completely missing my actual data entry point.
Additionally, lsusb generates this same exact amount 1614 total bytes of
data... so it seems to be control related to me.
I'd greatly appreciate any guidance.
Thanks!
George
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/