/* * Copyright (c) 2018-2020, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include #include namespace Kernel { KResultOr Process::sys$fstat(int fd, Userspace user_statbuf) { VERIFY_PROCESS_BIG_LOCK_ACQUIRED(this) REQUIRE_PROMISE(stdio); auto description = TRY(fds().file_description(fd)); stat buffer = {}; TRY(description->stat(buffer)); return copy_to_user(user_statbuf, &buffer); } KResultOr Process::sys$stat(Userspace user_params) { VERIFY_PROCESS_BIG_LOCK_ACQUIRED(this) REQUIRE_PROMISE(rpath); auto params = TRY(copy_typed_from_user(user_params)); auto path = TRY(get_syscall_path_argument(params.path)); RefPtr base; if (params.dirfd == AT_FDCWD) { base = current_directory(); } else { auto base_description = TRY(fds().file_description(params.dirfd)); if (!base_description->is_directory()) return ENOTDIR; if (!base_description->custody()) return EINVAL; base = base_description->custody(); } auto metadata = TRY(VirtualFileSystem::the().lookup_metadata(path->view(), *base, params.follow_symlinks ? 0 : O_NOFOLLOW_NOERROR)); stat statbuf = {}; TRY(metadata.stat(statbuf)); return copy_to_user(params.statbuf, &statbuf); } }