summaryrefslogtreecommitdiffstats
path: root/drivers/md/linear.c
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2010-05-17 03:27:00 +0200
committerNeilBrown <neilb@suse.de>2010-05-17 06:38:18 +0200
commitef2f80ff7325b2c1888ff02ead28957b5840bf51 (patch)
treef7d4eb0a1816c8a608ba61a9368203d7b0ac4978 /drivers/md/linear.c
parentmd: set mddev readonly flag on blkdev BLKROSET ioctl (diff)
downloadlinux-ef2f80ff7325b2c1888ff02ead28957b5840bf51.tar.xz
linux-ef2f80ff7325b2c1888ff02ead28957b5840bf51.zip
md/linear: avoid possible oops and array stop
Since commit ef286f6fa673cd7fb367e1b145069d8dbfcc6081 it has been important that each personality clears ->private in the ->stop() function, or sets it to a attribute group to be removed. linear.c doesn't. This can sometimes lead to an oops, though it doesn't always. Suitable for 2.6.33-stable and 2.6.34. Signed-off-by: NeilBrown <neilb@suse.de> Cc: stable@kernel.org
Diffstat (limited to 'drivers/md/linear.c')
-rw-r--r--drivers/md/linear.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/md/linear.c b/drivers/md/linear.c
index bb2a23159b21..9db8ee0614a4 100644
--- a/drivers/md/linear.c
+++ b/drivers/md/linear.c
@@ -281,6 +281,7 @@ static int linear_stop (mddev_t *mddev)
rcu_barrier();
blk_sync_queue(mddev->queue); /* the unplug fn references 'conf'*/
kfree(conf);
+ mddev->private = NULL;
return 0;
}