diff options
| author | Marcel Braun <marcel.braun@ost.ch> | 2026-05-12 13:50:56 +0200 |
|---|---|---|
| committer | Marcel Braun <marcel.braun@ost.ch> | 2026-05-12 13:50:56 +0200 |
| commit | 988977b80cd118749b6b813e0909f4607a4f27fe (patch) | |
| tree | ae124f5928ded32cdb56c93eddf0d695ccb524aa /kernel/src/filesystem/ext2/inode.cpp | |
| parent | 92994a0c662e19bc94a06a544520e8a48bf8f11e (diff) | |
| download | kernel-988977b80cd118749b6b813e0909f4607a4f27fe.tar.xz kernel-988977b80cd118749b6b813e0909f4607a4f27fe.zip | |
Determine ext2 inode size depending on revision level, add const to several methods
Diffstat (limited to 'kernel/src/filesystem/ext2/inode.cpp')
| -rw-r--r-- | kernel/src/filesystem/ext2/inode.cpp | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/kernel/src/filesystem/ext2/inode.cpp b/kernel/src/filesystem/ext2/inode.cpp index 1914c70..303838e 100644 --- a/kernel/src/filesystem/ext2/inode.cpp +++ b/kernel/src/filesystem/ext2/inode.cpp @@ -13,7 +13,7 @@ namespace kernel::filesystem::ext2 { - inode::inode(filesystem * fs, inode_data const & data) + inode::inode(filesystem const * fs, inode_data const & data) : m_filesystem(fs) , m_data(data) { @@ -25,11 +25,10 @@ namespace kernel::filesystem::ext2 auto inode::read(void * buffer, size_t offset, size_t size) const -> size_t { - // TODO BA-FS26 use revision 1 size - auto const max_readable = static_cast<size_t>(m_data.size) - offset; + auto const max_readable = get_size() - offset; auto const requested_size = std::min(size, max_readable); - if (is_symbolic_link() && m_data.size <= sizeof(m_data.block)) + if (is_symbolic_link() && get_size() <= sizeof(m_data.block)) { auto inline_target = reinterpret_cast<uint8_t const *>(m_data.block.data()); kstd::libc::memcpy(static_cast<uint8_t *>(buffer), inline_target + offset, requested_size); @@ -91,4 +90,17 @@ namespace kernel::filesystem::ext2 { return (m_data.mode & constants::mode_mask) == constants::mode_symbolic_link; } + + auto inode::get_size() const -> size_t + { + uint64_t size = m_data.size; + + if (m_filesystem->get_revision_level() > constants::good_old_revision && is_regular()) + { + size |= static_cast<uint64_t>(m_data.dir_acl) << 32; + } + + return size; + } + } // namespace kernel::filesystem::ext2 |
