forked from Bananymous/banan-os
Kernel: Ext2 can now read from non-block-size aligned offsets
This commit is contained in:
parent
072954480d
commit
337463ec16
|
@ -227,25 +227,25 @@ namespace Kernel
|
||||||
|
|
||||||
const uint32_t block_size = 1024 << m_fs.superblock().log_block_size;
|
const uint32_t block_size = 1024 << m_fs.superblock().log_block_size;
|
||||||
|
|
||||||
ASSERT(offset % block_size == 0);
|
|
||||||
|
|
||||||
const uint32_t first_block = offset / block_size;
|
const uint32_t first_block = offset / block_size;
|
||||||
const uint32_t last_block = BAN::Math::div_round_up<uint32_t>(offset + count, block_size);
|
const uint32_t last_block = BAN::Math::div_round_up<uint32_t>(offset + count, block_size);
|
||||||
|
|
||||||
size_t n_read = 0;
|
size_t n_read = 0;
|
||||||
|
|
||||||
for (uint32_t block = first_block; block < last_block; block++)
|
for (uint32_t block = first_block; block < last_block; block++)
|
||||||
{
|
{
|
||||||
uint32_t data_block = TRY(data_block_index(block));
|
uint32_t block_index = TRY(data_block_index(block));
|
||||||
auto block_data = TRY(m_fs.read_block(data_block));
|
auto block_data = TRY(m_fs.read_block(block_index));
|
||||||
|
ASSERT(block_data.size() == block_size);
|
||||||
|
|
||||||
uint32_t to_copy = BAN::Math::min<uint32_t>(block_data.size(), count - n_read);
|
uint32_t copy_offset = (offset + n_read) % block_size;
|
||||||
|
uint32_t to_copy = BAN::Math::min<uint32_t>(block_size - copy_offset, count - n_read);
|
||||||
|
memcpy((uint8_t*)buffer + n_read, block_data.data() + copy_offset, to_copy);
|
||||||
|
|
||||||
memcpy((uint8_t*)buffer + n_read, block_data.data(), to_copy);
|
|
||||||
n_read += to_copy;
|
n_read += to_copy;
|
||||||
}
|
}
|
||||||
|
|
||||||
return count;
|
return n_read;
|
||||||
}
|
}
|
||||||
|
|
||||||
BAN::ErrorOr<BAN::RefPtr<Inode>> Ext2Inode::directory_find_impl(BAN::StringView file_name)
|
BAN::ErrorOr<BAN::RefPtr<Inode>> Ext2Inode::directory_find_impl(BAN::StringView file_name)
|
||||||
|
|
Loading…
Reference in New Issue