- To: "Jun'ichi Nomura" <j-nomura@xxxxxxxxxxxxx>
- Subject: Re: [dm-devel] [PATCH v2 02/14] dm: kill dm_rq_bio_destructor
- From: Kent Overstreet <koverstreet@xxxxxxxxxx>
- Date: Wed, 23 May 2012 17:39:16 -0700
- Cc: device-mapper development <dm-devel@xxxxxxxxxx>, linux-kernel@xxxxxxxxxxxxxxx, linux-bcache@xxxxxxxxxxxxxxx, linux-fsdevel@xxxxxxxxxxxxxxx, axboe@xxxxxxxxx, yehuda@xxxxxxxxxxxxxxx, mpatocka@xxxxxxxxxx, vgoyal@xxxxxxxxxx, bharrosh@xxxxxxxxxxx, tj@xxxxxxxxxx, sage@xxxxxxxxxxxx, agk@xxxxxxxxxx, drbd-dev@xxxxxxxxxxxxxxxx
- In-reply-to: <4FBD7E80.4020005@ce.jp.nec.com>
- User-agent: Mutt/1.5.21 (2010-09-15)
On Thu, May 24, 2012 at 09:19:12AM +0900, Jun'ichi Nomura wrote:
> Hi,
>
> On 05/24/12 09:02, Kent Overstreet wrote:
> > @@ -1438,15 +1439,6 @@ void dm_dispatch_request(struct request *rq)
> > }
> > EXPORT_SYMBOL_GPL(dm_dispatch_request);
> >
> > -static void dm_rq_bio_destructor(struct bio *bio)
> > -{
> > - struct dm_rq_clone_bio_info *info = bio->bi_private;
> > - struct mapped_device *md = info->tio->md;
> > -
> > - free_bio_info(info);
> > - bio_free(bio, md->bs);
> > -}
> > -
> > static int dm_rq_bio_constructor(struct bio *bio, struct bio *bio_orig,
> > void *data)
> > {
> > @@ -1461,7 +1453,6 @@ static int dm_rq_bio_constructor(struct bio *bio, struct bio *bio_orig,
> > info->tio = tio;
> > bio->bi_end_io = end_clone_bio;
> > bio->bi_private = info;
> > - bio->bi_destructor = dm_rq_bio_destructor;
>
> The destructor may also be called from blk_rq_unprep_clone(),
> which just puts bio.
> So this patch will introduce a memory leak.
Well, keeping around bi_destructor solely for that reason would be
pretty lousy. Can you come up with a better solution?
--
To unsubscribe from this list: send the line "unsubscribe linux-bcache" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
[Linux ARM Kernel]
[Linux ARM]
[Linux Omap]
[Fedora ARM]
[IETF Annouce]
[Security]
[Bugtraq]
[Linux]
[Linux OMAP]
[Linux MIPS]
[ECOS]
[Tools]
[DDR & Rambus]
[Asterisk Internet PBX]
[Linux API]
[Monitors]