Skip to content

Commit fff49ab

Browse files
supercomputer7ADKaster
authored andcommitted
Kernel/FileSystem: Avoid double locking m_inode_lock in the Ext2 driver
1 parent b63a1dd commit fff49ab

File tree

3 files changed

+11
-2
lines changed

3 files changed

+11
-2
lines changed

Kernel/FileSystem/Ext2FS/Inode.cpp

Lines changed: 3 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -594,6 +594,7 @@ ErrorOr<size_t> Ext2FSInode::read_bytes_locked(off_t offset, size_t count, UserO
594594

595595
ErrorOr<void> Ext2FSInode::resize(u64 new_size)
596596
{
597+
VERIFY(m_inode_lock.is_locked());
597598
auto old_size = size();
598599
if (old_size == new_size)
599600
return {};
@@ -655,7 +656,7 @@ ErrorOr<void> Ext2FSInode::resize(u64 new_size)
655656
auto clear_from = old_size;
656657
u8 zero_buffer[PAGE_SIZE] {};
657658
while (bytes_to_clear) {
658-
auto nwritten = TRY(write_bytes(clear_from, min(static_cast<u64>(sizeof(zero_buffer)), bytes_to_clear), UserOrKernelBuffer::for_kernel_buffer(zero_buffer), nullptr));
659+
auto nwritten = TRY(prepare_and_write_bytes_locked(clear_from, min(static_cast<u64>(sizeof(zero_buffer)), bytes_to_clear), UserOrKernelBuffer::for_kernel_buffer(zero_buffer), nullptr));
659660
VERIFY(nwritten != 0);
660661
bytes_to_clear -= nwritten;
661662
clear_from += nwritten;
@@ -816,7 +817,7 @@ ErrorOr<void> Ext2FSInode::write_directory(Vector<Ext2FSDirectoryEntry>& entries
816817
TRY(resize(serialized_bytes_count));
817818

818819
auto buffer = UserOrKernelBuffer::for_kernel_buffer(directory_data.data());
819-
auto nwritten = TRY(write_bytes(0, serialized_bytes_count, buffer, nullptr));
820+
auto nwritten = TRY(prepare_and_write_bytes_locked(0, serialized_bytes_count, buffer, nullptr));
820821
set_metadata_dirty(true);
821822
if (nwritten != directory_data.size())
822823
return EIO;

Kernel/FileSystem/Inode.cpp

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -97,6 +97,12 @@ ErrorOr<void> Inode::truncate(u64 size)
9797
ErrorOr<size_t> Inode::write_bytes(off_t offset, size_t length, UserOrKernelBuffer const& target_buffer, OpenFileDescription* open_description)
9898
{
9999
MutexLocker locker(m_inode_lock);
100+
return prepare_and_write_bytes_locked(offset, length, target_buffer, open_description);
101+
}
102+
103+
ErrorOr<size_t> Inode::prepare_and_write_bytes_locked(off_t offset, size_t length, UserOrKernelBuffer const& target_buffer, OpenFileDescription* open_description)
104+
{
105+
VERIFY(m_inode_lock.is_locked());
100106
TRY(prepare_to_write_data());
101107
return write_bytes_locked(offset, length, target_buffer, open_description);
102108
}

Kernel/FileSystem/Inode.h

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -121,6 +121,8 @@ class Inode : public ListedRefCounted<Inode, LockType::Spinlock>
121121

122122
mutable Mutex m_inode_lock { "Inode"sv };
123123

124+
ErrorOr<size_t> prepare_and_write_bytes_locked(off_t, size_t, UserOrKernelBuffer const& data, OpenFileDescription*);
125+
124126
virtual ErrorOr<size_t> write_bytes_locked(off_t, size_t, UserOrKernelBuffer const& data, OpenFileDescription*) = 0;
125127
virtual ErrorOr<size_t> read_bytes_locked(off_t, size_t, UserOrKernelBuffer& buffer, OpenFileDescription*) const = 0;
126128
virtual ErrorOr<void> truncate_locked(u64) { return {}; }

0 commit comments

Comments
 (0)