aboutsummaryrefslogtreecommitdiffstats
path: root/fs/nfsd/nfs3xdr.c
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2013-02-26 23:16:07 -0500
committerLinus Torvalds <torvalds@linux-foundation.org>2013-02-26 23:16:07 -0500
commitd895cb1af15c04c522a25c79cc429076987c089b (patch)
tree895dc9157e28f603d937a58be664e4e440d5530c /fs/nfsd/nfs3xdr.c
parent9626357371b519f2b955fef399647181034a77fe (diff)
parentd3d009cb965eae7e002ea5badf603ea8f4c34915 (diff)
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
Pull vfs pile (part one) from Al Viro: "Assorted stuff - cleaning namei.c up a bit, fixing ->d_name/->d_parent locking violations, etc. The most visible changes here are death of FS_REVAL_DOT (replaced with "has ->d_weak_revalidate()") and a new helper getting from struct file to inode. Some bits of preparation to xattr method interface changes. Misc patches by various people sent this cycle *and* ocfs2 fixes from several cycles ago that should've been upstream right then. PS: the next vfs pile will be xattr stuff." * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs: (46 commits) saner proc_get_inode() calling conventions proc: avoid extra pde_put() in proc_fill_super() fs: change return values from -EACCES to -EPERM fs/exec.c: make bprm_mm_init() static ocfs2/dlm: use GFP_ATOMIC inside a spin_lock ocfs2: fix possible use-after-free with AIO ocfs2: Fix oops in ocfs2_fast_symlink_readpage() code path get_empty_filp()/alloc_file() leave both ->f_pos and ->f_version zero target: writev() on single-element vector is pointless export kernel_write(), convert open-coded instances fs: encode_fh: return FILEID_INVALID if invalid fid_type kill f_vfsmnt vfs: kill FS_REVAL_DOT by adding a d_weak_revalidate dentry op nfsd: handle vfs_getattr errors in acl protocol switch vfs_getattr() to struct path default SET_PERSONALITY() in linux/elf.h ceph: prepopulate inodes only when request is aborted d_hash_and_lookup(): export, switch open-coded instances 9p: switch v9fs_set_create_acl() to inode+fid, do it before d_instantiate() 9p: split dropping the acls from v9fs_set_create_acl() ...
Diffstat (limited to 'fs/nfsd/nfs3xdr.c')
-rw-r--r--fs/nfsd/nfs3xdr.c10
1 files changed, 5 insertions, 5 deletions
diff --git a/fs/nfsd/nfs3xdr.c b/fs/nfsd/nfs3xdr.c
index 925c944bc0bc..14d9ecb96cff 100644
--- a/fs/nfsd/nfs3xdr.c
+++ b/fs/nfsd/nfs3xdr.c
@@ -11,6 +11,7 @@
11#include "xdr3.h" 11#include "xdr3.h"
12#include "auth.h" 12#include "auth.h"
13#include "netns.h" 13#include "netns.h"
14#include "vfs.h"
14 15
15#define NFSDDBG_FACILITY NFSDDBG_XDR 16#define NFSDDBG_FACILITY NFSDDBG_XDR
16 17
@@ -206,10 +207,10 @@ encode_post_op_attr(struct svc_rqst *rqstp, __be32 *p, struct svc_fh *fhp)
206{ 207{
207 struct dentry *dentry = fhp->fh_dentry; 208 struct dentry *dentry = fhp->fh_dentry;
208 if (dentry && dentry->d_inode) { 209 if (dentry && dentry->d_inode) {
209 int err; 210 __be32 err;
210 struct kstat stat; 211 struct kstat stat;
211 212
212 err = vfs_getattr(fhp->fh_export->ex_path.mnt, dentry, &stat); 213 err = fh_getattr(fhp, &stat);
213 if (!err) { 214 if (!err) {
214 *p++ = xdr_one; /* attributes follow */ 215 *p++ = xdr_one; /* attributes follow */
215 lease_get_mtime(dentry->d_inode, &stat.mtime); 216 lease_get_mtime(dentry->d_inode, &stat.mtime);
@@ -256,13 +257,12 @@ encode_wcc_data(struct svc_rqst *rqstp, __be32 *p, struct svc_fh *fhp)
256 */ 257 */
257void fill_post_wcc(struct svc_fh *fhp) 258void fill_post_wcc(struct svc_fh *fhp)
258{ 259{
259 int err; 260 __be32 err;
260 261
261 if (fhp->fh_post_saved) 262 if (fhp->fh_post_saved)
262 printk("nfsd: inode locked twice during operation.\n"); 263 printk("nfsd: inode locked twice during operation.\n");
263 264
264 err = vfs_getattr(fhp->fh_export->ex_path.mnt, fhp->fh_dentry, 265 err = fh_getattr(fhp, &fhp->fh_post_attr);
265 &fhp->fh_post_attr);
266 fhp->fh_post_change = fhp->fh_dentry->d_inode->i_version; 266 fhp->fh_post_change = fhp->fh_dentry->d_inode->i_version;
267 if (err) { 267 if (err) {
268 fhp->fh_post_saved = 0; 268 fhp->fh_post_saved = 0;