/* * Copyright (c) 2018-2020, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include #include namespace Kernel { KResultOr Process::sys$chmod(Userspace user_path, size_t path_length, mode_t mode) { REQUIRE_PROMISE(fattr); auto path = get_syscall_path_argument(user_path, path_length); if (path.is_error()) return path.error(); return VFS::the().chmod(path.value(), mode, current_directory()); } KResultOr Process::sys$fchmod(int fd, mode_t mode) { REQUIRE_PROMISE(fattr); auto description = file_description(fd); if (!description) return EBADF; return description->chmod(mode); } }