aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/s390
diff options
context:
space:
mode:
authorStefan Weinhuber <wein@de.ibm.com>2013-02-04 07:10:35 -0500
committerMartin Schwidefsky <schwidefsky@de.ibm.com>2013-02-14 09:55:17 -0500
commitbe4904e5039a769f84f933bacce85c5e8ddd90a7 (patch)
tree794991a4c64ebac62a7d27552894e317fec97e0f /drivers/s390
parent53923354d69e4748506bfee932b7c6b309a15c21 (diff)
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: Stefan Weinhuber <wein@de.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Diffstat (limited to 'drivers/s390')
-rw-r--r--drivers/s390/block/dasd.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/s390/block/dasd.c b/drivers/s390/block/dasd.c
index e1d96344d733..f1b7fdc58a5f 100644
--- a/drivers/s390/block/dasd.c
+++ b/drivers/s390/block/dasd.c
@@ -3042,12 +3042,15 @@ void dasd_generic_remove(struct ccw_device *cdev)
3042 cdev->handler = NULL; 3042 cdev->handler = NULL;
3043 3043
3044 device = dasd_device_from_cdev(cdev); 3044 device = dasd_device_from_cdev(cdev);
3045 if (IS_ERR(device)) 3045 if (IS_ERR(device)) {
3046 dasd_remove_sysfs_files(cdev);
3046 return; 3047 return;
3048 }
3047 if (test_and_set_bit(DASD_FLAG_OFFLINE, &device->flags) && 3049 if (test_and_set_bit(DASD_FLAG_OFFLINE, &device->flags) &&
3048 !test_bit(DASD_FLAG_SAFE_OFFLINE_RUNNING, &device->flags)) { 3050 !test_bit(DASD_FLAG_SAFE_OFFLINE_RUNNING, &device->flags)) {
3049 /* Already doing offline processing */ 3051 /* Already doing offline processing */
3050 dasd_put_device(device); 3052 dasd_put_device(device);
3053 dasd_remove_sysfs_files(cdev);
3051 return; 3054 return;
3052 } 3055 }
3053 /* 3056 /*