From: Adrian Bunk <bunk@stusta.de>
To: Neil Brown <neilb@suse.de>, Andrew Morton <akpm@osdl.org>
Cc: matteo brancaleoni <mbrancaleoni@gmail.com>,
linux-kernel@vger.kernel.org
Subject: Re: Bio & Biovec-1 increasing cache size, never freed during disk IO
Date: Wed, 8 Mar 2006 22:57:49 +0100 [thread overview]
Message-ID: <20060308215749.GO4006@stusta.de> (raw)
In-Reply-To: <17414.36065.898271.383401@cse.unsw.edu.au>
On Thu, Mar 02, 2006 at 05:12:49PM +1100, Neil Brown wrote:
> On Wednesday March 1, mbrancaleoni@gmail.com wrote:
> > Hi Neil.
> >
> > unfortunately the patch does nothing, the problem persists.
> > Tested with 2.6.16-rc5.
> > (I've double checked if the patch was applied correctly)
> >
> > Can I do anything to be of some more help?
>
> Yes, try another patch. :-) and tell me if you have CONFIG_DEBUG_SLAB
> set... there was another use-after-free bug which CONFIG_DEBUG_SLAB
> would have made worse.
>
> This patch should fix it all up.
This patch seems to be 2.6.16 stuff?
> Thanks again,
> NeilBrown
>
>
> Signed-off-by: Neil Brown <neilb@suse.de>
>
> ### Diffstat output
> ./drivers/md/raid1.c | 13 ++++++++-----
> 1 file changed, 8 insertions(+), 5 deletions(-)
>
> diff ./drivers/md/raid1.c~current~ ./drivers/md/raid1.c
> --- ./drivers/md/raid1.c~current~ 2006-02-27 11:52:18.000000000 +1100
> +++ ./drivers/md/raid1.c 2006-03-01 10:44:49.000000000 +1100
> @@ -306,6 +306,7 @@ static int raid1_end_write_request(struc
> r1bio_t * r1_bio = (r1bio_t *)(bio->bi_private);
> int mirror, behind = test_bit(R1BIO_BehindIO, &r1_bio->state);
> conf_t *conf = mddev_to_conf(r1_bio->mddev);
> + struct bio *to_put = NULL;
>
> if (bio->bi_size)
> return 1;
> @@ -323,6 +324,7 @@ static int raid1_end_write_request(struc
> * this branch is our 'one mirror IO has finished' event handler:
> */
> r1_bio->bios[mirror] = NULL;
> + to_put = bio;
> if (!uptodate) {
> md_error(r1_bio->mddev, conf->mirrors[mirror].rdev);
> /* an I/O failed, we can't clear the bitmap */
> @@ -375,7 +377,7 @@ static int raid1_end_write_request(struc
> /* Don't dec_pending yet, we want to hold
> * the reference over the retry
> */
> - return 0;
> + goto out;
> }
> if (test_bit(R1BIO_BehindIO, &r1_bio->state)) {
> /* free extra copy of the data pages */
> @@ -392,10 +394,11 @@ static int raid1_end_write_request(struc
> raid_end_bio_io(r1_bio);
> }
>
> - if (r1_bio->bios[mirror]==NULL)
> - bio_put(bio);
> -
> rdev_dec_pending(conf->mirrors[mirror].rdev, conf->mddev);
> + out:
> + if (to_put)
> + bio_put(to_put);
> +
> return 0;
> }
>
> @@ -857,7 +860,7 @@ static int make_request(request_queue_t
> atomic_set(&r1_bio->remaining, 0);
> atomic_set(&r1_bio->behind_remaining, 0);
>
> - do_barriers = bio->bi_rw & BIO_RW_BARRIER;
> + do_barriers = bio_barrier(bio);
> if (do_barriers)
> set_bit(R1BIO_Barrier, &r1_bio->state);
>
> -
> To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at http://vger.kernel.org/majordomo-info.html
> Please read the FAQ at http://www.tux.org/lkml/
cu
Adrian
--
"Is there not promise of rain?" Ling Tan asked suddenly out
of the darkness. There had been need of rain for many days.
"Only a promise," Lao Er said.
Pearl S. Buck - Dragon Seed
prev parent reply other threads:[~2006-03-08 21:57 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-02-25 20:45 Bio & Biovec-1 increasing cache size, never freed during disk IO matteo brancaleoni
2006-02-27 20:38 ` matteo brancaleoni
2006-02-27 22:46 ` Neil Brown
2006-02-28 15:05 ` matteo brancaleoni
2006-02-28 23:35 ` Neil Brown
2006-03-01 10:46 ` matteo brancaleoni
2006-03-02 6:12 ` Neil Brown
2006-03-02 8:19 ` matteo brancaleoni
2006-03-02 8:58 ` matteo brancaleoni
2006-03-08 21:57 ` Adrian Bunk [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20060308215749.GO4006@stusta.de \
--to=bunk@stusta.de \
--cc=akpm@osdl.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mbrancaleoni@gmail.com \
--cc=neilb@suse.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.