[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <1262822158.4251.179.camel@localhost>
Date: Wed, 06 Jan 2010 18:55:58 -0500
From: Trond Myklebust <trond.myklebust@....uio.no>
To: Andrew Morton <akpm@...ux-foundation.org>
Cc: OGAWA Hirofumi <hirofumi@...l.parknet.co.jp>,
Marvin <marvin24@....de>,
Linux Kernel Mailing List <linux-kernel@...r.kernel.org>,
linux-nfs@...r.kernel.org
Subject: Re: vfs related crash in 2.6.33-rc2
On Wed, 2010-01-06 at 15:41 -0800, Andrew Morton wrote:
> On Thu, 31 Dec 2009 05:59:32 +0900
> OGAWA Hirofumi <hirofumi@...l.parknet.co.jp> wrote:
>
> > Marvin <marvin24@....de> writes:
> >
> > >> Marvin <marvin24@....de> writes:
> > >> > Hi,
> > >> >
> > >> > I'm getting a lot of these:
> > >> >
> > >> > kernel: general protection fault: 0000 [#1] SMP
> > >> > kernel: last sysfs file: /sys/devices/pci0000:00/0000:00:18.3/modalias
> > >> > kernel: CPU 0
> > >> > kernel: Pid: 12177, comm: packagekitd Not tainted 2.6.33-rc2 #1
> > >> > ...
> > >> >
> > >> > filesystem is ext4 (in case it matters).
> > >>
> > >> BTW, are you using nfs client on this machine?
> > >>
> > >
> > > um - yes, now that I think about it... I killed a nfs umount process (because of an
> > > offline server) shortly before the oopses started to fire.
> >
> > OK. Probably, this oops would be same with one which happened on my
> > machine recently. That path in patch corrupts dcache hash, so it can be
> > the cause of strange behavior or oops on dcache hash.
> >
> > If so, the attached patch would fix it.
> >
> > Thanks.
> > --
> > OGAWA Hirofumi <hirofumi@...l.parknet.co.jp>
> >
> >
> > Recent change is missing to update "rehash". With that change, it will
> > become the cause of adding dentry to hash twice.
> >
> > This explains the reason of Oops (dereference the freed dentry in
> > __d_lookup()) on my machine.
> >
> > Signed-off-by: OGAWA Hirofumi <hirofumi@...l.parknet.co.jp>
> > ---
> >
> > fs/nfs/dir.c | 1 +
> > 1 file changed, 1 insertion(+)
> >
> > diff -puN fs/nfs/dir.c~nfs-d_rehash-fix fs/nfs/dir.c
> > --- linux-2.6/fs/nfs/dir.c~nfs-d_rehash-fix 2009-12-28 06:18:09.000000000 +0900
> > +++ linux-2.6-hirofumi/fs/nfs/dir.c 2009-12-28 06:18:16.000000000 +0900
> > @@ -1615,6 +1615,7 @@ static int nfs_rename(struct inode *old_
> > goto out;
> >
> > new_dentry = dentry;
> > + rehash = NULL;
> > new_inode = NULL;
> > }
> > }
>
> Guys, what's the status of this fix? Did Marvin have a chance to test
> it? Are the NFS developers aware of it?
>
> Thanks.
>
Sorry for the delay. The above fix looks correct to me, but I too would
like a confirmation that it fixes the Oops before I push it to Linus.
In the meantime, I've committed it to my linux-next branch.
Cheers
Trond
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists