diff options
| -rw-r--r-- | drivers/md/faulty.c | 8 | ||||
| -rw-r--r-- | drivers/md/linear.c | 9 | ||||
| -rw-r--r-- | drivers/md/md.c | 10 | ||||
| -rw-r--r-- | drivers/md/md.h | 2 | ||||
| -rw-r--r-- | drivers/md/multipath.c | 10 | ||||
| -rw-r--r-- | drivers/md/raid0.c | 12 | ||||
| -rw-r--r-- | drivers/md/raid1.c | 14 | ||||
| -rw-r--r-- | drivers/md/raid10.c | 8 | ||||
| -rw-r--r-- | drivers/md/raid5.c | 12 |
9 files changed, 35 insertions, 50 deletions
diff --git a/drivers/md/faulty.c b/drivers/md/faulty.c index e8b4574956c7..1277eb26b58a 100644 --- a/drivers/md/faulty.c +++ b/drivers/md/faulty.c | |||
| @@ -332,13 +332,11 @@ static int run(struct mddev *mddev) | |||
| 332 | return 0; | 332 | return 0; |
| 333 | } | 333 | } |
| 334 | 334 | ||
| 335 | static int stop(struct mddev *mddev) | 335 | static void faulty_free(struct mddev *mddev, void *priv) |
| 336 | { | 336 | { |
| 337 | struct faulty_conf *conf = mddev->private; | 337 | struct faulty_conf *conf = priv; |
| 338 | 338 | ||
| 339 | kfree(conf); | 339 | kfree(conf); |
| 340 | mddev->private = NULL; | ||
| 341 | return 0; | ||
| 342 | } | 340 | } |
| 343 | 341 | ||
| 344 | static struct md_personality faulty_personality = | 342 | static struct md_personality faulty_personality = |
| @@ -348,7 +346,7 @@ static struct md_personality faulty_personality = | |||
| 348 | .owner = THIS_MODULE, | 346 | .owner = THIS_MODULE, |
| 349 | .make_request = make_request, | 347 | .make_request = make_request, |
| 350 | .run = run, | 348 | .run = run, |
| 351 | .stop = stop, | 349 | .free = faulty_free, |
| 352 | .status = status, | 350 | .status = status, |
| 353 | .check_reshape = reshape, | 351 | .check_reshape = reshape, |
| 354 | .size = faulty_size, | 352 | .size = faulty_size, |
diff --git a/drivers/md/linear.c b/drivers/md/linear.c index c201555b9c6c..fa7d577f3d12 100644 --- a/drivers/md/linear.c +++ b/drivers/md/linear.c | |||
| @@ -249,14 +249,11 @@ static int linear_add(struct mddev *mddev, struct md_rdev *rdev) | |||
| 249 | return 0; | 249 | return 0; |
| 250 | } | 250 | } |
| 251 | 251 | ||
| 252 | static int linear_stop (struct mddev *mddev) | 252 | static void linear_free(struct mddev *mddev, void *priv) |
| 253 | { | 253 | { |
| 254 | struct linear_conf *conf = mddev->private; | 254 | struct linear_conf *conf = priv; |
| 255 | 255 | ||
| 256 | kfree(conf); | 256 | kfree(conf); |
| 257 | mddev->private = NULL; | ||
| 258 | |||
| 259 | return 0; | ||
| 260 | } | 257 | } |
| 261 | 258 | ||
| 262 | static void linear_make_request(struct mddev *mddev, struct bio *bio) | 259 | static void linear_make_request(struct mddev *mddev, struct bio *bio) |
| @@ -335,7 +332,7 @@ static struct md_personality linear_personality = | |||
| 335 | .owner = THIS_MODULE, | 332 | .owner = THIS_MODULE, |
| 336 | .make_request = linear_make_request, | 333 | .make_request = linear_make_request, |
| 337 | .run = linear_run, | 334 | .run = linear_run, |
| 338 | .stop = linear_stop, | 335 | .free = linear_free, |
| 339 | .status = linear_status, | 336 | .status = linear_status, |
| 340 | .hot_add_disk = linear_add, | 337 | .hot_add_disk = linear_add, |
| 341 | .size = linear_size, | 338 | .size = linear_size, |
diff --git a/drivers/md/md.c b/drivers/md/md.c index 58f140bef999..2920fd004865 100644 --- a/drivers/md/md.c +++ b/drivers/md/md.c | |||
| @@ -293,8 +293,8 @@ static void md_make_request(struct request_queue *q, struct bio *bio) | |||
| 293 | /* mddev_suspend makes sure no new requests are submitted | 293 | /* mddev_suspend makes sure no new requests are submitted |
| 294 | * to the device, and that any requests that have been submitted | 294 | * to the device, and that any requests that have been submitted |
| 295 | * are completely handled. | 295 | * are completely handled. |
| 296 | * Once ->stop is called and completes, the module will be completely | 296 | * Once mddev_detach() is called and completes, the module will be |
| 297 | * unused. | 297 | * completely unused. |
| 298 | */ | 298 | */ |
| 299 | void mddev_suspend(struct mddev *mddev) | 299 | void mddev_suspend(struct mddev *mddev) |
| 300 | { | 300 | { |
| @@ -3374,7 +3374,7 @@ level_store(struct mddev *mddev, const char *buf, size_t len) | |||
| 3374 | /* Looks like we have a winner */ | 3374 | /* Looks like we have a winner */ |
| 3375 | mddev_suspend(mddev); | 3375 | mddev_suspend(mddev); |
| 3376 | mddev_detach(mddev); | 3376 | mddev_detach(mddev); |
| 3377 | mddev->pers->stop(mddev); | 3377 | mddev->pers->free(mddev, mddev->private); |
| 3378 | 3378 | ||
| 3379 | if (mddev->pers->sync_request == NULL && | 3379 | if (mddev->pers->sync_request == NULL && |
| 3380 | pers->sync_request != NULL) { | 3380 | pers->sync_request != NULL) { |
| @@ -4940,7 +4940,7 @@ int md_run(struct mddev *mddev) | |||
| 4940 | } | 4940 | } |
| 4941 | if (err) { | 4941 | if (err) { |
| 4942 | mddev_detach(mddev); | 4942 | mddev_detach(mddev); |
| 4943 | mddev->pers->stop(mddev); | 4943 | mddev->pers->free(mddev, mddev->private); |
| 4944 | module_put(mddev->pers->owner); | 4944 | module_put(mddev->pers->owner); |
| 4945 | mddev->pers = NULL; | 4945 | mddev->pers = NULL; |
| 4946 | bitmap_destroy(mddev); | 4946 | bitmap_destroy(mddev); |
| @@ -5137,7 +5137,7 @@ static void __md_stop(struct mddev *mddev) | |||
| 5137 | { | 5137 | { |
| 5138 | mddev->ready = 0; | 5138 | mddev->ready = 0; |
| 5139 | mddev_detach(mddev); | 5139 | mddev_detach(mddev); |
| 5140 | mddev->pers->stop(mddev); | 5140 | mddev->pers->free(mddev, mddev->private); |
| 5141 | if (mddev->pers->sync_request && mddev->to_remove == NULL) | 5141 | if (mddev->pers->sync_request && mddev->to_remove == NULL) |
| 5142 | mddev->to_remove = &md_redundancy_group; | 5142 | mddev->to_remove = &md_redundancy_group; |
| 5143 | module_put(mddev->pers->owner); | 5143 | module_put(mddev->pers->owner); |
diff --git a/drivers/md/md.h b/drivers/md/md.h index bee5b852c33f..37e7c17e56a6 100644 --- a/drivers/md/md.h +++ b/drivers/md/md.h | |||
| @@ -465,7 +465,7 @@ struct md_personality | |||
| 465 | struct module *owner; | 465 | struct module *owner; |
| 466 | void (*make_request)(struct mddev *mddev, struct bio *bio); | 466 | void (*make_request)(struct mddev *mddev, struct bio *bio); |
| 467 | int (*run)(struct mddev *mddev); | 467 | int (*run)(struct mddev *mddev); |
| 468 | int (*stop)(struct mddev *mddev); | 468 | void (*free)(struct mddev *mddev, void *priv); |
| 469 | void (*status)(struct seq_file *seq, struct mddev *mddev); | 469 | void (*status)(struct seq_file *seq, struct mddev *mddev); |
| 470 | /* error_handler must set ->faulty and clear ->in_sync | 470 | /* error_handler must set ->faulty and clear ->in_sync |
| 471 | * if appropriate, and should abort recovery if needed | 471 | * if appropriate, and should abort recovery if needed |
diff --git a/drivers/md/multipath.c b/drivers/md/multipath.c index 9fe34453835b..ac3ede2bd00e 100644 --- a/drivers/md/multipath.c +++ b/drivers/md/multipath.c | |||
| @@ -399,7 +399,7 @@ static int multipath_run (struct mddev *mddev) | |||
| 399 | /* | 399 | /* |
| 400 | * copy the already verified devices into our private MULTIPATH | 400 | * copy the already verified devices into our private MULTIPATH |
| 401 | * bookkeeping area. [whatever we allocate in multipath_run(), | 401 | * bookkeeping area. [whatever we allocate in multipath_run(), |
| 402 | * should be freed in multipath_stop()] | 402 | * should be freed in multipath_free()] |
| 403 | */ | 403 | */ |
| 404 | 404 | ||
| 405 | conf = kzalloc(sizeof(struct mpconf), GFP_KERNEL); | 405 | conf = kzalloc(sizeof(struct mpconf), GFP_KERNEL); |
| @@ -500,15 +500,13 @@ out: | |||
| 500 | return -EIO; | 500 | return -EIO; |
| 501 | } | 501 | } |
| 502 | 502 | ||
| 503 | static int multipath_stop (struct mddev *mddev) | 503 | static void multipath_free(struct mddev *mddev, void *priv) |
| 504 | { | 504 | { |
| 505 | struct mpconf *conf = mddev->private; | 505 | struct mpconf *conf = priv; |
| 506 | 506 | ||
| 507 | mempool_destroy(conf->pool); | 507 | mempool_destroy(conf->pool); |
| 508 | kfree(conf->multipaths); | 508 | kfree(conf->multipaths); |
| 509 | kfree(conf); | 509 | kfree(conf); |
| 510 | mddev->private = NULL; | ||
| 511 | return 0; | ||
| 512 | } | 510 | } |
| 513 | 511 | ||
| 514 | static struct md_personality multipath_personality = | 512 | static struct md_personality multipath_personality = |
| @@ -518,7 +516,7 @@ static struct md_personality multipath_personality = | |||
| 518 | .owner = THIS_MODULE, | 516 | .owner = THIS_MODULE, |
| 519 | .make_request = multipath_make_request, | 517 | .make_request = multipath_make_request, |
| 520 | .run = multipath_run, | 518 | .run = multipath_run, |
| 521 | .stop = multipath_stop, | 519 | .free = multipath_free, |
| 522 | .status = multipath_status, | 520 | .status = multipath_status, |
| 523 | .error_handler = multipath_error, | 521 | .error_handler = multipath_error, |
| 524 | .hot_add_disk = multipath_add_disk, | 522 | .hot_add_disk = multipath_add_disk, |
diff --git a/drivers/md/raid0.c b/drivers/md/raid0.c index 01dfca94b663..a13f738a7b39 100644 --- a/drivers/md/raid0.c +++ b/drivers/md/raid0.c | |||
| @@ -415,7 +415,7 @@ static sector_t raid0_size(struct mddev *mddev, sector_t sectors, int raid_disks | |||
| 415 | return array_sectors; | 415 | return array_sectors; |
| 416 | } | 416 | } |
| 417 | 417 | ||
| 418 | static int raid0_stop(struct mddev *mddev); | 418 | static void raid0_free(struct mddev *mddev, void *priv); |
| 419 | 419 | ||
| 420 | static int raid0_run(struct mddev *mddev) | 420 | static int raid0_run(struct mddev *mddev) |
| 421 | { | 421 | { |
| @@ -468,20 +468,18 @@ static int raid0_run(struct mddev *mddev) | |||
| 468 | 468 | ||
| 469 | ret = md_integrity_register(mddev); | 469 | ret = md_integrity_register(mddev); |
| 470 | if (ret) | 470 | if (ret) |
| 471 | raid0_stop(mddev); | 471 | raid0_free(mddev, conf); |
| 472 | 472 | ||
| 473 | return ret; | 473 | return ret; |
| 474 | } | 474 | } |
| 475 | 475 | ||
| 476 | static int raid0_stop(struct mddev *mddev) | 476 | static void raid0_free(struct mddev *mddev, void *priv) |
| 477 | { | 477 | { |
| 478 | struct r0conf *conf = mddev->private; | 478 | struct r0conf *conf = priv; |
| 479 | 479 | ||
| 480 | kfree(conf->strip_zone); | 480 | kfree(conf->strip_zone); |
| 481 | kfree(conf->devlist); | 481 | kfree(conf->devlist); |
| 482 | kfree(conf); | 482 | kfree(conf); |
| 483 | mddev->private = NULL; | ||
| 484 | return 0; | ||
| 485 | } | 483 | } |
| 486 | 484 | ||
| 487 | /* | 485 | /* |
| @@ -715,7 +713,7 @@ static struct md_personality raid0_personality= | |||
| 715 | .owner = THIS_MODULE, | 713 | .owner = THIS_MODULE, |
| 716 | .make_request = raid0_make_request, | 714 | .make_request = raid0_make_request, |
| 717 | .run = raid0_run, | 715 | .run = raid0_run, |
| 718 | .stop = raid0_stop, | 716 | .free = raid0_free, |
| 719 | .status = raid0_status, | 717 | .status = raid0_status, |
| 720 | .size = raid0_size, | 718 | .size = raid0_size, |
| 721 | .takeover = raid0_takeover, | 719 | .takeover = raid0_takeover, |
diff --git a/drivers/md/raid1.c b/drivers/md/raid1.c index fccea0b39808..5dd0c2e59ab9 100644 --- a/drivers/md/raid1.c +++ b/drivers/md/raid1.c | |||
| @@ -2872,7 +2872,7 @@ static struct r1conf *setup_conf(struct mddev *mddev) | |||
| 2872 | return ERR_PTR(err); | 2872 | return ERR_PTR(err); |
| 2873 | } | 2873 | } |
| 2874 | 2874 | ||
| 2875 | static int stop(struct mddev *mddev); | 2875 | static void raid1_free(struct mddev *mddev, void *priv); |
| 2876 | static int run(struct mddev *mddev) | 2876 | static int run(struct mddev *mddev) |
| 2877 | { | 2877 | { |
| 2878 | struct r1conf *conf; | 2878 | struct r1conf *conf; |
| @@ -2894,7 +2894,7 @@ static int run(struct mddev *mddev) | |||
| 2894 | /* | 2894 | /* |
| 2895 | * copy the already verified devices into our private RAID1 | 2895 | * copy the already verified devices into our private RAID1 |
| 2896 | * bookkeeping area. [whatever we allocate in run(), | 2896 | * bookkeeping area. [whatever we allocate in run(), |
| 2897 | * should be freed in stop()] | 2897 | * should be freed in raid1_free()] |
| 2898 | */ | 2898 | */ |
| 2899 | if (mddev->private == NULL) | 2899 | if (mddev->private == NULL) |
| 2900 | conf = setup_conf(mddev); | 2900 | conf = setup_conf(mddev); |
| @@ -2956,14 +2956,14 @@ static int run(struct mddev *mddev) | |||
| 2956 | ret = md_integrity_register(mddev); | 2956 | ret = md_integrity_register(mddev); |
| 2957 | if (ret) { | 2957 | if (ret) { |
| 2958 | md_unregister_thread(&mddev->thread); | 2958 | md_unregister_thread(&mddev->thread); |
| 2959 | stop(mddev); | 2959 | raid1_free(mddev, conf); |
| 2960 | } | 2960 | } |
| 2961 | return ret; | 2961 | return ret; |
| 2962 | } | 2962 | } |
| 2963 | 2963 | ||
| 2964 | static int stop(struct mddev *mddev) | 2964 | static void raid1_free(struct mddev *mddev, void *priv) |
| 2965 | { | 2965 | { |
| 2966 | struct r1conf *conf = mddev->private; | 2966 | struct r1conf *conf = priv; |
| 2967 | 2967 | ||
| 2968 | if (conf->r1bio_pool) | 2968 | if (conf->r1bio_pool) |
| 2969 | mempool_destroy(conf->r1bio_pool); | 2969 | mempool_destroy(conf->r1bio_pool); |
| @@ -2971,8 +2971,6 @@ static int stop(struct mddev *mddev) | |||
| 2971 | safe_put_page(conf->tmppage); | 2971 | safe_put_page(conf->tmppage); |
| 2972 | kfree(conf->poolinfo); | 2972 | kfree(conf->poolinfo); |
| 2973 | kfree(conf); | 2973 | kfree(conf); |
| 2974 | mddev->private = NULL; | ||
| 2975 | return 0; | ||
| 2976 | } | 2974 | } |
| 2977 | 2975 | ||
| 2978 | static int raid1_resize(struct mddev *mddev, sector_t sectors) | 2976 | static int raid1_resize(struct mddev *mddev, sector_t sectors) |
| @@ -3155,7 +3153,7 @@ static struct md_personality raid1_personality = | |||
| 3155 | .owner = THIS_MODULE, | 3153 | .owner = THIS_MODULE, |
| 3156 | .make_request = make_request, | 3154 | .make_request = make_request, |
| 3157 | .run = run, | 3155 | .run = run, |
| 3158 | .stop = stop, | 3156 | .free = raid1_free, |
| 3159 | .status = status, | 3157 | .status = status, |
| 3160 | .error_handler = error, | 3158 | .error_handler = error, |
| 3161 | .hot_add_disk = raid1_add_disk, | 3159 | .hot_add_disk = raid1_add_disk, |
diff --git a/drivers/md/raid10.c b/drivers/md/raid10.c index 654fdae906aa..d1203cddb024 100644 --- a/drivers/md/raid10.c +++ b/drivers/md/raid10.c | |||
| @@ -3798,9 +3798,9 @@ out: | |||
| 3798 | return -EIO; | 3798 | return -EIO; |
| 3799 | } | 3799 | } |
| 3800 | 3800 | ||
| 3801 | static int stop(struct mddev *mddev) | 3801 | static void raid10_free(struct mddev *mddev, void *priv) |
| 3802 | { | 3802 | { |
| 3803 | struct r10conf *conf = mddev->private; | 3803 | struct r10conf *conf = priv; |
| 3804 | 3804 | ||
| 3805 | if (conf->r10bio_pool) | 3805 | if (conf->r10bio_pool) |
| 3806 | mempool_destroy(conf->r10bio_pool); | 3806 | mempool_destroy(conf->r10bio_pool); |
| @@ -3809,8 +3809,6 @@ static int stop(struct mddev *mddev) | |||
| 3809 | kfree(conf->mirrors_old); | 3809 | kfree(conf->mirrors_old); |
| 3810 | kfree(conf->mirrors_new); | 3810 | kfree(conf->mirrors_new); |
| 3811 | kfree(conf); | 3811 | kfree(conf); |
| 3812 | mddev->private = NULL; | ||
| 3813 | return 0; | ||
| 3814 | } | 3812 | } |
| 3815 | 3813 | ||
| 3816 | static void raid10_quiesce(struct mddev *mddev, int state) | 3814 | static void raid10_quiesce(struct mddev *mddev, int state) |
| @@ -4692,7 +4690,7 @@ static struct md_personality raid10_personality = | |||
| 4692 | .owner = THIS_MODULE, | 4690 | .owner = THIS_MODULE, |
| 4693 | .make_request = make_request, | 4691 | .make_request = make_request, |
| 4694 | .run = run, | 4692 | .run = run, |
| 4695 | .stop = stop, | 4693 | .free = raid10_free, |
| 4696 | .status = status, | 4694 | .status = status, |
| 4697 | .error_handler = error, | 4695 | .error_handler = error, |
| 4698 | .hot_add_disk = raid10_add_disk, | 4696 | .hot_add_disk = raid10_add_disk, |
diff --git a/drivers/md/raid5.c b/drivers/md/raid5.c index 482526077647..dab908b2aa9a 100644 --- a/drivers/md/raid5.c +++ b/drivers/md/raid5.c | |||
| @@ -6313,14 +6313,12 @@ abort: | |||
| 6313 | return -EIO; | 6313 | return -EIO; |
| 6314 | } | 6314 | } |
| 6315 | 6315 | ||
| 6316 | static int stop(struct mddev *mddev) | 6316 | static void raid5_free(struct mddev *mddev, void *priv) |
| 6317 | { | 6317 | { |
| 6318 | struct r5conf *conf = mddev->private; | 6318 | struct r5conf *conf = priv; |
| 6319 | 6319 | ||
| 6320 | free_conf(conf); | 6320 | free_conf(conf); |
| 6321 | mddev->private = NULL; | ||
| 6322 | mddev->to_remove = &raid5_attrs_group; | 6321 | mddev->to_remove = &raid5_attrs_group; |
| 6323 | return 0; | ||
| 6324 | } | 6322 | } |
| 6325 | 6323 | ||
| 6326 | static void status(struct seq_file *seq, struct mddev *mddev) | 6324 | static void status(struct seq_file *seq, struct mddev *mddev) |
| @@ -7094,7 +7092,7 @@ static struct md_personality raid6_personality = | |||
| 7094 | .owner = THIS_MODULE, | 7092 | .owner = THIS_MODULE, |
| 7095 | .make_request = make_request, | 7093 | .make_request = make_request, |
| 7096 | .run = run, | 7094 | .run = run, |
| 7097 | .stop = stop, | 7095 | .free = raid5_free, |
| 7098 | .status = status, | 7096 | .status = status, |
| 7099 | .error_handler = error, | 7097 | .error_handler = error, |
| 7100 | .hot_add_disk = raid5_add_disk, | 7098 | .hot_add_disk = raid5_add_disk, |
| @@ -7118,7 +7116,7 @@ static struct md_personality raid5_personality = | |||
| 7118 | .owner = THIS_MODULE, | 7116 | .owner = THIS_MODULE, |
| 7119 | .make_request = make_request, | 7117 | .make_request = make_request, |
| 7120 | .run = run, | 7118 | .run = run, |
| 7121 | .stop = stop, | 7119 | .free = raid5_free, |
| 7122 | .status = status, | 7120 | .status = status, |
| 7123 | .error_handler = error, | 7121 | .error_handler = error, |
| 7124 | .hot_add_disk = raid5_add_disk, | 7122 | .hot_add_disk = raid5_add_disk, |
| @@ -7143,7 +7141,7 @@ static struct md_personality raid4_personality = | |||
| 7143 | .owner = THIS_MODULE, | 7141 | .owner = THIS_MODULE, |
| 7144 | .make_request = make_request, | 7142 | .make_request = make_request, |
| 7145 | .run = run, | 7143 | .run = run, |
| 7146 | .stop = stop, | 7144 | .free = raid5_free, |
| 7147 | .status = status, | 7145 | .status = status, |
| 7148 | .error_handler = error, | 7146 | .error_handler = error, |
| 7149 | .hot_add_disk = raid5_add_disk, | 7147 | .hot_add_disk = raid5_add_disk, |
