Commit be4904e5 authored by Stefan Weinhuber's avatar Stefan Weinhuber Committed by Martin Schwidefsky

dasd: fix sysfs cleanup in dasd_generic_remove

When the DASD devices are detached from the driver, then the
dasd_generic_remove function is called. One of the things this
function should do is to remove the DASD specific sysfs attributes,
but this is not done in all cases. This is likely to cause an oops
when at a later point sysfs stumbles over the stale pointers. In
particular this happens when when the modules are unloaded and loaded
again.
Signed-off-by: default avatarStefan Weinhuber <wein@de.ibm.com>
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
parent 53923354
...@@ -3042,12 +3042,15 @@ void dasd_generic_remove(struct ccw_device *cdev) ...@@ -3042,12 +3042,15 @@ void dasd_generic_remove(struct ccw_device *cdev)
cdev->handler = NULL; cdev->handler = NULL;
device = dasd_device_from_cdev(cdev); device = dasd_device_from_cdev(cdev);
if (IS_ERR(device)) if (IS_ERR(device)) {
dasd_remove_sysfs_files(cdev);
return; return;
}
if (test_and_set_bit(DASD_FLAG_OFFLINE, &device->flags) && if (test_and_set_bit(DASD_FLAG_OFFLINE, &device->flags) &&
!test_bit(DASD_FLAG_SAFE_OFFLINE_RUNNING, &device->flags)) { !test_bit(DASD_FLAG_SAFE_OFFLINE_RUNNING, &device->flags)) {
/* Already doing offline processing */ /* Already doing offline processing */
dasd_put_device(device); dasd_put_device(device);
dasd_remove_sysfs_files(cdev);
return; return;
} }
/* /*
......
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