> > We want only one method of URB allocation, don't we?
> 
> Of course.  But that method could be used either to pre-allocate URBs and
> buffers like Matt is suggesting, or to allocate them on demand like we do
> now.

If we want to avoid the memory allocation in block io path problem,
we have to preallocate. Besides, it is faster.

> > > I'm puzzled how pre-allocation would help usb_kill_urb().
> > 
> > Reentrancy. The URB can be resubmitted from the completion handler, but
> > it cannot have completed.
> 
> I don't see what this has to do with pre-allocating URBs.  (Also I don't 
> understand what you mean "it cannot have completed", but maybe that's not 
> important for this discussion.)

An URB with its buffer preallocated is bound to a device, respectively
an endpoint, so it cannot complete without triggering the same irq the
completion handler is running in.

        Regards
                Oliver


-------------------------------------------------------
This SF.Net email is sponsored by BEA Weblogic Workshop
FREE Java Enterprise J2EE developer tools!
Get your free copy of BEA WebLogic Workshop 8.1 today.
http://ads.osdn.com/?ad_id=4721&alloc_id=10040&op=click
_______________________________________________
[EMAIL PROTECTED]
To unsubscribe, use the last form field at:
https://lists.sourceforge.net/lists/listinfo/linux-usb-devel

Reply via email to