aboutsummaryrefslogtreecommitdiff
path: root/kernel/devices/include
diff options
context:
space:
mode:
authorLukas Oesch <lukasoesch20@gmail.com>2026-02-28 19:15:38 +0100
committerLukas Oesch <lukasoesch20@gmail.com>2026-03-17 16:42:22 +0100
commit47d94c6e1c0c46a9c5cdce528c8dca588a531595 (patch)
tree78850a86a11406bc9abcc8179ec0ab2f43a688f1 /kernel/devices/include
parentd22f98cb70587dc451db5cfc0abd4b7fd89ee602 (diff)
downloadteachos-47d94c6e1c0c46a9c5cdce528c8dca588a531595.tar.xz
teachos-47d94c6e1c0c46a9c5cdce528c8dca588a531595.zip
implement first draft of RAMDiskDevice
Diffstat (limited to 'kernel/devices/include')
-rw-r--r--kernel/devices/include/devices/BlockDevice.hpp5
-rw-r--r--kernel/devices/include/devices/storage/RAMDisk/RAMDiskDevice.hpp18
2 files changed, 22 insertions, 1 deletions
diff --git a/kernel/devices/include/devices/BlockDevice.hpp b/kernel/devices/include/devices/BlockDevice.hpp
index db66683..69d7f81 100644
--- a/kernel/devices/include/devices/BlockDevice.hpp
+++ b/kernel/devices/include/devices/BlockDevice.hpp
@@ -1,10 +1,15 @@
#ifndef TEACH_OS_KERNEL_DEVICES_BLOCK_DEVICE_HPP
#define TEACH_OS_KERNEL_DEVICES_BLOCK_DEVICE_HPP
+#include <cstddef>
+
namespace devices
{
struct block_device
{
+ virtual ~block_device() = default;
+
+ virtual auto read_block(size_t block_index, void * buffer) const -> void = 0;
};
} // namespace devices
diff --git a/kernel/devices/include/devices/storage/RAMDisk/RAMDiskDevice.hpp b/kernel/devices/include/devices/storage/RAMDisk/RAMDiskDevice.hpp
index 98471cf..aa736a4 100644
--- a/kernel/devices/include/devices/storage/RAMDisk/RAMDiskDevice.hpp
+++ b/kernel/devices/include/devices/storage/RAMDisk/RAMDiskDevice.hpp
@@ -1,10 +1,26 @@
#ifndef TEACH_OS_KERNEL_DEVICES_STORAGE_RAM_DISK_DEVICE_HPP
#define TEACH_OS_KERNEL_DEVICES_STORAGE_RAM_DISK_DEVICE_HPP
+#include "kapi/memory.hpp"
+
+#include "devices/BlockDevice.hpp"
+
+#include <cstddef>
+
namespace devices::storage::ram_disk
{
- struct ram_disk_device
+ struct ram_disk_device : block_device
{
+ constexpr size_t static block_size = 512uz; // TODO BA-FS26 really correct / good??
+
+ ram_disk_device() = default;
+ ram_disk_device(kapi::memory::linear_address data_start, size_t data_size);
+
+ auto read_block(size_t block_index, void * buffer) const -> void override;
+
+ private:
+ kapi::memory::linear_address m_data_start{};
+ size_t m_data_size{};
};
} // namespace devices::storage::ram_disk