aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/s390/cio/device_fsm.c
diff options
context:
space:
mode:
authorCornelia Huck <cornelia.huck@de.ibm.com>2008-12-25 07:39:06 -0500
committerMartin Schwidefsky <schwidefsky@de.ibm.com>2008-12-25 07:39:07 -0500
commit9cd67421977a701272820987ff9e6f197b1b97b7 (patch)
tree3d29b739749d6aeb0d3f427b23678d71d080c307 /drivers/s390/cio/device_fsm.c
parent97166f52fc84c0bc49c7dbba2a26720110acb458 (diff)
[S390] cio: Fix reference counting for online/offline.
The current code attempts to get an extra reference count for online devices by doing a get_device() in ccw_device_online() and a put_device() in ccw_device_done(). However, this - incorrectly obtains an extra reference for disconnected devices becoming available again (since they are already online) - needs special checks for css_init_done in order to handle the console device - is not obvious and - may incorretly drop a reference count in ccw_device_done() if that function is called after path verification for a device that just became not operational. So let's just get the reference in ccw_device_set_online() and drop it in ccw_device_set_offline(). (Unfortunately, we still need the special case in io_subchannel_probe().) Signed-off-by: Cornelia Huck <cornelia.huck@de.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'drivers/s390/cio/device_fsm.c')
-rw-r--r--drivers/s390/cio/device_fsm.c5
1 files changed, 0 insertions, 5 deletions
diff --git a/drivers/s390/cio/device_fsm.c b/drivers/s390/cio/device_fsm.c
index 10bc03940fb3..01330cf5ae5e 100644
--- a/drivers/s390/cio/device_fsm.c
+++ b/drivers/s390/cio/device_fsm.c
@@ -399,9 +399,6 @@ ccw_device_done(struct ccw_device *cdev, int state)
399 ccw_device_oper_notify(cdev); 399 ccw_device_oper_notify(cdev);
400 } 400 }
401 wake_up(&cdev->private->wait_q); 401 wake_up(&cdev->private->wait_q);
402
403 if (css_init_done && state != DEV_STATE_ONLINE)
404 put_device (&cdev->dev);
405} 402}
406 403
407static int cmp_pgid(struct pgid *p1, struct pgid *p2) 404static int cmp_pgid(struct pgid *p1, struct pgid *p2)
@@ -611,8 +608,6 @@ ccw_device_online(struct ccw_device *cdev)
611 (cdev->private->state != DEV_STATE_BOXED)) 608 (cdev->private->state != DEV_STATE_BOXED))
612 return -EINVAL; 609 return -EINVAL;
613 sch = to_subchannel(cdev->dev.parent); 610 sch = to_subchannel(cdev->dev.parent);
614 if (css_init_done && !get_device(&cdev->dev))
615 return -ENODEV;
616 ret = cio_enable_subchannel(sch, (u32)(addr_t)sch); 611 ret = cio_enable_subchannel(sch, (u32)(addr_t)sch);
617 if (ret != 0) { 612 if (ret != 0) {
618 /* Couldn't enable the subchannel for i/o. Sick device. */ 613 /* Couldn't enable the subchannel for i/o. Sick device. */