summaryrefslogtreecommitdiff
path: root/Kernel/Syscalls/execve.cpp
diff options
context:
space:
mode:
authorAndreas Kling <kling@serenityos.org>2021-09-06 13:01:33 +0200
committerAndreas Kling <kling@serenityos.org>2021-09-06 13:06:05 +0200
commit84addef10f2d44581ce148de9e51bb59d3a2dd94 (patch)
tree830f440eccdeab7c16c41607d2102cacc69c442f /Kernel/Syscalls/execve.cpp
parent6e3381ac32e5d251c124cc6147c4598dd2bac505 (diff)
downloadserenity-84addef10f2d44581ce148de9e51bb59d3a2dd94.zip
Kernel: Improve arguments retrieval error propagation in sys$execve()
Instead of turning any arguments related error into an EFAULT, we now propagate the innermost error during arguments retrieval.
Diffstat (limited to 'Kernel/Syscalls/execve.cpp')
-rw-r--r--Kernel/Syscalls/execve.cpp31
1 files changed, 12 insertions, 19 deletions
diff --git a/Kernel/Syscalls/execve.cpp b/Kernel/Syscalls/execve.cpp
index 5e83ef9dec..9e0cdb00a6 100644
--- a/Kernel/Syscalls/execve.cpp
+++ b/Kernel/Syscalls/execve.cpp
@@ -933,39 +933,32 @@ KResultOr<FlatPtr> Process::sys$execve(Userspace<const Syscall::SC_execve_params
path = path_arg.value()->view();
}
- auto copy_user_strings = [](const auto& list, auto& output) {
+ auto copy_user_strings = [](const auto& list, auto& output) -> KResult {
if (!list.length)
- return true;
+ return KSuccess;
Checked<size_t> size = sizeof(*list.strings);
size *= list.length;
if (size.has_overflow())
- return false;
+ return EOVERFLOW;
Vector<Syscall::StringArgument, 32> strings;
if (!strings.try_resize(list.length))
- return false;
- if (copy_from_user(strings.data(), list.strings, size.value()).is_error())
- return false;
+ return ENOMEM;
+ TRY(copy_from_user(strings.data(), list.strings, size.value()));
for (size_t i = 0; i < list.length; ++i) {
- auto string_or_error = try_copy_kstring_from_user(strings[i]);
- if (string_or_error.is_error()) {
- // FIXME: Propagate the error.
- return false;
- }
+ auto string = TRY(try_copy_kstring_from_user(strings[i]));
// FIXME: Don't convert to String here, use KString all the way.
- auto string = String(string_or_error.value()->view());
- if (!output.try_append(move(string)))
- return false;
+ auto ak_string = String(string->view());
+ if (!output.try_append(move(ak_string)))
+ return ENOMEM;
}
- return true;
+ return KSuccess;
};
Vector<String> arguments;
- if (!copy_user_strings(params.arguments, arguments))
- return EFAULT;
+ TRY(copy_user_strings(params.arguments, arguments));
Vector<String> environment;
- if (!copy_user_strings(params.environment, environment))
- return EFAULT;
+ TRY(copy_user_strings(params.environment, environment));
auto result = exec(move(path), move(arguments), move(environment));
VERIFY(result.is_error()); // We should never continue after a successful exec!