aboutsummaryrefslogtreecommitdiff
path: root/kernel/src
diff options
context:
space:
mode:
authorFelix Morgner <felix.morgner@ost.ch>2026-04-02 13:36:01 +0200
committerFelix Morgner <felix.morgner@ost.ch>2026-04-02 13:36:01 +0200
commitd0c532af74d8d486d734904fd330d5dae7f49754 (patch)
treedb85c8ae19b4aba06afcf903aa7edba414c16f6f /kernel/src
parente7af7ceea2324dcf7d2222986c09d1c478ee4c7e (diff)
downloadteachos-d0c532af74d8d486d734904fd330d5dae7f49754.tar.xz
teachos-d0c532af74d8d486d734904fd330d5dae7f49754.zip
kapi: add basic device subsystem
Diffstat (limited to 'kernel/src')
-rw-r--r--kernel/src/devices/root_bus.cpp55
-rw-r--r--kernel/src/main.cpp4
2 files changed, 59 insertions, 0 deletions
diff --git a/kernel/src/devices/root_bus.cpp b/kernel/src/devices/root_bus.cpp
new file mode 100644
index 0000000..a7f3c1a
--- /dev/null
+++ b/kernel/src/devices/root_bus.cpp
@@ -0,0 +1,55 @@
+#include "kernel/devices/root_bus.hpp"
+
+#include "kapi/devices.hpp"
+#include "kapi/devices/bus.hpp"
+#include "kapi/devices/device.hpp"
+#include "kapi/system.hpp"
+
+#include <kstd/memory>
+#include <kstd/print>
+#include <kstd/vector>
+
+#include <algorithm>
+#include <utility>
+
+namespace kernel::devices
+{
+
+ root_bus::root_bus()
+ : kapi::devices::bus{kapi::devices::allocate_major_number(), 0, "system"}
+ {}
+
+ auto root_bus::add_child(kstd::unique_ptr<device> child) -> void
+ {
+ auto observer = m_observers.emplace_back(child.get());
+ m_children.push_back(std::move(child));
+
+ if (m_initialized)
+ {
+ kstd::println("Initializing child device '{}'", observer->name());
+ if (!observer->init())
+ {
+ kapi::system::panic("[kernel:devices] Failed to initialize child device");
+ }
+ }
+ }
+
+ auto root_bus::children() const -> kstd::vector<kstd::observer_ptr<device>> const &
+ {
+ return m_observers;
+ }
+
+ auto root_bus::init() -> bool
+ {
+ if (m_initialized)
+ {
+ kapi::system::panic("[kernel:devices] Root bus already initialized!");
+ }
+
+ return std::ranges::fold_left(m_children, true, [](bool acc, auto & child) -> bool {
+ kstd::println("[kernel:devices] Initializing child device '{}'", child->name());
+ return acc && child->init();
+ });
+ }
+
+} // namespace kernel::devices \ No newline at end of file
diff --git a/kernel/src/main.cpp b/kernel/src/main.cpp
index 37b4c5b..9d6028d 100644
--- a/kernel/src/main.cpp
+++ b/kernel/src/main.cpp
@@ -1,6 +1,7 @@
#include "kapi/boot_modules.hpp"
#include "kapi/cio.hpp"
#include "kapi/cpu.hpp"
+#include "kapi/devices.hpp"
#include "kapi/interrupts.hpp"
#include "kapi/memory.hpp"
#include "kapi/system.hpp"
@@ -179,6 +180,9 @@ auto main() -> int
kstd::println("[OS] Memory subsystem initialized.");
kapi::system::memory_initialized();
+ kapi::devices::init();
+ kstd::println("[OS] System root bus initialized.");
+
kapi::boot_modules::init();
kstd::println("[OS] Boot module registry initialized.");