From 6ad2f232597128eecfcb4886e7e40629f3f1cf35 Mon Sep 17 00:00:00 2001 From: Bananymous Date: Tue, 5 Sep 2023 14:46:56 +0300 Subject: [PATCH] Kernel: Correct inode links count --- kernel/kernel/FS/Ext2/FileSystem.cpp | 12 +++--------- kernel/kernel/FS/Ext2/Inode.cpp | 4 +--- 2 files changed, 4 insertions(+), 12 deletions(-) diff --git a/kernel/kernel/FS/Ext2/FileSystem.cpp b/kernel/kernel/FS/Ext2/FileSystem.cpp index 36699364e2..03f60e07d7 100644 --- a/kernel/kernel/FS/Ext2/FileSystem.cpp +++ b/kernel/kernel/FS/Ext2/FileSystem.cpp @@ -2,6 +2,7 @@ #include #define EXT2_DEBUG_PRINT 1 +#define EXT2_VERIFY_INODE 0 namespace Kernel { @@ -129,13 +130,6 @@ namespace Kernel BAN::ErrorOr Ext2FS::initialize_root_inode() { m_root_inode = TRY(Ext2Inode::create(*this, Ext2::Enum::ROOT_INO)); - -#if EXT2_DEBUG_PRINT - dprintln("root inode:"); - dprintln(" created {}", root_inode()->ctime().tv_sec); - dprintln(" modified {}", root_inode()->mtime().tv_sec); - dprintln(" accessed {}", root_inode()->atime().tv_sec); -#endif return {}; } @@ -336,7 +330,7 @@ namespace Kernel BAN::ErrorOr Ext2FS::locate_inode(uint32_t ino) { - ASSERT(ino < superblock().inodes_count); + ASSERT(ino <= superblock().inodes_count); const uint32_t block_size = this->block_size(); @@ -359,7 +353,7 @@ namespace Kernel .offset = inode_byte_offset % block_size }; -#if VERIFY_INODE_EXISTANCE +#if EXT2_VERIFY_INODE const uint32_t inode_bitmap_block = bgd.inode_bitmap; // NOTE: we can reuse the bgd_buffer since it is not needed anymore diff --git a/kernel/kernel/FS/Ext2/Inode.cpp b/kernel/kernel/FS/Ext2/Inode.cpp index e43aecebcd..3db561c585 100644 --- a/kernel/kernel/FS/Ext2/Inode.cpp +++ b/kernel/kernel/FS/Ext2/Inode.cpp @@ -3,8 +3,6 @@ #include #include -#define EXT2_DEBUG_PRINT 1 - namespace Kernel { @@ -406,7 +404,7 @@ namespace Kernel .mtime = (uint32_t)current_time.tv_sec, .dtime = 0, .gid = (uint16_t)gid, - .links_count = 5, + .links_count = 1, .blocks = 0, .flags = 0, .osd1 = 0,