diff options
author | Sebastian Ott <sebott@linux.vnet.ibm.com> | 2013-01-28 13:31:50 -0500 |
---|---|---|
committer | Martin Schwidefsky <schwidefsky@de.ibm.com> | 2013-02-14 09:55:07 -0500 |
commit | e6a0b7c90f9f2663f470bbfaf83afcf52f8459e8 (patch) | |
tree | 4856e350b7dee7878d6ea3fb68b54976abbbbae7 | |
parent | 69f5576f6c8c9d0f0b3670ee7c807a194b4c40f4 (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.c | 11 |
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 | } |
352 | out: | 353 | out: |
@@ -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); |