dm mpath: hold io until all pg_inits completed
authorKiyoshi Ueda <k-ueda@ct.jp.nec.com>
Sat, 6 Mar 2010 02:30:02 +0000 (02:30 +0000)
committerAlasdair G Kergon <agk@redhat.com>
Sat, 6 Mar 2010 02:30:02 +0000 (02:30 +0000)
commitd0259bf0eefc503d3c9c9ccda35033c3dd3aac30
tree8e0a6ebf9e9509875c160369803a2b6dd2abd943
parentfce323dd68e13354071538c765b062859e6f8286
dm mpath: hold io until all pg_inits completed

m->queue_io is set to block processing I/Os, and it needs to be kept
while pg-init, which issues multiple path activations, is in progress.
But m->queue is cleared when a path activation completes without error
in pg_init_done(), even while other path activations are in progress.
That may cause undesired -EIO on paths which are not complete activation.

This patch fixes that by not clearing m->queue_io until all path
activations complete.

(Before the hardware handlers were moved into the SCSI layer, pg_init
only used one path.)

Signed-off-by: Kiyoshi Ueda <k-ueda@ct.jp.nec.com>
Signed-off-by: Jun'ichi Nomura <j-nomura@ce.jp.nec.com>
Signed-off-by: Alasdair G Kergon <agk@redhat.com>
drivers/md/dm-mpath.c