diff options
author | Sebastian Ott <sebott@linux.vnet.ibm.com> | 2012-11-09 08:33:06 -0500 |
---|---|---|
committer | Martin Schwidefsky <schwidefsky@de.ibm.com> | 2012-11-23 05:14:34 -0500 |
commit | cff971026d7c19f67f9312e753bb06f18b6cdae7 (patch) | |
tree | 71f7dd867568fd3e8681a2eea8af060565ab8d51 /drivers | |
parent | ce6a04ac1b759beafc88dbc443ae5da867579eeb (diff) |
s390/ccwgroup: set_online return error when already online
Return -EINVAL if set_{on,off}line is called for already {on,off}line
devices. Also return -EINVAL for drivers which do not provide a callback
for set_{on,off}line. This behaviour is now consistent with the one for
ccw devices.
Reported-by: Stefan Raspl <raspl@linux.vnet.ibm.com>
Signed-off-by: Sebastian Ott <sebott@linux.vnet.ibm.com>
Acked-by: Peter Oberparleiter <peter.oberparleiter@de.ibm.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/s390/cio/ccwgroup.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/s390/cio/ccwgroup.c b/drivers/s390/cio/ccwgroup.c index 731470e68493..9c8e117c7d3a 100644 --- a/drivers/s390/cio/ccwgroup.c +++ b/drivers/s390/cio/ccwgroup.c | |||
@@ -68,7 +68,7 @@ static void __ccwgroup_remove_cdev_refs(struct ccwgroup_device *gdev) | |||
68 | static int ccwgroup_set_online(struct ccwgroup_device *gdev) | 68 | static int ccwgroup_set_online(struct ccwgroup_device *gdev) |
69 | { | 69 | { |
70 | struct ccwgroup_driver *gdrv = to_ccwgroupdrv(gdev->dev.driver); | 70 | struct ccwgroup_driver *gdrv = to_ccwgroupdrv(gdev->dev.driver); |
71 | int ret = 0; | 71 | int ret = -EINVAL; |
72 | 72 | ||
73 | if (atomic_cmpxchg(&gdev->onoff, 0, 1) != 0) | 73 | if (atomic_cmpxchg(&gdev->onoff, 0, 1) != 0) |
74 | return -EAGAIN; | 74 | return -EAGAIN; |
@@ -88,7 +88,7 @@ out: | |||
88 | static int ccwgroup_set_offline(struct ccwgroup_device *gdev) | 88 | static int ccwgroup_set_offline(struct ccwgroup_device *gdev) |
89 | { | 89 | { |
90 | struct ccwgroup_driver *gdrv = to_ccwgroupdrv(gdev->dev.driver); | 90 | struct ccwgroup_driver *gdrv = to_ccwgroupdrv(gdev->dev.driver); |
91 | int ret = 0; | 91 | int ret = -EINVAL; |
92 | 92 | ||
93 | if (atomic_cmpxchg(&gdev->onoff, 0, 1) != 0) | 93 | if (atomic_cmpxchg(&gdev->onoff, 0, 1) != 0) |
94 | return -EAGAIN; | 94 | return -EAGAIN; |