Alan Stern [EMAIL PROTECTED] wrote: > On Thu, 13 May 2004, Mike Anderson wrote: > > > The LLDD queuecommand should not be called after the return of > > scsi_remove_host (unless we have a bug). The LLDD should not free its > > resources until the release function is called on the struct device > > passed in during the scsi_add_host call. > > Ah. We have a problem here, because usb-storage doesn't own that struct > device. It is owned by the USB core, and usb-storage has no way to know > when its release function has been called. > > Even worse, the release function may never be called at all. The device > itself may still exist and be attached to the system even though the > usb-storage driver has been unbound from it. > > There must be many other LLDDs with the same problem. Any driver that > manages a PCI host controller, for example. The struct device it receives > from the PCI layer isn't owned by the LLDD, yet that's what it must pass > to scsi_add_host(). > > How should we handle this? >
I was incorrect in my previous statement. Well we may hold a reference count on the struct device passed into the scsi_add_host until all references on the host instance are gone and there maybe a positive ref count on the hostt module until all devices are closed a instance of LLDD should be able to do cleanup post return of scsi_remove_host. This needs to be true or SCSI mid-layer would not honor the requirement for the pci remove call. I believe in the past you or someone else has mentioned that post the return of scsi_remove_host a Scsi_Host instance still has a hostt and a transportt which may be dangerous if all code paths are not correctly handling a host in the SHOST_DEL state. I guess we still have this current issue on what is happening in the usb storage that it believes SCSI mid is still using the device. Is something not cleaning up, or is something in SCSI mid not honoring the SHOST_DEL state. -andmike -- Michael Anderson [EMAIL PROTECTED] ------------------------------------------------------- This SF.Net email is sponsored by: SourceForge.net Broadband Sign-up now for SourceForge Broadband and get the fastest 6.0/768 connection for only $19.95/mo for the first 3 months! http://ads.osdn.com/?ad_id=2562&alloc_id=6184&op=click _______________________________________________ [EMAIL PROTECTED] To unsubscribe, use the last form field at: https://lists.sourceforge.net/lists/listinfo/linux-usb-devel