aboutsummaryrefslogtreecommitdiff
path: root/kernel/src/devices/storage/storage_controller.cpp
diff options
context:
space:
mode:
authorLukas Oesch <lukas.oesch@ost.ch>2026-03-17 19:48:59 +0100
committerLukas Oesch <lukas.oesch@ost.ch>2026-03-17 19:48:59 +0100
commite4291ea7c01cad04a02ca3f577dba9ccbadad110 (patch)
tree4af08f01820bf13fba8dda7646d036bcbdd3df53 /kernel/src/devices/storage/storage_controller.cpp
parent59504cfd677dd3e9d9ddb0deea4df7614efedb84 (diff)
parentfde097681f96e2c6f23ecd71a5c0037acb3ac79e (diff)
downloadkernel-e4291ea7c01cad04a02ca3f577dba9ccbadad110.tar.xz
kernel-e4291ea7c01cad04a02ca3f577dba9ccbadad110.zip
Merge branch 'tidy-up-folder-structure' into 'develop-BA-FS26'
rename files to snake_case (temp_device part1 -> renamed to device later, due... See merge request teachos/kernel!12
Diffstat (limited to 'kernel/src/devices/storage/storage_controller.cpp')
-rw-r--r--kernel/src/devices/storage/storage_controller.cpp44
1 files changed, 44 insertions, 0 deletions
diff --git a/kernel/src/devices/storage/storage_controller.cpp b/kernel/src/devices/storage/storage_controller.cpp
new file mode 100644
index 0000000..e415436
--- /dev/null
+++ b/kernel/src/devices/storage/storage_controller.cpp
@@ -0,0 +1,44 @@
+#include "kernel/devices/storage/storage_controller.hpp"
+
+#include "kernel/devices/device.hpp"
+
+#include <kstd/memory>
+#include <kstd/vector>
+
+#include <algorithm>
+#include <cstddef>
+
+namespace devices::storage
+{
+ auto storage_controller::set_ids(size_t major, size_t minors_per_dev) -> void
+ {
+ m_major = major;
+ m_minors_per_device = minors_per_dev;
+ }
+
+ auto storage_controller::major() const -> size_t
+ {
+ return m_major;
+ }
+
+ auto storage_controller::device_by_minor(size_t minor) const -> kstd::shared_ptr<devices::device>
+ {
+ auto it = std::ranges::find_if(m_devices, [minor](auto const & device) { return device->minor() == minor; });
+
+ if (it != m_devices.end())
+ {
+ return *it;
+ }
+ return nullptr;
+ }
+
+ auto storage_controller::devices_count() const -> size_t
+ {
+ return m_devices.size();
+ }
+
+ auto storage_controller::all_devices() const -> kstd::vector<kstd::shared_ptr<devices::device>> const &
+ {
+ return m_devices;
+ }
+} // namespace devices::storage \ No newline at end of file