/* * Copyright (c) 2018-2022, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include namespace Kernel { class Inode; class InodeFile final : public File { public: static ErrorOr> create(NonnullRefPtr inode) { auto file = adopt_ref_if_nonnull(new (nothrow) InodeFile(move(inode))); if (!file) return ENOMEM; return file.release_nonnull(); } virtual ~InodeFile() override; Inode const& inode() const { return *m_inode; } Inode& inode() { return *m_inode; } virtual bool can_read(OpenFileDescription const&, u64) const override { return true; } virtual bool can_write(OpenFileDescription const&, u64) const override { return true; } virtual ErrorOr read(OpenFileDescription&, u64, UserOrKernelBuffer&, size_t) override; virtual ErrorOr write(OpenFileDescription&, u64, UserOrKernelBuffer const&, size_t) override; virtual ErrorOr ioctl(OpenFileDescription&, unsigned request, Userspace arg) override; virtual ErrorOr> vmobject_for_mmap(Process&, Memory::VirtualRange const&, u64& offset, bool shared) override; virtual ErrorOr stat() const override { return inode().metadata().stat(); } virtual ErrorOr> pseudo_path(OpenFileDescription const&) const override; virtual ErrorOr truncate(u64) override; virtual ErrorOr sync() override; virtual ErrorOr chown(Credentials const&, OpenFileDescription&, UserID, GroupID) override; virtual ErrorOr chmod(Credentials const&, OpenFileDescription&, mode_t) override; virtual StringView class_name() const override { return "InodeFile"sv; } virtual bool is_seekable() const override { return true; } virtual bool is_inode() const override { return true; } private: virtual bool is_regular_file() const override; explicit InodeFile(NonnullRefPtr); NonnullRefPtr const m_inode; }; }