From 47d94c6e1c0c46a9c5cdce528c8dca588a531595 Mon Sep 17 00:00:00 2001 From: Lukas Oesch Date: Sat, 28 Feb 2026 19:15:38 +0100 Subject: implement first draft of RAMDiskDevice --- kernel/devices/src/storage/RAMDisk/RAMDiskController.cpp | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) (limited to 'kernel/devices/src/storage/RAMDisk/RAMDiskController.cpp') diff --git a/kernel/devices/src/storage/RAMDisk/RAMDiskController.cpp b/kernel/devices/src/storage/RAMDisk/RAMDiskController.cpp index 3e12e0d..48b9116 100644 --- a/kernel/devices/src/storage/RAMDisk/RAMDiskController.cpp +++ b/kernel/devices/src/storage/RAMDisk/RAMDiskController.cpp @@ -3,6 +3,8 @@ #include "kapi/boot_module/boot_module.hpp" #include "kapi/boot_module/boot_module_registry.hpp" +#include "devices/storage/RAMDisk/RAMDiskDevice.hpp" + #include #include @@ -18,16 +20,21 @@ namespace devices::storage::ram_disk { std::ranges::for_each(*m_boot_module_registry, [this](auto const & module) { create_device_from_boot_module(module); }); - } - auto ram_disk_controller::devices_count() -> size_t - { - return m_devices.size(); + // TODO BA-FS26 just for testing, remove again + std::ranges::for_each(m_devices, [](auto const & device) { device.read_block(0, nullptr); }); } auto ram_disk_controller::create_device_from_boot_module(kapi::boot_modules::boot_module const & module) -> void { + m_devices.at(0) = ram_disk_device{module.start_address, module.size}; + kstd::println("[RAM DISK CONTROLLER] Found boot module: {} at address {} with size {} bytes", module.name, module.start_address, module.size); } + + auto ram_disk_controller::devices_count() -> size_t + { + return m_devices.size(); + } } // namespace devices::storage::ram_disk \ No newline at end of file -- cgit v1.2.3