Commit 0fb1ea09 authored by Al Viro's avatar Al Viro

atomic_open(): delay open_to_namei_flags() until the method call

nobody else needs that transformation.
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent fe9ec829
...@@ -2828,7 +2828,7 @@ static int atomic_open(struct nameidata *nd, struct dentry *dentry, ...@@ -2828,7 +2828,7 @@ static int atomic_open(struct nameidata *nd, struct dentry *dentry,
int *opened) int *opened)
{ {
struct inode *dir = nd->path.dentry->d_inode; struct inode *dir = nd->path.dentry->d_inode;
unsigned open_flag = open_to_namei_flags(op->open_flag); unsigned open_flag = op->open_flag;
umode_t mode; umode_t mode;
int error; int error;
int acc_mode; int acc_mode;
...@@ -2886,8 +2886,9 @@ static int atomic_open(struct nameidata *nd, struct dentry *dentry, ...@@ -2886,8 +2886,9 @@ static int atomic_open(struct nameidata *nd, struct dentry *dentry,
file->f_path.dentry = DENTRY_NOT_SET; file->f_path.dentry = DENTRY_NOT_SET;
file->f_path.mnt = nd->path.mnt; file->f_path.mnt = nd->path.mnt;
error = dir->i_op->atomic_open(dir, dentry, file, open_flag, mode, error = dir->i_op->atomic_open(dir, dentry, file,
opened); open_to_namei_flags(open_flag),
mode, opened);
if (error < 0) { if (error < 0) {
if (create_error && error == -ENOENT) if (create_error && error == -ENOENT)
error = create_error; error = create_error;
......
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