On Tue, 2004-10-26 at 14:08, Mike Christie wrote: > > The null state and and oops are becuase of this > > http://marc.theaimsgroup.com/?l=linux-scsi&m=109733573729283&w=2 > > Oh yeah. that patch is not correct, but if you correctly modify it to > use device_for_each_child per Christoph's suggestion, I seem to be > getting some refcounting errors. For some reason the sdev will be > released, but the sd.c still thinks it is there.
Actually, he suggested using shost_for_each_device. The reason being that you can't have nested device_for_each_child (because it takes the bus semaphore). The attached should do this, if someone would care to try it out. James ===== hosts.c 1.102 vs edited ===== --- 1.102/drivers/scsi/hosts.c 2004-10-11 10:03:45 -05:00 +++ edited/hosts.c 2004-10-26 20:49:51 -05:00 @@ -50,11 +50,6 @@ .release = scsi_host_cls_release, }; -static int scsi_device_cancel_cb(struct device *dev, void *data) -{ - return scsi_device_cancel(to_scsi_device(dev), *(int *)data); -} - /** * scsi_host_cancel - cancel outstanding IO to this host * @shost: pointer to struct Scsi_Host @@ -62,9 +57,12 @@ **/ void scsi_host_cancel(struct Scsi_Host *shost, int recovery) { + struct scsi_device *sdev; + set_bit(SHOST_CANCEL, &shost->shost_state); - device_for_each_child(&shost->shost_gendev, &recovery, - scsi_device_cancel_cb); + shost_for_each_device(sdev, shost) { + scsi_device_cancel(sdev, recovery); + } wait_event(shost->host_wait, (!test_bit(SHOST_RECOVERY, &shost->shost_state))); } ------------------------------------------------------- This SF.Net email is sponsored by: Sybase ASE Linux Express Edition - download now for FREE LinuxWorld Reader's Choice Award Winner for best database on Linux. http://ads.osdn.com/?ad_id=5588&alloc_id=12065&op=click _______________________________________________ [EMAIL PROTECTED] To unsubscribe, use the last form field at: https://lists.sourceforge.net/lists/listinfo/linux-usb-devel