Kernel: Fix not returning errors for the last path item.

Previously the check for an empty part would happen before the
check for access and for the parent being a directory, and so an
error in those would not be detected.
This commit is contained in:
Sergey Bugaev 2019-06-13 16:33:01 +03:00 committed by Andreas Kling
parent 1a697f70db
commit 27203369b4
Notes: sideshowbarker 2024-07-19 13:37:36 +09:00

View file

@ -650,9 +650,6 @@ KResultOr<Retained<Custody>> VFS::resolve_path(StringView path, Custody& base, R
for (int i = 0; i < parts.size(); ++i) {
bool inode_was_root_at_head_of_loop = crumb_id.is_root_inode();
auto& part = parts[i];
if (part.is_empty())
break;
auto crumb_inode = get_inode(crumb_id);
if (!crumb_inode)
return KResult(-EIO);
@ -661,6 +658,11 @@ KResultOr<Retained<Custody>> VFS::resolve_path(StringView path, Custody& base, R
return KResult(-ENOTDIR);
if (!metadata.may_execute(current->process()))
return KResult(-EACCES);
auto& part = parts[i];
if (part.is_empty())
break;
auto current_parent = custody_chain.last();
crumb_id = crumb_inode->lookup(part);
if (!crumb_id.is_valid())