diff options
Diffstat (limited to 'drivers/s390/cio/cmf.c')
-rw-r--r-- | drivers/s390/cio/cmf.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/drivers/s390/cio/cmf.c b/drivers/s390/cio/cmf.c index a90b28c0be57..288482b21048 100644 --- a/drivers/s390/cio/cmf.c +++ b/drivers/s390/cio/cmf.c | |||
@@ -195,7 +195,8 @@ static int set_schib(struct ccw_device *cdev, u32 mme, int mbfc, | |||
195 | /* msch can silently fail, so do it again if necessary */ | 195 | /* msch can silently fail, so do it again if necessary */ |
196 | for (retry = 0; retry < 3; retry++) { | 196 | for (retry = 0; retry < 3; retry++) { |
197 | /* prepare schib */ | 197 | /* prepare schib */ |
198 | stsch(sch->schid, schib); | 198 | if (cio_update_schib(sch)) |
199 | return -ENODEV; | ||
199 | schib->pmcw.mme = mme; | 200 | schib->pmcw.mme = mme; |
200 | schib->pmcw.mbfc = mbfc; | 201 | schib->pmcw.mbfc = mbfc; |
201 | /* address can be either a block address or a block index */ | 202 | /* address can be either a block address or a block index */ |
@@ -219,7 +220,8 @@ static int set_schib(struct ccw_device *cdev, u32 mme, int mbfc, | |||
219 | ret = -EINVAL; | 220 | ret = -EINVAL; |
220 | break; | 221 | break; |
221 | } | 222 | } |
222 | stsch(sch->schid, schib); /* restore the schib */ | 223 | if (cio_update_schib(sch)) |
224 | return -ENODEV; | ||
223 | 225 | ||
224 | if (ret) | 226 | if (ret) |
225 | break; | 227 | break; |
@@ -338,7 +340,7 @@ static int cmf_copy_block(struct ccw_device *cdev) | |||
338 | 340 | ||
339 | sch = to_subchannel(cdev->dev.parent); | 341 | sch = to_subchannel(cdev->dev.parent); |
340 | 342 | ||
341 | if (stsch(sch->schid, &sch->schib)) | 343 | if (cio_update_schib(sch)) |
342 | return -ENODEV; | 344 | return -ENODEV; |
343 | 345 | ||
344 | if (scsw_fctl(&sch->schib.scsw) & SCSW_FCTL_START_FUNC) { | 346 | if (scsw_fctl(&sch->schib.scsw) & SCSW_FCTL_START_FUNC) { |