From: "J. Bruce Fields" <bfields@fieldses.org>
To: NeilBrown <neilb@suse.com>
Cc: fdmanana@kernel.org, linux-btrfs@vger.kernel.org,
NFS List <linux-nfs@vger.kernel.org>
Subject: Re: [PATCH 1/2] Btrfs: be more precise on errors when getting an inode from disk
Date: Thu, 21 Jul 2016 21:59:04 -0400 [thread overview]
Message-ID: <20160722015904.GB29969@fieldses.org> (raw)
In-Reply-To: <874m7i8oou.fsf@notabene.neil.brown.name>
On Fri, Jul 22, 2016 at 11:08:17AM +1000, NeilBrown wrote:
> On Fri, Jun 10 2016, fdmanana@kernel.org wrote:
>
> > From: Filipe Manana <fdmanana@suse.com>
> >
> > When we attempt to read an inode from disk, we end up always returning an
> > -ESTALE error to the caller regardless of the actual failure reason, which
> > can be an out of memory problem (when allocating a path), some error found
> > when reading from the fs/subvolume btree (like a genuine IO error) or the
> > inode does not exists. So lets start returning the real error code to the
> > callers so that they don't treat all -ESTALE errors as meaning that the
> > inode does not exists (such as during orphan cleanup). This will also be
> > needed for a subsequent patch in the same series dealing with a special
> > fsync case.
> >
> > Signed-off-by: Filipe Manana <fdmanana@suse.com>
>
> SNIP
>
> > @@ -5594,7 +5602,8 @@ struct inode *btrfs_iget(struct super_block *s, struct btrfs_key *location,
> > } else {
> > unlock_new_inode(inode);
> > iput(inode);
> > - inode = ERR_PTR(-ESTALE);
> > + ASSERT(ret < 0);
> > + inode = ERR_PTR(ret < 0 ? ret : -ESTALE);
> > }
>
> Just a heads-up. This change breaks NFS :-(
>
> The change in error code percolates up the call chain:
>
> nfs4_pufh->fh_verify->nfsd_set_fh_dentry->exportfs_decode_fh
> ->btrfs_fh_to_dentry->ntrfs_get_dentry->btrfs_iget
>
> and nfsd returns NFS4ERR_NOENT to the client instead of NFS4ERR_STALE,
> and the client doesn't handle that quite the same way.
>
> This doesn't mean that the change is wrong, but it could mean we need to
> fix something else in the path to sanitize the error code.
>
> nfsd_set_fh_dentry already has
>
> error = nfserr_stale;
> if (PTR_ERR(exp) == -ENOENT)
> return error;
>
> if (IS_ERR(exp))
> return nfserrno(PTR_ERR(exp));
>
> for a different error case, so duplicating that would work, but I doubt
> it is best. At the very least we should check for valid errors, not
> specific invalid ones.
>
> Bruce: do you have an opinion where we should make sure that PUTFH (and
> various other requests) returns a valid error code?
Uh, I guess not. Maybe exportfs_decode_fh?
Though my kneejerk reaction is to be cranky and wonder why btrfs
suddenly needs a different convention for decode_fh().
--b.
next prev parent reply other threads:[~2016-07-22 1:59 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-06-09 16:53 [PATCH 1/2] Btrfs: be more precise on errors when getting an inode from disk fdmanana
2016-06-09 16:53 ` [PATCH 2/2] Btrfs: improve performance on fsync against new inode after rename/unlink fdmanana
2016-07-22 1:08 ` [PATCH 1/2] Btrfs: be more precise on errors when getting an inode from disk NeilBrown
2016-07-22 1:59 ` J. Bruce Fields [this message]
2016-07-22 2:40 ` NeilBrown
2016-07-22 20:08 ` J. Bruce Fields
2016-08-04 0:19 ` [PATCH] exportfs: be careful to only return expected errors NeilBrown
2016-08-04 12:47 ` Christoph Hellwig
2016-08-04 20:12 ` J. Bruce Fields
2016-08-05 0:51 ` NeilBrown
2016-10-06 6:39 ` NeilBrown
2016-10-06 13:10 ` J. Bruce Fields
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=20160722015904.GB29969@fieldses.org \
--to=bfields@fieldses.org \
--cc=fdmanana@kernel.org \
--cc=linux-btrfs@vger.kernel.org \
--cc=linux-nfs@vger.kernel.org \
--cc=neilb@suse.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;
as well as URLs for NNTP newsgroup(s).