提交 5f4a6a69 编写于 作者: A Al Viro

link_path_walk(): move assignments to nd->last/nd->last_type up

... and clean the main loop a bit
Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
上级 ad8ca374
...@@ -1802,8 +1802,11 @@ static int link_path_walk(const char *name, struct nameidata *nd) ...@@ -1802,8 +1802,11 @@ static int link_path_walk(const char *name, struct nameidata *nd)
} }
} }
nd->last = this;
nd->last_type = type;
if (!name[len]) if (!name[len])
goto last_component; return 0;
/* /*
* If it wasn't NUL, we know it was '/'. Skip that * If it wasn't NUL, we know it was '/'. Skip that
* slash, and continue until no more slashes. * slash, and continue until no more slashes.
...@@ -1812,7 +1815,8 @@ static int link_path_walk(const char *name, struct nameidata *nd) ...@@ -1812,7 +1815,8 @@ static int link_path_walk(const char *name, struct nameidata *nd)
len++; len++;
} while (unlikely(name[len] == '/')); } while (unlikely(name[len] == '/'));
if (!name[len]) if (!name[len])
goto last_component; return 0;
name += len; name += len;
err = walk_component(nd, &next, &this, type, LOOKUP_FOLLOW); err = walk_component(nd, &next, &this, type, LOOKUP_FOLLOW);
...@@ -1824,16 +1828,10 @@ static int link_path_walk(const char *name, struct nameidata *nd) ...@@ -1824,16 +1828,10 @@ static int link_path_walk(const char *name, struct nameidata *nd)
if (err) if (err)
return err; return err;
} }
if (can_lookup(nd->inode)) if (!can_lookup(nd->inode)) {
continue; err = -ENOTDIR;
err = -ENOTDIR; break;
break; }
/* here ends the main loop */
last_component:
nd->last = this;
nd->last_type = type;
return 0;
} }
terminate_walk(nd); terminate_walk(nd);
return err; return err;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册