mirror of
https://github.com/SerenityOS/serenity.git
synced 2025-01-23 09:51:57 -05:00
42d9f18cae
This should be reimplemented with proper paging support. This approach was mostly just chewing kmalloc memory.
80 lines
2.2 KiB
C++
80 lines
2.2 KiB
C++
#include "DiskBackedFileSystem.h"
|
|
|
|
#ifdef SERENITY
|
|
#include "i386.h"
|
|
#else
|
|
typedef int InterruptDisabler;
|
|
#endif
|
|
|
|
//#define DBFS_DEBUG
|
|
|
|
DiskBackedFS::DiskBackedFS(RetainPtr<DiskDevice>&& device)
|
|
: m_device(move(device))
|
|
{
|
|
ASSERT(m_device);
|
|
}
|
|
|
|
DiskBackedFS::~DiskBackedFS()
|
|
{
|
|
}
|
|
|
|
bool DiskBackedFS::writeBlock(unsigned index, const ByteBuffer& data)
|
|
{
|
|
ASSERT(data.size() == blockSize());
|
|
#ifdef DBFS_DEBUG
|
|
kprintf("DiskBackedFileSystem::writeBlock %u\n", index);
|
|
#endif
|
|
DiskOffset baseOffset = static_cast<DiskOffset>(index) * static_cast<DiskOffset>(blockSize());
|
|
return device().write(baseOffset, blockSize(), data.pointer());
|
|
}
|
|
|
|
bool DiskBackedFS::writeBlocks(unsigned index, unsigned count, const ByteBuffer& data)
|
|
{
|
|
#ifdef DBFS_DEBUG
|
|
kprintf("DiskBackedFileSystem::writeBlocks %u x%u\n", index, count);
|
|
#endif
|
|
DiskOffset baseOffset = static_cast<DiskOffset>(index) * static_cast<DiskOffset>(blockSize());
|
|
return device().write(baseOffset, count * blockSize(), data.pointer());
|
|
}
|
|
|
|
ByteBuffer DiskBackedFS::readBlock(unsigned index) const
|
|
{
|
|
#ifdef DBFS_DEBUG
|
|
kprintf("DiskBackedFileSystem::readBlock %u\n", index);
|
|
#endif
|
|
auto buffer = ByteBuffer::create_uninitialized(blockSize());
|
|
//kprintf("created block buffer with size %u\n", blockSize());
|
|
DiskOffset baseOffset = static_cast<DiskOffset>(index) * static_cast<DiskOffset>(blockSize());
|
|
auto* bufferPointer = buffer.pointer();
|
|
bool success = device().read(baseOffset, blockSize(), bufferPointer);
|
|
ASSERT(success);
|
|
ASSERT(buffer.size() == blockSize());
|
|
return buffer;
|
|
}
|
|
|
|
ByteBuffer DiskBackedFS::readBlocks(unsigned index, unsigned count) const
|
|
{
|
|
if (!count)
|
|
return nullptr;
|
|
if (count == 1)
|
|
return readBlock(index);
|
|
auto blocks = ByteBuffer::create_uninitialized(count * blockSize());
|
|
byte* out = blocks.pointer();
|
|
|
|
for (unsigned i = 0; i < count; ++i) {
|
|
auto block = readBlock(index + i);
|
|
if (!block)
|
|
return nullptr;
|
|
memcpy(out, block.pointer(), block.size());
|
|
out += blockSize();
|
|
}
|
|
|
|
return blocks;
|
|
}
|
|
|
|
void DiskBackedFS::setBlockSize(unsigned blockSize)
|
|
{
|
|
if (blockSize == m_blockSize)
|
|
return;
|
|
m_blockSize = blockSize;
|
|
}
|