Commit ca732e11 authored by Stefan Haberland's avatar Stefan Haberland Committed by Martin Schwidefsky

s390/dasd: check blockdevice pointer before trying to sync blockdevice

If safe offline is called for a DASD alias device a null pointer is passed
to fsync_bdev. So check for existence of the blockdevice before calling
fsync_bdev.
Should not be a real world problem since safe offline for an alias device
does not make sense and fsync_bdev can deal with a NULL pointer which it
gets after successful NULL pointer dereferencing on s390.
Signed-off-by: default avatarStefan Haberland <sth@linux.vnet.ibm.com>
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
parent 2202134e
...@@ -3601,10 +3601,11 @@ int dasd_generic_set_offline(struct ccw_device *cdev) ...@@ -3601,10 +3601,11 @@ int dasd_generic_set_offline(struct ccw_device *cdev)
* empty * empty
*/ */
/* sync blockdev and partitions */ /* sync blockdev and partitions */
rc = fsync_bdev(device->block->bdev); if (device->block) {
if (rc != 0) rc = fsync_bdev(device->block->bdev);
goto interrupted; if (rc != 0)
goto interrupted;
}
/* schedule device tasklet and wait for completion */ /* schedule device tasklet and wait for completion */
dasd_schedule_device_bh(device); dasd_schedule_device_bh(device);
rc = wait_event_interruptible(shutdown_waitq, rc = wait_event_interruptible(shutdown_waitq,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment