public inbox for linux-xfs@vger.kernel.org
 help / color / mirror / Atom feed
From: David Chinner <dgc@sgi.com>
To: David Chinner <dgc@sgi.com>
Cc: Christoph Hellwig <hch@infradead.org>,
	Bret Towe <magnade@gmail.com>,
	xfs@oss.sgi.com
Subject: Re: xfs mknod regression
Date: Wed, 19 Dec 2007 12:06:07 +1100	[thread overview]
Message-ID: <20071219010607.GT4396912@sgi.com> (raw)
In-Reply-To: <20071219003745.GR4396912@sgi.com>

On Wed, Dec 19, 2007 at 11:37:45AM +1100, David Chinner wrote:
> On Tue, Dec 18, 2007 at 05:36:42PM +0000, Christoph Hellwig wrote:
> > 
> > This was broken by my '[XFS] simplify xfs_create/mknod/symlink prototype',
> > which assigned the re-shuffled ondisk dev_t back to the rdev variable in
> > xfs_vn_mknod.  Because of that i_rdev is set to the ondisk dev_t instead
> > of the linux dev_t later down the function.
> > 
> > Fortunately the fix for it is trivial:  we can just remove the
> > assignment because xfs_revalidate_inode has done the proper job before
> > unlocking the inode.
> > 
> > 
> > Signed-off-by: Christoph Hellwig <hch@lst.de>
> > 
> > Index: linux-2.6-xfs/fs/xfs/linux-2.6/xfs_iops.c
> > ===================================================================
> > --- linux-2.6-xfs.orig/fs/xfs/linux-2.6/xfs_iops.c	2007-12-18 18:23:32.000000000 +0100
> > +++ linux-2.6-xfs/fs/xfs/linux-2.6/xfs_iops.c	2007-12-18 18:23:43.000000000 +0100
> > @@ -345,9 +345,7 @@ xfs_vn_mknod(
> >  		ASSERT(vp);
> >  		ip = vn_to_inode(vp);
> >  
> > -		if (S_ISCHR(mode) || S_ISBLK(mode))
> > -			ip->i_rdev = rdev;
> > -		else if (S_ISDIR(mode))
> > +		if (S_ISDIR(mode))
> >  			xfs_validate_fields(ip);
> >  		d_instantiate(dentry, ip);
> >  		xfs_validate_fields(dir);
> 
> Thanks for this, Christoph - I'll run some tests on it and check it in.

Can I get an eyeball or two on the qa test below so i can check it in at the
same time?

Cheers,

Dave.
-- 
Dave Chinner
Principal Engineer
SGI Australian Software Group


---
 xfstests/184     |   43 +++++++++++++++++++++++++++++++++++++++++++
 xfstests/184.out |    1 +
 xfstests/group   |    1 +
 3 files changed, 45 insertions(+)

Index: xfs-cmds/xfstests/group
===================================================================
--- xfs-cmds.orig/xfstests/group	2007-12-19 12:01:13.000000000 +1100
+++ xfs-cmds/xfstests/group	2007-12-19 12:02:25.141919445 +1100
@@ -271,3 +271,4 @@ filestreams	dgc@sgi.com
 181 log auto
 182 metadata rw auto
 183 rw other auto
+184 metadata auto
Index: xfs-cmds/xfstests/184
===================================================================
--- /dev/null	1970-01-01 00:00:00.000000000 +0000
+++ xfs-cmds/xfstests/184	2007-12-19 12:05:39.756887566 +1100
@@ -0,0 +1,43 @@
+#! /bin/sh
+# FS QA Test No. 184
+#
+# check mknod makes working nodes.
+#
+#-----------------------------------------------------------------------
+# Copyright (c) 2007 Silicon Graphics, Inc.  All Rights Reserved.
+#-----------------------------------------------------------------------
+#
+# creator
+owner=dgc@sgi.com
+
+seq=`basename $0`
+echo "QA output created by $seq - silence is golden"
+
+here=`pwd`
+tmp=/tmp/$$
+status=1	# failure is the default!
+trap "_cleanup; exit \$status" 0 1 2 3 15
+
+_cleanup()
+{
+    cd /
+    rm -f $tmp.*
+    _cleanup_testdir
+}
+
+# get standard environment, filters and checks
+. ./common.rc
+. ./common.filter
+
+# real QA test starts here
+_supported_fs xfs udf nfs
+_supported_os IRIX Linux
+
+_setup_testdir
+
+mknod $testdir/null c 1 3
+chmod 666 $testdir/null
+echo fred > $testdir/null
+
+status=$?
+exit
Index: xfs-cmds/xfstests/184.out
===================================================================
--- /dev/null	1970-01-01 00:00:00.000000000 +0000
+++ xfs-cmds/xfstests/184.out	2007-12-19 12:03:13.835636262 +1100
@@ -0,0 +1 @@
+QA output created by 184 - silence is golden

  reply	other threads:[~2007-12-19  1:06 UTC|newest]

Thread overview: 8+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2007-12-18  4:48 xfs mknod regression Bret Towe
2007-12-18 13:46 ` David Chinner
2007-12-18 17:36 ` Christoph Hellwig
2007-12-19  0:37   ` David Chinner
2007-12-19  1:06     ` David Chinner [this message]
2007-12-19  1:13       ` Lachlan McIlroy
2007-12-20  0:04     ` Rafael J. Wysocki
2007-12-19  2:46   ` Bret Towe

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=20071219010607.GT4396912@sgi.com \
    --to=dgc@sgi.com \
    --cc=hch@infradead.org \
    --cc=magnade@gmail.com \
    --cc=xfs@oss.sgi.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