>On Thu, 15 Nov 2012 16:46:54 +0800 majianpeng <majianpeng@xxxxxxxxx> wrote: > >> Because dm-raid call md_stop to clear up,but md_stop can't clear up completely. >> So add a new func to do. >> >> Jianpeng Ma (3): >> md:Add a func 'dm_md_stop' for dm-raid to clear up md resource. >> dm: When stoping dm-raid, it call dm_md_stop rather than md_stop to >> do clear-up work. >> md: Remove EXPORT_SYMBOL_GPL(md_stop). >> >> drivers/md/dm-raid.c | 4 ++-- >> drivers/md/md.c | 10 +++++++++- >> drivers/md/md.h | 1 + >> 3 files changed, 12 insertions(+), 3 deletions(-) >> > >You don't really need 3 patches for this one little change. > >I've applied the following. > >Thanks for the report. > >NeilBrown > >From 4ba69e1a88480249918ed2df8be0896be6ba7952 Mon Sep 17 00:00:00 2001 >From: NeilBrown <neilb@xxxxxxx> >Date: Mon, 19 Nov 2012 10:47:48 +1100 >Subject: [PATCH] md: make sure everything is freed when dm-raid stops an > array. > >md_stop() would stop an array, but not free various attached >data structures. >For internal arrays, these are freed later in do_md_stop() or >mddev_put(), but they don't apply for dm-raid arrays. >So get md_stop() to free them, and only all it from dm-raid. >For internal arrays we now call __md_stop. > >Reported-by: majianpeng <majianpeng@xxxxxxxxx> >Signed-off-by: NeilBrown <neilb@xxxxxxx> > >diff --git a/drivers/md/md.c b/drivers/md/md.c >index 98e1484..71df3c2 100644 >--- a/drivers/md/md.c >+++ b/drivers/md/md.c >@@ -5294,7 +5294,7 @@ void md_stop_writes(struct mddev *mddev) > } > EXPORT_SYMBOL_GPL(md_stop_writes); > >-void md_stop(struct mddev *mddev) >+void __md_stop(struct mddev *mddev) > { > mddev->ready = 0; > mddev->pers->stop(mddev); >@@ -5304,6 +5304,18 @@ void md_stop(struct mddev *mddev) > mddev->pers = NULL; > clear_bit(MD_RECOVERY_FROZEN, &mddev->recovery); > } >+ >+void md_stop(struct mddev *mddev) >+{ >+ /* stop the array and free an attached data structures. >+ * This is called from dm-raid >+ */ >+ __md_stop(mddev); >+ bitmap_destroy(mddev); >+ if (mddev->bio_set) >+ bioset_free(mddev->bio_set); >+} >+ > EXPORT_SYMBOL_GPL(md_stop); > > static int md_set_readonly(struct mddev *mddev, struct block_device *bdev) >@@ -5364,7 +5376,7 @@ static int do_md_stop(struct mddev * mddev, int mode, > set_disk_ro(disk, 0); > > __md_stop_writes(mddev); >- md_stop(mddev); >+ __md_stop(mddev); > mddev->queue->merge_bvec_fn = NULL; > mddev->queue->backing_dev_info.congested_fn = NULL; > > Thanks! Jianpeng?韬{.n?????%??檩??w?{.n???{炳盯w???塄}?财??j:+v??????2??璀??摺?囤??z夸z罐?+?????w棹f