aboutsummaryrefslogtreecommitdiff
path: root/kernel/devices/src
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/src
parentd22f98cb70587dc451db5cfc0abd4b7fd89ee602 (diff)
downloadteachos-47d94c6e1c0c46a9c5cdce528c8dca588a531595.tar.xz
teachos-47d94c6e1c0c46a9c5cdce528c8dca588a531595.zip
implement first draft of RAMDiskDevice
Diffstat (limited to 'kernel/devices/src')
-rw-r--r--kernel/devices/src/storage/RAMDisk/RAMDiskController.cpp15
-rw-r--r--kernel/devices/src/storage/RAMDisk/RAMDiskDevice.cpp34
2 files changed, 44 insertions, 5 deletions
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 <kstd/print>
#include <algorithm>
@@ -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
diff --git a/kernel/devices/src/storage/RAMDisk/RAMDiskDevice.cpp b/kernel/devices/src/storage/RAMDisk/RAMDiskDevice.cpp
index 8d8f51e..1e650d8 100644
--- a/kernel/devices/src/storage/RAMDisk/RAMDiskDevice.cpp
+++ b/kernel/devices/src/storage/RAMDisk/RAMDiskDevice.cpp
@@ -1,6 +1,38 @@
#include "devices/storage/RAMDisk/RAMDiskDevice.hpp"
+#include "kapi/memory.hpp"
+#include "kapi/system.hpp"
+
+#include <kstd/print>
+
+#include <cstddef>
+
namespace devices::storage::ram_disk
{
- // TODO BA-FS26 implement ram disk device functionality
+ ram_disk_device::ram_disk_device(kapi::memory::linear_address data_start, size_t data_size)
+ : m_data_start(data_start)
+ , m_data_size(data_size)
+ {}
+
+ auto ram_disk_device::read_block(size_t block_index, void * /*buffer*/) const -> void
+ {
+ // if (buffer == nullptr)
+ // {
+ // kapi::system::panic("[RAM DISK DEVICE] read_block called with null buffer.");
+ // }
+
+ auto const offset = block_index * block_size;
+ if (offset + block_size >
+ m_data_size) // TODO BA-FS26 really correct, what if block_size doesn't divide m_data_size?
+ {
+ kapi::system::panic("[RAM DISK DEVICE] read_block out of bounds.");
+ }
+
+ auto const source = static_cast<std::byte *>(m_data_start) + offset;
+ for (size_t i = 0; i < block_size; ++i)
+ {
+ kstd::println("address: {}, value: {}", source + i, std::to_integer<unsigned int>(*(source + i)));
+ }
+ // std::memcpy(buffer, source, block_size);
+ }
} // namespace devices::storage::ram_disk \ No newline at end of file