aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSebastian Ott <sebott@linux.vnet.ibm.com>2013-01-28 13:31:50 -0500
committerMartin Schwidefsky <schwidefsky@de.ibm.com>2013-02-14 09:55:07 -0500
commite6a0b7c90f9f2663f470bbfaf83afcf52f8459e8 (patch)
tree4856e350b7dee7878d6ea3fb68b54976abbbbae7
parent69f5576f6c8c9d0f0b3670ee7c807a194b4c40f4 (diff)
s390/cio: skip broken paths
Omit known to be broken paths (those set in path_noirq_mask) for the sense/set PGID and nop IO commands. Note: path_noirq_mask will be reset in ccw_device_verify_start (the paths could be healthy again). However if we restart a path verification via verify_start this mask will not be reset (there is no need to let the wait for an interrupt time out again - plus we do not want to loop once we deal with the paths in unknown path group state). Reviewed-by: Peter Oberparleiter <peter.oberparleiter@de.ibm.com> Signed-off-by: Sebastian Ott <sebott@linux.vnet.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
-rw-r--r--drivers/s390/cio/device_pgid.c11
1 files changed, 6 insertions, 5 deletions
diff --git a/drivers/s390/cio/device_pgid.c b/drivers/s390/cio/device_pgid.c
index 6f2987d8da99..f12beb72f263 100644
--- a/drivers/s390/cio/device_pgid.c
+++ b/drivers/s390/cio/device_pgid.c
@@ -70,8 +70,8 @@ static void nop_do(struct ccw_device *cdev)
70 struct subchannel *sch = to_subchannel(cdev->dev.parent); 70 struct subchannel *sch = to_subchannel(cdev->dev.parent);
71 struct ccw_request *req = &cdev->private->req; 71 struct ccw_request *req = &cdev->private->req;
72 72
73 /* Adjust lpm. */ 73 req->lpm = lpm_adjust(req->lpm, sch->schib.pmcw.pam & sch->opm &
74 req->lpm = lpm_adjust(req->lpm, sch->schib.pmcw.pam & sch->opm); 74 ~cdev->private->path_noirq_mask);
75 if (!req->lpm) 75 if (!req->lpm)
76 goto out_nopath; 76 goto out_nopath;
77 nop_build_cp(cdev); 77 nop_build_cp(cdev);
@@ -345,8 +345,9 @@ static void snid_done(struct ccw_device *cdev, int rc)
345 else { 345 else {
346 donepm = pgid_to_donepm(cdev); 346 donepm = pgid_to_donepm(cdev);
347 sch->vpm = donepm & sch->opm; 347 sch->vpm = donepm & sch->opm;
348 cdev->private->pgid_todo_mask &= ~donepm;
349 cdev->private->pgid_reset_mask |= reset; 348 cdev->private->pgid_reset_mask |= reset;
349 cdev->private->pgid_todo_mask &=
350 ~(donepm | cdev->private->path_noirq_mask);
350 pgid_fill(cdev, pgid); 351 pgid_fill(cdev, pgid);
351 } 352 }
352out: 353out:
@@ -400,8 +401,8 @@ static void snid_do(struct ccw_device *cdev)
400 struct subchannel *sch = to_subchannel(cdev->dev.parent); 401 struct subchannel *sch = to_subchannel(cdev->dev.parent);
401 struct ccw_request *req = &cdev->private->req; 402 struct ccw_request *req = &cdev->private->req;
402 403
403 /* Adjust lpm if paths are not set in pam. */ 404 req->lpm = lpm_adjust(req->lpm, sch->schib.pmcw.pam &
404 req->lpm = lpm_adjust(req->lpm, sch->schib.pmcw.pam); 405 ~cdev->private->path_noirq_mask);
405 if (!req->lpm) 406 if (!req->lpm)
406 goto out_nopath; 407 goto out_nopath;
407 snid_build_cp(cdev); 408 snid_build_cp(cdev);