cxl_getfile(): switch to alloc_file_pseudo()
authorAl Viro <viro@zeniv.linux.org.uk>
Sat, 9 Jun 2018 13:45:56 +0000 (09:45 -0400)
committerAl Viro <viro@zeniv.linux.org.uk>
Thu, 12 Jul 2018 14:04:25 +0000 (10:04 -0400)
Acked-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
drivers/misc/cxl/api.c

index 0b5cb6cf91a054fbc11e55b529a20cd1a2249a6c..8fd5ec4d60423e453b7ff5ca4319079097fda3a8 100644 (file)
@@ -67,10 +67,8 @@ static struct file *cxl_getfile(const char *name,
                                const struct file_operations *fops,
                                void *priv, int flags)
 {
-       struct qstr this;
-       struct path path;
        struct file *file;
-       struct inode *inode = NULL;
+       struct inode *inode;
        int rc;
 
        /* strongly inspired by anon_inode_getfile() */
@@ -91,22 +89,11 @@ static struct file *cxl_getfile(const char *name,
                goto err_fs;
        }
 
-       file = ERR_PTR(-ENOMEM);
-       this.name = name;
-       this.len = strlen(name);
-       this.hash = 0;
-       path.dentry = d_alloc_pseudo(cxl_vfs_mount->mnt_sb, &this);
-       if (!path.dentry)
+       file = alloc_file_pseudo(inode, cxl_vfs_mount, name,
+                                flags & (O_ACCMODE | O_NONBLOCK), fops);
+       if (IS_ERR(file))
                goto err_inode;
 
-       path.mnt = mntget(cxl_vfs_mount);
-       d_instantiate(path.dentry, inode);
-
-       file = alloc_file(&path, flags & (O_ACCMODE | O_NONBLOCK), fops);
-       if (IS_ERR(file)) {
-               path_put(&path);
-               goto err_fs;
-       }
        file->private_data = priv;
 
        return file;