From 1626b65ae40a32ed56db176a8b3f52a0b2bb09e8 Mon Sep 17 00:00:00 2001 From: Sebastian Ott Date: Thu, 26 Mar 2009 15:24:08 +0100 Subject: [PATCH] --- yaml --- r: 135611 b: refs/heads/master c: e74fe0cec92439115630b51195444b89b910800a h: refs/heads/master i: 135609: db3336b80d474faad0d0b715a50aaa7c241b9afe 135607: cd0e89cd0a13bea99b9810d3e888904e6ff70194 v: v3 --- [refs] | 2 +- trunk/drivers/s390/cio/device.c | 14 ++++++-------- 2 files changed, 7 insertions(+), 9 deletions(-) diff --git a/[refs] b/[refs] index d9f9de3bd5d4..aa217110e808 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: c08f294a14cb4c2abbd1a9a619c2d8d07afd41e3 +refs/heads/master: e74fe0cec92439115630b51195444b89b910800a diff --git a/trunk/drivers/s390/cio/device.c b/trunk/drivers/s390/cio/device.c index 71b3b73e8ebe..9be6dd5a5664 100644 --- a/trunk/drivers/s390/cio/device.c +++ b/trunk/drivers/s390/cio/device.c @@ -457,12 +457,13 @@ int ccw_device_set_online(struct ccw_device *cdev) return (ret == 0) ? -ENODEV : ret; } -static void online_store_handle_offline(struct ccw_device *cdev) +static int online_store_handle_offline(struct ccw_device *cdev) { if (cdev->private->state == DEV_STATE_DISCONNECTED) ccw_device_remove_disconnected(cdev); - else if (cdev->drv && cdev->drv->set_offline) - ccw_device_set_offline(cdev); + else if (cdev->online && cdev->drv && cdev->drv->set_offline) + return ccw_device_set_offline(cdev); + return 0; } static int online_store_recog_and_online(struct ccw_device *cdev) @@ -530,13 +531,10 @@ static ssize_t online_store (struct device *dev, struct device_attribute *attr, goto out; switch (i) { case 0: - online_store_handle_offline(cdev); - ret = count; + ret = online_store_handle_offline(cdev); break; case 1: ret = online_store_handle_online(cdev, force); - if (!ret) - ret = count; break; default: ret = -EINVAL; @@ -545,7 +543,7 @@ static ssize_t online_store (struct device *dev, struct device_attribute *attr, if (cdev->drv) module_put(cdev->drv->owner); atomic_set(&cdev->private->onoff, 0); - return ret; + return (ret < 0) ? ret : count; } static ssize_t