Commit a7dab9e8 authored by Roland Dreier's avatar Roland Dreier

IB/uverbs: Use alloc_file() instead of get_empty_filp()

Christoph Hellwig wants to unexport get_empty_filp(), which is an ugly
internal interface.  Change the modular user in ib_uverbs_alloc_event_file()
to use the better alloc_file() interface; this makes the code cleaner too.
Signed-off-by: default avatarRoland Dreier <rolandd@cisco.com>
parent 1ae5c187
...@@ -517,23 +517,18 @@ struct file *ib_uverbs_alloc_event_file(struct ib_uverbs_file *uverbs_file, ...@@ -517,23 +517,18 @@ struct file *ib_uverbs_alloc_event_file(struct ib_uverbs_file *uverbs_file,
goto err; goto err;
} }
filp = get_empty_filp();
if (!filp) {
ret = -ENFILE;
goto err_fd;
}
/* /*
* fops_get() can't fail here, because we're coming from a * fops_get() can't fail here, because we're coming from a
* system call on a uverbs file, which will already have a * system call on a uverbs file, which will already have a
* module reference. * module reference.
*/ */
filp->f_op = fops_get(&uverbs_event_fops); filp = alloc_file(uverbs_event_mnt, dget(uverbs_event_mnt->mnt_root),
filp->f_path.mnt = mntget(uverbs_event_mnt); FMODE_READ, fops_get(&uverbs_event_fops));
filp->f_path.dentry = dget(uverbs_event_mnt->mnt_root); if (!filp) {
filp->f_mapping = filp->f_path.dentry->d_inode->i_mapping; ret = -ENFILE;
filp->f_flags = O_RDONLY; goto err_fd;
filp->f_mode = FMODE_READ; }
filp->private_data = ev_file; filp->private_data = ev_file;
return filp; return filp;
......
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