/* * Copyright (c) 2018-2020, Andreas Kling * * SPDX-License-Identifier: BSD-2-Clause */ #pragma once #include #include #include #include #include #include namespace Kernel { class Ext2FSInode final : public Inode { friend class Ext2FS; public: virtual ~Ext2FSInode() override; u64 size() const; bool is_symlink() const { return Kernel::is_symlink(m_raw_inode.i_mode); } bool is_directory() const { return Kernel::is_directory(m_raw_inode.i_mode); } private: // ^Inode virtual ErrorOr read_bytes_locked(off_t, size_t, UserOrKernelBuffer& buffer, OpenFileDescription*) const override; virtual InodeMetadata metadata() const override; virtual ErrorOr traverse_as_directory(Function(FileSystem::DirectoryEntryView const&)>) const override; virtual ErrorOr> lookup(StringView name) override; virtual ErrorOr flush_metadata() override; virtual ErrorOr write_bytes_locked(off_t, size_t, UserOrKernelBuffer const& data, OpenFileDescription*) override; virtual ErrorOr> create_child(StringView name, mode_t, dev_t, UserID, GroupID) override; virtual ErrorOr add_child(Inode& child, StringView name, mode_t) override; virtual ErrorOr remove_child(StringView name) override; virtual ErrorOr replace_child(StringView name, Inode& child) override; virtual ErrorOr update_timestamps(Optional atime, Optional ctime, Optional mtime) override; virtual ErrorOr increment_link_count() override; virtual ErrorOr decrement_link_count() override; virtual ErrorOr chmod(mode_t) override; virtual ErrorOr chown(UserID, GroupID) override; virtual ErrorOr truncate(u64) override; virtual ErrorOr get_block_address(int) override; ErrorOr write_directory(Vector&); ErrorOr populate_lookup_cache(); ErrorOr resize(u64); ErrorOr write_indirect_block(BlockBasedFileSystem::BlockIndex, Span); ErrorOr grow_doubly_indirect_block(BlockBasedFileSystem::BlockIndex, size_t, Span, Vector&, unsigned&); ErrorOr shrink_doubly_indirect_block(BlockBasedFileSystem::BlockIndex, size_t, size_t, unsigned&); ErrorOr grow_triply_indirect_block(BlockBasedFileSystem::BlockIndex, size_t, Span, Vector&, unsigned&); ErrorOr shrink_triply_indirect_block(BlockBasedFileSystem::BlockIndex, size_t, size_t, unsigned&); ErrorOr flush_block_list(); ErrorOr compute_block_list_with_exclusive_locking(); ErrorOr> compute_block_list() const; ErrorOr> compute_block_list_with_meta_blocks() const; ErrorOr> compute_block_list_impl(bool include_block_list_blocks) const; ErrorOr> compute_block_list_impl_internal(ext2_inode const&, bool include_block_list_blocks) const; Ext2FS& fs(); Ext2FS const& fs() const; Ext2FSInode(Ext2FS&, InodeIndex); Vector m_block_list; HashMap, InodeIndex> m_lookup_cache; ext2_inode m_raw_inode {}; Mutex m_block_list_lock { "BlockList"sv }; }; inline Ext2FS& Ext2FSInode::fs() { return static_cast(Inode::fs()); } inline Ext2FS const& Ext2FSInode::fs() const { return static_cast(Inode::fs()); } }