Kernel/FileSystem: Avoid double locking m_inode_lock in the Ext2 driver
This commit is contained in:
parent
b63a1dda63
commit
fff49ab6d3
Notes:
sideshowbarker
2024-07-16 18:26:46 +09:00
Author: https://github.com/supercomputer7 Commit: https://github.com/SerenityOS/serenity/commit/fff49ab6d3 Pull-request: https://github.com/SerenityOS/serenity/pull/23316 Reviewed-by: https://github.com/ADKaster ✅
3 changed files with 11 additions and 2 deletions
|
@ -594,6 +594,7 @@ ErrorOr<size_t> Ext2FSInode::read_bytes_locked(off_t offset, size_t count, UserO
|
|||
|
||||
ErrorOr<void> Ext2FSInode::resize(u64 new_size)
|
||||
{
|
||||
VERIFY(m_inode_lock.is_locked());
|
||||
auto old_size = size();
|
||||
if (old_size == new_size)
|
||||
return {};
|
||||
|
@ -655,7 +656,7 @@ ErrorOr<void> Ext2FSInode::resize(u64 new_size)
|
|||
auto clear_from = old_size;
|
||||
u8 zero_buffer[PAGE_SIZE] {};
|
||||
while (bytes_to_clear) {
|
||||
auto nwritten = TRY(write_bytes(clear_from, min(static_cast<u64>(sizeof(zero_buffer)), bytes_to_clear), UserOrKernelBuffer::for_kernel_buffer(zero_buffer), nullptr));
|
||||
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));
|
||||
VERIFY(nwritten != 0);
|
||||
bytes_to_clear -= nwritten;
|
||||
clear_from += nwritten;
|
||||
|
@ -816,7 +817,7 @@ ErrorOr<void> Ext2FSInode::write_directory(Vector<Ext2FSDirectoryEntry>& entries
|
|||
TRY(resize(serialized_bytes_count));
|
||||
|
||||
auto buffer = UserOrKernelBuffer::for_kernel_buffer(directory_data.data());
|
||||
auto nwritten = TRY(write_bytes(0, serialized_bytes_count, buffer, nullptr));
|
||||
auto nwritten = TRY(prepare_and_write_bytes_locked(0, serialized_bytes_count, buffer, nullptr));
|
||||
set_metadata_dirty(true);
|
||||
if (nwritten != directory_data.size())
|
||||
return EIO;
|
||||
|
|
|
@ -97,6 +97,12 @@ ErrorOr<void> Inode::truncate(u64 size)
|
|||
ErrorOr<size_t> Inode::write_bytes(off_t offset, size_t length, UserOrKernelBuffer const& target_buffer, OpenFileDescription* open_description)
|
||||
{
|
||||
MutexLocker locker(m_inode_lock);
|
||||
return prepare_and_write_bytes_locked(offset, length, target_buffer, open_description);
|
||||
}
|
||||
|
||||
ErrorOr<size_t> Inode::prepare_and_write_bytes_locked(off_t offset, size_t length, UserOrKernelBuffer const& target_buffer, OpenFileDescription* open_description)
|
||||
{
|
||||
VERIFY(m_inode_lock.is_locked());
|
||||
TRY(prepare_to_write_data());
|
||||
return write_bytes_locked(offset, length, target_buffer, open_description);
|
||||
}
|
||||
|
|
|
@ -121,6 +121,8 @@ protected:
|
|||
|
||||
mutable Mutex m_inode_lock { "Inode"sv };
|
||||
|
||||
ErrorOr<size_t> prepare_and_write_bytes_locked(off_t, size_t, UserOrKernelBuffer const& data, OpenFileDescription*);
|
||||
|
||||
virtual ErrorOr<size_t> write_bytes_locked(off_t, size_t, UserOrKernelBuffer const& data, OpenFileDescription*) = 0;
|
||||
virtual ErrorOr<size_t> read_bytes_locked(off_t, size_t, UserOrKernelBuffer& buffer, OpenFileDescription*) const = 0;
|
||||
virtual ErrorOr<void> truncate_locked(u64) { return {}; }
|
||||
|
|
Loading…
Add table
Reference in a new issue