linux-scsi.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH] fix oops when removing scsi_host while IO is outstanding (and when using scsi_target patches)
@ 2004-10-09 15:28 Mike Christie
  2004-10-10 10:14 ` Christoph Hellwig
  0 siblings, 1 reply; 3+ messages in thread
From: Mike Christie @ 2004-10-09 15:28 UTC (permalink / raw)
  To: linux-scsi

[-- Attachment #1: Type: text/plain, Size: 1160 bytes --]

When trying to remove a host while IO is running I will get the folling warning,
and after these messages my log fills up with various oops.

Oct  9 04:54:44 mina kernel:  target0:0:0: Illegal state transition <NULL>->cancel
Oct  9 04:54:44 mina kernel: Badness in scsi_device_set_state at drivers/scsi/scsi_lib.c:1713
Oct  9 04:54:44 mina kernel:  [<c010585e>] dump_stack+0x1e/0x30
Oct  9 04:54:44 mina kernel:  [<f8831316>] scsi_device_set_state+0xc6/0x130 [scsi_mod]
Oct  9 04:54:44 mina kernel:  [<f88290fc>] scsi_device_cancel+0x3c/0x263 [scsi_mod]
Oct  9 04:54:44 mina kernel:  [<c02c280d>] device_for_each_child+0x4d/0x80
Oct  9 04:54:44 mina kernel:  [<f88293c2>] scsi_host_cancel+0x32/0xc0 [scsi_mod]
Oct  9 04:54:44 mina kernel:  [<f8829472>] scsi_remove_host+0x22/0x70 [scsi_mod]

Note the target dev name and NULL state.

Basically, scsi_host_cancel is doing a device_for_each_child thinking it's
children are scsi_devices, but in the scsi-target-2.6 tree they are now
targets. The attached patch fixes this by just adding the extra
device_for_each_child loop to get to the scsi device. It was built against
the current scsi-target-2.6 tree.

Mike

[-- Attachment #2: cancel-scsi-targets.patch --]
[-- Type: text/x-patch, Size: 779 bytes --]

--- scsi-target-2.6/drivers/scsi/hosts.c	2004-10-09 07:56:54.363746835 -0700
+++ scsi-target-2.6.work/drivers/scsi/hosts.c	2004-10-09 07:49:21.287638490 -0700
@@ -55,6 +55,12 @@
 	return scsi_device_cancel(to_scsi_device(dev), *(int *)data);
 }
 
+static int scsi_target_cancel_cb(struct device *dev, void *data)
+{
+	device_for_each_child(dev, data, scsi_device_cancel_cb);
+	return 0;
+}
+
 /**
  * scsi_host_cancel - cancel outstanding IO to this host
  * @shost:	pointer to struct Scsi_Host
@@ -64,7 +70,7 @@
 {
 	set_bit(SHOST_CANCEL, &shost->shost_state);
 	device_for_each_child(&shost->shost_gendev, &recovery,
-			      scsi_device_cancel_cb);
+			      scsi_target_cancel_cb);
 	wait_event(shost->host_wait, (!test_bit(SHOST_RECOVERY,
 						&shost->shost_state)));
 }

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2004-10-10 18:56 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2004-10-09 15:28 [PATCH] fix oops when removing scsi_host while IO is outstanding (and when using scsi_target patches) Mike Christie
2004-10-10 10:14 ` Christoph Hellwig
2004-10-10 18:55   ` Mike Christie

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).