Commit c981a482 authored by Al Viro's avatar Al Viro

split the lookup-related parts of do_last() into a separate helper

Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent 973d4b73
...@@ -3112,19 +3112,12 @@ static struct dentry *lookup_open(struct nameidata *nd, struct file *file, ...@@ -3112,19 +3112,12 @@ static struct dentry *lookup_open(struct nameidata *nd, struct file *file,
return ERR_PTR(error); return ERR_PTR(error);
} }
/* static const char *open_last_lookups(struct nameidata *nd,
* Handle the last step of open()
*/
static const char *do_last(struct nameidata *nd,
struct file *file, const struct open_flags *op) struct file *file, const struct open_flags *op)
{ {
struct dentry *dir = nd->path.dentry; struct dentry *dir = nd->path.dentry;
kuid_t dir_uid = nd->inode->i_uid;
umode_t dir_mode = nd->inode->i_mode;
int open_flag = op->open_flag; int open_flag = op->open_flag;
bool do_truncate;
bool got_write = false; bool got_write = false;
int acc_mode;
unsigned seq; unsigned seq;
struct inode *inode; struct inode *inode;
struct dentry *dentry; struct dentry *dentry;
...@@ -3137,9 +3130,9 @@ static const char *do_last(struct nameidata *nd, ...@@ -3137,9 +3130,9 @@ static const char *do_last(struct nameidata *nd,
if (nd->depth) if (nd->depth)
put_link(nd); put_link(nd);
error = handle_dots(nd, nd->last_type); error = handle_dots(nd, nd->last_type);
if (unlikely(error)) if (likely(!error))
return ERR_PTR(error); error = complete_walk(nd);
goto finish_open; return ERR_PTR(error);
} }
if (!(open_flag & O_CREAT)) { if (!(open_flag & O_CREAT)) {
...@@ -3152,7 +3145,6 @@ static const char *do_last(struct nameidata *nd, ...@@ -3152,7 +3145,6 @@ static const char *do_last(struct nameidata *nd,
if (likely(dentry)) if (likely(dentry))
goto finish_lookup; goto finish_lookup;
BUG_ON(nd->inode != dir->d_inode);
BUG_ON(nd->flags & LOOKUP_RCU); BUG_ON(nd->flags & LOOKUP_RCU);
} else { } else {
/* create side of things */ /* create side of things */
...@@ -3162,7 +3154,7 @@ static const char *do_last(struct nameidata *nd, ...@@ -3162,7 +3154,7 @@ static const char *do_last(struct nameidata *nd,
* about to look up * about to look up
*/ */
error = complete_walk(nd); error = complete_walk(nd);
if (error) if (unlikely(error))
return ERR_PTR(error); return ERR_PTR(error);
audit_inode(nd->name, dir, AUDIT_INODE_PARENT); audit_inode(nd->name, dir, AUDIT_INODE_PARENT);
...@@ -3191,10 +3183,8 @@ static const char *do_last(struct nameidata *nd, ...@@ -3191,10 +3183,8 @@ static const char *do_last(struct nameidata *nd,
else else
inode_unlock_shared(dir->d_inode); inode_unlock_shared(dir->d_inode);
if (got_write) { if (got_write)
mnt_drop_write(nd->path.mnt); mnt_drop_write(nd->path.mnt);
got_write = false;
}
if (IS_ERR(dentry)) if (IS_ERR(dentry))
return ERR_CAST(dentry); return ERR_CAST(dentry);
...@@ -3202,7 +3192,7 @@ static const char *do_last(struct nameidata *nd, ...@@ -3202,7 +3192,7 @@ static const char *do_last(struct nameidata *nd,
if (file->f_mode & (FMODE_OPENED | FMODE_CREATED)) { if (file->f_mode & (FMODE_OPENED | FMODE_CREATED)) {
dput(nd->path.dentry); dput(nd->path.dentry);
nd->path.dentry = dentry; nd->path.dentry = dentry;
goto finish_open_created; return NULL;
} }
finish_lookup: finish_lookup:
...@@ -3218,12 +3208,29 @@ static const char *do_last(struct nameidata *nd, ...@@ -3218,12 +3208,29 @@ static const char *do_last(struct nameidata *nd,
audit_inode(nd->name, nd->path.dentry, 0); audit_inode(nd->name, nd->path.dentry, 0);
return ERR_PTR(-EEXIST); return ERR_PTR(-EEXIST);
} }
finish_open:
/* Why this, you ask? _Now_ we might have grown LOOKUP_JUMPED... */ /* Why this, you ask? _Now_ we might have grown LOOKUP_JUMPED... */
error = complete_walk(nd); return ERR_PTR(complete_walk(nd));
if (error) }
return ERR_PTR(error);
finish_open_created: /*
* Handle the last step of open()
*/
static const char *do_last(struct nameidata *nd,
struct file *file, const struct open_flags *op)
{
kuid_t dir_uid = nd->inode->i_uid;
umode_t dir_mode = nd->inode->i_mode;
int open_flag = op->open_flag;
bool do_truncate;
int acc_mode;
const char *link;
int error;
link = open_last_lookups(nd, file, op);
if (unlikely(link))
return link;
if (!(file->f_mode & FMODE_CREATED)) if (!(file->f_mode & FMODE_CREATED))
audit_inode(nd->name, nd->path.dentry, 0); audit_inode(nd->name, nd->path.dentry, 0);
if (open_flag & O_CREAT) { if (open_flag & O_CREAT) {
......
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