blob: 1f70e2d7751e1996f61d03a779f01c37e41d238f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
#include "devices/storage/RAMDisk/RAMDiskController.hpp"
#include "kapi/boot_module/boot_module.hpp"
#include "kapi/boot_module/boot_module_registry.hpp"
#include "devices/BlockDevice.hpp"
#include "devices/storage/RAMDisk/RAMDiskDevice.hpp"
#include <kstd/print>
#include <algorithm>
#include <array>
#include <cstddef>
#include <cstdint>
namespace devices::storage::ram_disk
{
ram_disk_controller::ram_disk_controller(kapi::boot_modules::boot_module_registry const * registry)
: m_boot_module_registry(registry)
{}
auto ram_disk_controller::probe() -> void
{
size_t current_device_index = 0; // Starte bei 0
std::ranges::for_each(*m_boot_module_registry, [this, ¤t_device_index](auto const & module) {
auto const minor = current_device_index * m_minors_per_device;
// TODO BA-FS26 use push_back from kstd::vector when available
m_devices.at(0) = ram_disk_device{module, m_major, minor};
current_device_index++;
});
std::ranges::for_each(*m_boot_module_registry,
[this](auto const & module) { create_device_from_boot_module(module); });
}
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};
}
auto ram_disk_controller::device_by_major_minor(size_t major, size_t minor) -> block_device *
{
auto it = std::ranges::find_if(
m_devices, [major, minor](auto const & device) { return device.major() == major && device.minor() == minor; });
if (it != m_devices.end())
{
return &(*it);
}
return nullptr;
}
auto ram_disk_controller::devices_count() -> size_t
{
return m_devices.size();
}
} // namespace devices::storage::ram_disk
|