From: Maneesh Soni <maneesh@in.ibm.com>
To: Steven Rostedt <rostedt@goodmis.org>
Cc: "Duetsch, Thomas LDE1" <thomas.duetsch@siemens.com>,
linux-kernel@vger.kernel.org, mingo@elte.hu,
Patrick Mochel <mochel@osdl.org>, Andrew Morton <akpm@osdl.org>
Subject: Re: [SYSFS] Kernel Null pointer dereference in sysfs_readdir()
Date: Thu, 13 Jul 2006 02:09:35 +0530 [thread overview]
Message-ID: <20060712203935.GA25484@in.ibm.com> (raw)
In-Reply-To: <1152736118.13382.6.camel@localhost.localdomain>
On Wed, Jul 12, 2006 at 04:28:38PM -0400, Steven Rostedt wrote:
> On Thu, 2006-07-13 at 01:27 +0530, Maneesh Soni wrote:
>
> >
> > sysfs_attach_attr() is called from sysfs_lookup() only, and which in turn
> > is called under parent inode's i_mutex from VFS layer.
>
> Ah, I didn't see the parent mutex lock.
>
> Does sysfs support hard links? Where an inode may belong to two
> different dentrys?
>
No, only symbolic links are supported.
> >
> > But you did help in spotting a bug which could happen like this
> >
> > i_mutext held
> > sysfs_lookup()
> > -->sysfs_attach_attr()
> > --> sysfs_create() fails
> > --> sd->s_dentry has a NULL d_inode
> > --> sysfs_put() frees the sysfs_dirent
> > --> error returned to lookup
> > i_mutex released
> >
> > But the sysfs_dirent with NULL d_inode is never unlinked from
> > the parent sysfs_dirent. And later on this happens
>
> But doesn't this only happen in case of no memory?
>
Right, but this is a bug anyway.
> Thomas, is the system running low on memory?
>
> >
> > vfs_readdir()
> > i_mutex held
> > -->sysfs_readdir()
> > --> trips on the freed sysfs_dirent with NULL inode.
> >
> > I am not sure if it is possible for other thread to see the freed
> > sysfs_dirent and trip at sd->s_dentry->d_inode but the sysfs_dirent
> > should have been unlinked from the parent sysfs_dirent's s_children list.
> >
> > > Now the question is, is it safe to add the test for s_dentry->d_inode too.
> > > I ask this because the s_dentry is in the process of being filled, and
> > > I don't know what effect this will have on what readdir wants. I guess
> > > it may be safe, so I'm giving this patch:
> > >
> > > -- Steve
> > >
> > >
> > > Description:
> > >
> > > In the process of creating a sysfs attribute, we can have a state
> > > where the sysfs descriptor can have a dentry with a NULL inode.
> > >
> > > Signed-off-by: Steven Rostedt <rostedt@goodmis.org>
> > >
> > > Index: linux-2.6.18-rc1/fs/sysfs/dir.c
> > > ===================================================================
> > > --- linux-2.6.18-rc1.orig/fs/sysfs/dir.c 2006-07-12 09:43:10.000000000 -0400
> > > +++ linux-2.6.18-rc1/fs/sysfs/dir.c 2006-07-12 10:01:18.000000000 -0400
> > > @@ -445,7 +445,7 @@ static int sysfs_readdir(struct file * f
> > >
> > > name = sysfs_get_name(next);
> > > len = strlen(name);
> > > - if (next->s_dentry)
> > > + if (next->s_dentry && next->s_dentry->d_inode)
> > > ino = next->s_dentry->d_inode->i_ino;
> > > else
> > > ino = iunique(sysfs_sb, 2);
> > >
> >
> > I think this patch only fixes the sympton. I have tried to keep the
> > assumption of no negative dentries (dentries with NULL d_inode) valid
> > in sysfs. So, this does indicate a bug.
>
> Something else that might help is knowing what the other tasks where
> doing at the time. Thomas, do you also have the task dump? You can
> send that to me offline if you like.
>
yup... please cc me also.
thanks
Maneesh
next prev parent reply other threads:[~2006-07-12 20:39 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-07-12 11:35 [SYSFS] Kernel Null pointer dereference in sysfs_readdir() Duetsch, Thomas LDE1
2006-07-12 12:06 ` Steven Rostedt
2006-07-12 12:39 ` AW: " Duetsch, Thomas LDE1
2006-07-12 14:06 ` Steven Rostedt
2006-07-12 19:57 ` Maneesh Soni
2006-07-12 20:28 ` Steven Rostedt
2006-07-12 20:39 ` Maneesh Soni [this message]
2006-07-13 2:59 ` Steven Rostedt
2006-07-12 19:58 ` Maneesh Soni
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=20060712203935.GA25484@in.ibm.com \
--to=maneesh@in.ibm.com \
--cc=akpm@osdl.org \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@elte.hu \
--cc=mochel@osdl.org \
--cc=rostedt@goodmis.org \
--cc=thomas.duetsch@siemens.com \
/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