Commit 906fd2d2 authored by Trond Myklebust's avatar Trond Myklebust

NFS: mkdir() cleanup

Signed-off-by: default avatarTrond Myklebust <Trond.Myklebust@netapp.com>
parent 4e593930
...@@ -1067,8 +1067,6 @@ nfs_mknod(struct inode *dir, struct dentry *dentry, int mode, dev_t rdev) ...@@ -1067,8 +1067,6 @@ nfs_mknod(struct inode *dir, struct dentry *dentry, int mode, dev_t rdev)
static int nfs_mkdir(struct inode *dir, struct dentry *dentry, int mode) static int nfs_mkdir(struct inode *dir, struct dentry *dentry, int mode)
{ {
struct iattr attr; struct iattr attr;
struct nfs_fattr fattr;
struct nfs_fh fhandle;
int error; int error;
dfprintk(VFS, "NFS: mkdir(%s/%ld, %s\n", dir->i_sb->s_id, dfprintk(VFS, "NFS: mkdir(%s/%ld, %s\n", dir->i_sb->s_id,
...@@ -1078,21 +1076,9 @@ static int nfs_mkdir(struct inode *dir, struct dentry *dentry, int mode) ...@@ -1078,21 +1076,9 @@ static int nfs_mkdir(struct inode *dir, struct dentry *dentry, int mode)
attr.ia_mode = mode | S_IFDIR; attr.ia_mode = mode | S_IFDIR;
lock_kernel(); lock_kernel();
#if 0
/*
* Always drop the dentry, we can't always depend on
* the fattr returned by the server (AIX seems to be
* broken). We're better off doing another lookup than
* depending on potentially bogus information.
*/
d_drop(dentry);
#endif
nfs_begin_data_update(dir); nfs_begin_data_update(dir);
error = NFS_PROTO(dir)->mkdir(dir, &dentry->d_name, &attr, &fhandle, error = NFS_PROTO(dir)->mkdir(dir, dentry, &attr);
&fattr);
nfs_end_data_update(dir); nfs_end_data_update(dir);
if (!error)
error = nfs_instantiate(dentry, &fhandle, &fattr);
if (error != 0) if (error != 0)
goto out_err; goto out_err;
nfs_renew_times(dentry); nfs_renew_times(dentry);
......
...@@ -540,28 +540,30 @@ nfs3_proc_symlink(struct inode *dir, struct qstr *name, struct qstr *path, ...@@ -540,28 +540,30 @@ nfs3_proc_symlink(struct inode *dir, struct qstr *name, struct qstr *path,
} }
static int static int
nfs3_proc_mkdir(struct inode *dir, struct qstr *name, struct iattr *sattr, nfs3_proc_mkdir(struct inode *dir, struct dentry *dentry, struct iattr *sattr)
struct nfs_fh *fhandle, struct nfs_fattr *fattr)
{ {
struct nfs_fattr dir_attr; struct nfs_fh fhandle;
struct nfs_fattr fattr, dir_attr;
struct nfs3_mkdirargs arg = { struct nfs3_mkdirargs arg = {
.fh = NFS_FH(dir), .fh = NFS_FH(dir),
.name = name->name, .name = dentry->d_name.name,
.len = name->len, .len = dentry->d_name.len,
.sattr = sattr .sattr = sattr
}; };
struct nfs3_diropres res = { struct nfs3_diropres res = {
.dir_attr = &dir_attr, .dir_attr = &dir_attr,
.fh = fhandle, .fh = &fhandle,
.fattr = fattr .fattr = &fattr
}; };
int status; int status;
dprintk("NFS call mkdir %s\n", name->name); dprintk("NFS call mkdir %s\n", dentry->d_name.name);
dir_attr.valid = 0; dir_attr.valid = 0;
fattr->valid = 0; fattr.valid = 0;
status = rpc_call(NFS_CLIENT(dir), NFS3PROC_MKDIR, &arg, &res, 0); status = rpc_call(NFS_CLIENT(dir), NFS3PROC_MKDIR, &arg, &res, 0);
nfs_refresh_inode(dir, &dir_attr); nfs_refresh_inode(dir, &dir_attr);
if (status == 0)
status = nfs_instantiate(dentry, &fhandle, &fattr);
dprintk("NFS reply mkdir: %d\n", status); dprintk("NFS reply mkdir: %d\n", status);
return status; return status;
} }
......
...@@ -1663,23 +1663,24 @@ static int nfs4_proc_symlink(struct inode *dir, struct qstr *name, ...@@ -1663,23 +1663,24 @@ static int nfs4_proc_symlink(struct inode *dir, struct qstr *name,
return err; return err;
} }
static int _nfs4_proc_mkdir(struct inode *dir, struct qstr *name, static int _nfs4_proc_mkdir(struct inode *dir, struct dentry *dentry,
struct iattr *sattr, struct nfs_fh *fhandle, struct iattr *sattr)
struct nfs_fattr *fattr)
{ {
struct nfs_server *server = NFS_SERVER(dir); struct nfs_server *server = NFS_SERVER(dir);
struct nfs_fh fhandle;
struct nfs_fattr fattr;
struct nfs4_create_arg arg = { struct nfs4_create_arg arg = {
.dir_fh = NFS_FH(dir), .dir_fh = NFS_FH(dir),
.server = server, .server = server,
.name = name, .name = &dentry->d_name,
.attrs = sattr, .attrs = sattr,
.ftype = NF4DIR, .ftype = NF4DIR,
.bitmask = server->attr_bitmask, .bitmask = server->attr_bitmask,
}; };
struct nfs4_create_res res = { struct nfs4_create_res res = {
.server = server, .server = server,
.fh = fhandle, .fh = &fhandle,
.fattr = fattr, .fattr = &fattr,
}; };
struct rpc_message msg = { struct rpc_message msg = {
.rpc_proc = &nfs4_procedures[NFSPROC4_CLNT_CREATE], .rpc_proc = &nfs4_procedures[NFSPROC4_CLNT_CREATE],
...@@ -1688,24 +1689,24 @@ static int _nfs4_proc_mkdir(struct inode *dir, struct qstr *name, ...@@ -1688,24 +1689,24 @@ static int _nfs4_proc_mkdir(struct inode *dir, struct qstr *name,
}; };
int status; int status;
fattr->valid = 0; fattr.valid = 0;
status = rpc_call_sync(NFS_CLIENT(dir), &msg, 0); status = rpc_call_sync(NFS_CLIENT(dir), &msg, 0);
if (!status) if (!status) {
update_changeattr(dir, &res.dir_cinfo); update_changeattr(dir, &res.dir_cinfo);
status = nfs_instantiate(dentry, &fhandle, &fattr);
}
return status; return status;
} }
static int nfs4_proc_mkdir(struct inode *dir, struct qstr *name, static int nfs4_proc_mkdir(struct inode *dir, struct dentry *dentry,
struct iattr *sattr, struct nfs_fh *fhandle, struct iattr *sattr)
struct nfs_fattr *fattr)
{ {
struct nfs4_exception exception = { }; struct nfs4_exception exception = { };
int err; int err;
do { do {
err = nfs4_handle_exception(NFS_SERVER(dir), err = nfs4_handle_exception(NFS_SERVER(dir),
_nfs4_proc_mkdir(dir, name, sattr, _nfs4_proc_mkdir(dir, dentry, sattr),
fhandle, fattr),
&exception); &exception);
} while (exception.retry); } while (exception.retry);
return err; return err;
......
...@@ -402,24 +402,27 @@ nfs_proc_symlink(struct inode *dir, struct qstr *name, struct qstr *path, ...@@ -402,24 +402,27 @@ nfs_proc_symlink(struct inode *dir, struct qstr *name, struct qstr *path,
} }
static int static int
nfs_proc_mkdir(struct inode *dir, struct qstr *name, struct iattr *sattr, nfs_proc_mkdir(struct inode *dir, struct dentry *dentry, struct iattr *sattr)
struct nfs_fh *fhandle, struct nfs_fattr *fattr)
{ {
struct nfs_fh fhandle;
struct nfs_fattr fattr;
struct nfs_createargs arg = { struct nfs_createargs arg = {
.fh = NFS_FH(dir), .fh = NFS_FH(dir),
.name = name->name, .name = dentry->d_name.name,
.len = name->len, .len = dentry->d_name.len,
.sattr = sattr .sattr = sattr
}; };
struct nfs_diropok res = { struct nfs_diropok res = {
.fh = fhandle, .fh = &fhandle,
.fattr = fattr .fattr = &fattr
}; };
int status; int status;
dprintk("NFS call mkdir %s\n", name->name); dprintk("NFS call mkdir %s\n", dentry->d_name.name);
fattr->valid = 0; fattr.valid = 0;
status = rpc_call(NFS_CLIENT(dir), NFSPROC_MKDIR, &arg, &res, 0); status = rpc_call(NFS_CLIENT(dir), NFSPROC_MKDIR, &arg, &res, 0);
if (status == 0)
status = nfs_instantiate(dentry, &fhandle, &fattr);
dprintk("NFS reply mkdir: %d\n", status); dprintk("NFS reply mkdir: %d\n", status);
return status; return status;
} }
......
...@@ -694,8 +694,7 @@ struct nfs_rpc_ops { ...@@ -694,8 +694,7 @@ struct nfs_rpc_ops {
int (*symlink) (struct inode *, struct qstr *, struct qstr *, int (*symlink) (struct inode *, struct qstr *, struct qstr *,
struct iattr *, struct nfs_fh *, struct iattr *, struct nfs_fh *,
struct nfs_fattr *); struct nfs_fattr *);
int (*mkdir) (struct inode *, struct qstr *, struct iattr *, int (*mkdir) (struct inode *, struct dentry *, struct iattr *);
struct nfs_fh *, struct nfs_fattr *);
int (*rmdir) (struct inode *, struct qstr *); int (*rmdir) (struct inode *, struct qstr *);
int (*readdir) (struct dentry *, struct rpc_cred *, int (*readdir) (struct dentry *, struct rpc_cred *,
u64, struct page *, unsigned int, int); u64, struct page *, unsigned int, int);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment