mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 07:58:11 +00:00

Instead of getting credentials from Process::current(), we now require that they be provided as input to the various VFS functions. This ensures that an atomic set of credentials is used throughout an entire VFS operation.
30 lines
879 B
C++
30 lines
879 B
C++
/*
|
|
* Copyright (c) 2018-2020, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <AK/StringView.h>
|
|
#include <Kernel/FileSystem/VirtualFileSystem.h>
|
|
#include <Kernel/Process.h>
|
|
|
|
namespace Kernel {
|
|
|
|
ErrorOr<FlatPtr> Process::sys$utime(Userspace<char const*> user_path, size_t path_length, Userspace<const struct utimbuf*> user_buf)
|
|
{
|
|
VERIFY_PROCESS_BIG_LOCK_ACQUIRED(this);
|
|
TRY(require_promise(Pledge::fattr));
|
|
auto path = TRY(get_syscall_path_argument(user_path, path_length));
|
|
utimbuf buf;
|
|
if (user_buf) {
|
|
TRY(copy_from_user(&buf, user_buf));
|
|
} else {
|
|
auto now = kgettimeofday().to_truncated_seconds();
|
|
// Not a bug!
|
|
buf = { now, now };
|
|
}
|
|
TRY(VirtualFileSystem::the().utime(credentials(), path->view(), current_directory(), buf.actime, buf.modtime));
|
|
return 0;
|
|
}
|
|
|
|
}
|