nfsdfs_create_files(): switch to simple_start_creating()

Reviewed-by: NeilBrown <neil@brown.name>
Reviewed-by: Jeff Layton <jlayton@kernel.org>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
Al Viro 2025-07-02 03:30:58 -04:00
parent a6281a7043
commit e59f06bb5d
1 changed files with 12 additions and 18 deletions

View File

@ -1222,34 +1222,28 @@ static int nfsdfs_create_files(struct dentry *root,
struct dentry **fdentries)
{
struct inode *dir = d_inode(root);
struct inode *inode;
struct dentry *dentry;
int i;
inode_lock(dir);
for (i = 0; files->name && files->name[0]; i++, files++) {
dentry = d_alloc_name(root, files->name);
if (!dentry)
goto out;
inode = nfsd_get_inode(d_inode(root)->i_sb,
for (int i = 0; files->name && files->name[0]; i++, files++) {
struct inode *inode = nfsd_get_inode(root->d_sb,
S_IFREG | files->mode);
if (!inode) {
dput(dentry);
goto out;
if (!inode)
return -ENOMEM;
dentry = simple_start_creating(root, files->name);
if (IS_ERR(dentry)) {
iput(inode);
return PTR_ERR(dentry);
}
kref_get(&ncl->cl_ref);
inode->i_fop = files->ops;
inode->i_private = ncl;
d_add(dentry, inode);
d_instantiate(dentry, inode);
fsnotify_create(dir, dentry);
if (fdentries)
fdentries[i] = dentry;
inode_unlock(dir);
}
inode_unlock(dir);
return 0;
out:
inode_unlock(dir);
return -ENOMEM;
}
/* on success, returns positive number unique to that client. */