link_path_walk: split "return from recursive call" path
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
parent
32cd74685c
commit
07681481b8
40
fs/namei.c
40
fs/namei.c
@ -1826,23 +1826,6 @@ Walked:
|
|||||||
last->name = name;
|
last->name = name;
|
||||||
name = s;
|
name = s;
|
||||||
goto start;
|
goto start;
|
||||||
|
|
||||||
back:
|
|
||||||
name = last->name;
|
|
||||||
if (unlikely(err)) {
|
|
||||||
put_link(nd, &last->link, last->cookie);
|
|
||||||
current->link_count--;
|
|
||||||
nd->depth--;
|
|
||||||
last--;
|
|
||||||
goto Err;
|
|
||||||
} else {
|
|
||||||
err = walk_component(nd, LOOKUP_FOLLOW);
|
|
||||||
put_link(nd, &last->link, last->cookie);
|
|
||||||
current->link_count--;
|
|
||||||
nd->depth--;
|
|
||||||
last--;
|
|
||||||
goto Walked;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!d_can_lookup(nd->path.dentry)) {
|
if (!d_can_lookup(nd->path.dentry)) {
|
||||||
@ -1852,13 +1835,24 @@ back:
|
|||||||
}
|
}
|
||||||
terminate_walk(nd);
|
terminate_walk(nd);
|
||||||
Err:
|
Err:
|
||||||
if (likely(!nd->depth))
|
while (unlikely(nd->depth)) {
|
||||||
return err;
|
put_link(nd, &last->link, last->cookie);
|
||||||
goto back;
|
current->link_count--;
|
||||||
|
nd->depth--;
|
||||||
|
last--;
|
||||||
|
}
|
||||||
|
return err;
|
||||||
OK:
|
OK:
|
||||||
if (likely(!nd->depth))
|
if (unlikely(nd->depth)) {
|
||||||
return 0;
|
name = last->name;
|
||||||
goto back;
|
err = walk_component(nd, LOOKUP_FOLLOW);
|
||||||
|
put_link(nd, &last->link, last->cookie);
|
||||||
|
current->link_count--;
|
||||||
|
nd->depth--;
|
||||||
|
last--;
|
||||||
|
goto Walked;
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int path_init(int dfd, const struct filename *name, unsigned int flags,
|
static int path_init(int dfd, const struct filename *name, unsigned int flags,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user