From: Jens Axboe <jens.axboe@oracle.com>
To: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Linux Kernel <linux-kernel@vger.kernel.org>
Subject: Re: [GIT PULL] block fixes for 2.6.32-rc
Date: Wed, 28 Oct 2009 20:10:04 +0100 [thread overview]
Message-ID: <20091028191004.GU10727@kernel.dk> (raw)
In-Reply-To: <alpine.LFD.2.01.0910281157160.31845@localhost.localdomain>
On Wed, Oct 28 2009, Linus Torvalds wrote:
>
>
> On Wed, 28 Oct 2009, Jens Axboe wrote:
> >
> > Neil Brown (1):
> > block: use after free bug in __blkdev_get
> >
> > diff --git a/fs/block_dev.c b/fs/block_dev.c
> > index 9cf4b92..8bed055 100644
> > --- a/fs/block_dev.c
> > +++ b/fs/block_dev.c
> > @@ -1248,8 +1248,8 @@ static int __blkdev_get(struct block_device *bdev, fmode_t mode, int for_part)
> > bd_set_size(bdev, (loff_t)bdev->bd_part->nr_sects << 9);
> > }
> > } else {
> > - put_disk(disk);
> > module_put(disk->fops->owner);
> > + put_disk(disk);
> > disk = NULL;
> > if (bdev->bd_contains == bdev) {
> > if (bdev->bd_disk->fops->open) {
>
> Is this really right? You do the module-put while the disk is still
> available..
>
> I get the feeling that it might have been better to do
>
> struct module *mod = disk->fops->owner;
> put_disk(disk);
> module_put(mod);
>
> instead, which tries to make sure that the module is put only after we've
> gotten rid of the disk entirely.
>
> But I dunno. Maybe there is some reason why it's safe either way. You're
> sure the kobject_put() in put_disk will never call to the module?
Hmm good point. The general use case in block_dev.c is indeed to put the
module after the disk, which does seem a bit backwards (at least
logically). I'd say pull the patch since it fixes Neil's problem and
follows the general pattern, then I'll investigate whether that use
pattern is indeed safe. It wont make things worse and the current usage
being fixed is definitely wrong.
--
Jens Axboe
next prev parent reply other threads:[~2009-10-28 19:10 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-10-28 18:51 [GIT PULL] block fixes for 2.6.32-rc Jens Axboe
2009-10-28 19:00 ` Linus Torvalds
2009-10-28 19:10 ` Jens Axboe [this message]
2009-10-28 19:33 ` Jens Axboe
-- strict thread matches above, loose matches on Subject: below --
2009-11-03 19:40 Jens Axboe
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=20091028191004.GU10727@kernel.dk \
--to=jens.axboe@oracle.com \
--cc=linux-kernel@vger.kernel.org \
--cc=torvalds@linux-foundation.org \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox