diff options
| author | Lukas Oesch <lukas.oesch@ost.ch> | 2026-03-17 19:48:59 +0100 |
|---|---|---|
| committer | Lukas Oesch <lukas.oesch@ost.ch> | 2026-03-17 19:48:59 +0100 |
| commit | e4291ea7c01cad04a02ca3f577dba9ccbadad110 (patch) | |
| tree | 4af08f01820bf13fba8dda7646d036bcbdd3df53 /kernel/src/devices/storage/storage_controller.cpp | |
| parent | 59504cfd677dd3e9d9ddb0deea4df7614efedb84 (diff) | |
| parent | fde097681f96e2c6f23ecd71a5c0037acb3ac79e (diff) | |
| download | kernel-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.cpp | 44 |
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 |
