From: Dave Hansen <haveblue@us.ibm.com>
To: Herbert Poetzl <herbert@13thfloor.at>
Cc: linux-fsdevel@vger.kernel.org, viro@ftp.linux.org.uk,
hch@infradead.org, trond.myklebust@fys.uio.no
Subject: Re: [RFC][PATCH 22/27] sys_mknodat(): elevate write count for vfs_mknod/create()
Date: Thu, 08 Jun 2006 08:23:22 -0700 [thread overview]
Message-ID: <1149780202.4097.62.camel@localhost.localdomain> (raw)
In-Reply-To: <20060608111652.GL11996@MAIL.13thfloor.at>
On Thu, 2006-06-08 at 13:16 +0200, Herbert Poetzl wrote:
> On Wed, Jun 07, 2006 at 05:10:35PM -0700, Dave Hansen wrote:
> > This takes care of all of the direct callers of vfs_mknod().
> > Since a few of these cases also handle normal file creation
> > as well, this also covers some calls to vfs_create().
> >
> > Signed-off-by: Dave Hansen <haveblue@us.ibm.com>
> > ---
> >
> > ipc/mqueue.c | 0
> > lxc-dave/fs/namei.c | 48 ++++++++++++++++++++++++++++----------------
> > lxc-dave/fs/nfsd/vfs.c | 4 +++
> > lxc-dave/net/unix/af_unix.c | 4 +++
> > 4 files changed, 39 insertions(+), 17 deletions(-)
> >
> > diff -puN fs/namei.c~elevate-writers-vfs_mknod-try2 fs/namei.c
> > --- lxc/fs/namei.c~elevate-writers-vfs_mknod-try2 2006-06-07 16:53:25.000000000 -0700
> > +++ lxc-dave/fs/namei.c 2006-06-07 16:53:25.000000000 -0700
> > @@ -1852,26 +1852,40 @@ asmlinkage long sys_mknodat(int dfd, con
> >
> > if (!IS_POSIXACL(nd.dentry->d_inode))
> > mode &= ~current->fs->umask;
> > - if (!IS_ERR(dentry)) {
> > - switch (mode & S_IFMT) {
> > - case 0: case S_IFREG:
> > - error = vfs_create(nd.dentry->d_inode,dentry,mode,&nd);
> > - break;
> > - case S_IFCHR: case S_IFBLK:
> > - error = vfs_mknod(nd.dentry->d_inode,dentry,mode,
> > - new_decode_dev(dev));
> > - break;
> > - case S_IFIFO: case S_IFSOCK:
> > - error = vfs_mknod(nd.dentry->d_inode,dentry,mode,0);
> > + if (IS_ERR(dentry))
> > + goto out_unlock;
> > + error = mnt_want_write(nd.mnt);
> > + if (error)
> > + goto out_dput;
> > + switch (mode & S_IFMT) {
> > + case 0: case S_IFREG:
> > + error = vfs_create(nd.dentry->d_inode,dentry,mode,&nd);
> > + break;
> > + case S_IFCHR: case S_IFBLK:
>
> hmm, could you outline some cases where the following
> fails, but the previous (above) check succeeded?
> (except for dubious locking issues)
Are you asking about the vfs_create() call, or the second
mnt_want_write() call?
I appear to have munged two patches together here. One which elevates
the count over the entire switch(), and the other which does the
elevation only around the actual vfs_*() calls. It should only have the
lower-level calls.
> > + error = mnt_want_write(nd.mnt);
> > + if (error)
> > break;
> > - case S_IFDIR:
> > - error = -EPERM;
> > + error = vfs_mknod(nd.dentry->d_inode,dentry,mode,
> > + new_decode_dev(dev));
> > + mnt_drop_write(nd.mnt);
> > + break;
> > + case S_IFIFO: case S_IFSOCK:
>
> same here
>
> > + error = mnt_want_write(nd.mnt);
> > + if (error)
> > break;
> > - default:
> > - error = -EINVAL;
> > - }
> > - dput(dentry);
> > + error = vfs_mknod(nd.dentry->d_inode,dentry,mode,0);
> > + mnt_drop_write(nd.mnt);
> > + break;
> > + case S_IFDIR:
> > + error = -EPERM;
>
> this will give -EPERM on a r/w filesystem, but
> -EROFS on r/o, is that consistant with the current
> behaviour?
Nope. That's a bug, I think. I'll fix it up.
> > + break;
> > + default:
> > + error = -EINVAL;
>
> same here for -EINVAL and -EROFS, maybe the
> mnt_want_write() wants to go into vfs_mknod()?
I think I tried that once, and it didn't quite work out. In this case,
I think just giving vfs_mknod() the same treatment that I gave
vfs_create() should do for now.
-- Dave
next prev parent reply other threads:[~2006-06-08 15:24 UTC|newest]
Thread overview: 56+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-06-08 0:10 [RFC][PATCH 00/27] Read-only bind mounts Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 01/27] Add vfsmount writer count Dave Hansen
2006-06-08 10:33 ` Herbert Poetzl
2006-06-08 0:10 ` [RFC][PATCH 02/27] vfs_rmdir: change if() into goto Dave Hansen
2006-06-08 10:37 ` Herbert Poetzl
2006-06-08 0:10 ` [RFC][PATCH 04/27] elevate mnt writers for vfs_unlink() callers Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 03/27] do_rmdir(): elevate write count Dave Hansen
2006-06-08 10:42 ` Herbert Poetzl
2006-06-08 15:04 ` Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 05/27] elevate mnt writers for nfsd caller of vfs_mkdir() Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 06/27] elevate write count during entire ncp_ioctl() Dave Hansen
2006-06-08 10:44 ` Herbert Poetzl
2006-06-08 15:07 ` Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 07/27] sys_mkdirat(): collapse if() Dave Hansen
2006-06-08 10:46 ` Herbert Poetzl
2006-06-08 15:10 ` Dave Hansen
2006-06-08 15:54 ` Herbert Poetzl
2006-06-08 0:10 ` [RFC][PATCH 08/27] sys_mkdirat(): one more goto Dave Hansen
2006-06-08 10:48 ` Herbert Poetzl
2006-06-08 0:10 ` [RFC][PATCH 09/27] elevate mnt writers for sys_mkdirat() call of vfs_mkdir() Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 10/27] sys_symlinkat() collapse if()s Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 11/27] sys_symlinkat() collapse one more if () Dave Hansen
2006-06-08 10:49 ` Herbert Poetzl
2006-06-08 0:10 ` [RFC][PATCH 12/27] sys_symlinkat() elevate write count around vfs_symlink() Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 13/27] sys_linkat(): elevate write count around vfs_link() Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 14/27] tricky: elevate write count files are open()ed Dave Hansen
2006-06-08 10:54 ` Herbert Poetzl
2006-06-08 15:12 ` Dave Hansen
2006-06-08 16:07 ` Herbert Poetzl
2006-06-08 0:10 ` [RFC][PATCH 15/27] elevate writer count for do_sys_truncate() Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 16/27] elevate write count for do_sys_utime() Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 17/27] elevate write count for do_utimes() Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 19/27] sys_faccessat() elevate writer count Dave Hansen
2006-06-08 11:03 ` Herbert Poetzl
2006-06-08 15:15 ` Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 18/27] sys_faccessat(): collapse if() Dave Hansen
2006-06-08 11:05 ` Herbert Poetzl
2006-06-08 0:10 ` [RFC][PATCH 20/27] unix_find_other() elevate write count for touch_atime() Dave Hansen
2006-06-08 11:07 ` Herbert Poetzl
2006-06-08 0:10 ` [RFC][PATCH 21/27] mount_is_safe(): add comment Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 22/27] sys_mknodat(): elevate write count for vfs_mknod/create() Dave Hansen
2006-06-08 11:16 ` Herbert Poetzl
2006-06-08 15:23 ` Dave Hansen [this message]
2006-06-08 0:10 ` [RFC][PATCH 23/27] elevate write count over calls to vfs_rename() Dave Hansen
2006-06-08 11:23 ` Herbert Poetzl
2006-06-08 15:24 ` Dave Hansen
2006-06-12 18:18 ` Al Viro
2006-06-12 18:29 ` Dave Hansen
2006-06-12 19:03 ` Al Viro
2006-06-08 0:10 ` [RFC][PATCH 24/27] elevate mount count for extended attributes Dave Hansen
2006-06-08 0:10 ` [RFC][PATCH 25/27] /proc/mounts: prep for flags from sb or mnt Dave Hansen
2006-06-08 11:25 ` Herbert Poetzl
2006-06-08 0:10 ` [RFC][PATCH 26/27] /proc/mounts: treat ro/rw like the rest Dave Hansen
2006-06-08 11:26 ` Herbert Poetzl
2006-06-08 0:10 ` [RFC][PATCH 27/27] create and pass read-only mnt flag into do_loopback() Dave Hansen
-- strict thread matches above, loose matches on Subject: below --
2006-07-12 18:17 [RFC][PATCH 00/27] Mount writer count and read-only bind mounts (v4) Dave Hansen
2006-07-12 18:17 ` [RFC][PATCH 22/27] sys_mknodat(): elevate write count for vfs_mknod/create() Dave Hansen
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=1149780202.4097.62.camel@localhost.localdomain \
--to=haveblue@us.ibm.com \
--cc=hch@infradead.org \
--cc=herbert@13thfloor.at \
--cc=linux-fsdevel@vger.kernel.org \
--cc=trond.myklebust@fys.uio.no \
--cc=viro@ftp.linux.org.uk \
/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.