aboutsummaryrefslogtreecommitdiff
path: root/arch/x86_64
diff options
context:
space:
mode:
authorFelix Morgner <felix.morgner@ost.ch>2026-04-02 14:24:52 +0200
committerFelix Morgner <felix.morgner@ost.ch>2026-04-02 14:24:52 +0200
commit66ffd2ad8c793c4eea1527848fe4772e42595718 (patch)
tree9d86601b57270172d76d5e617218507864ee4f54 /arch/x86_64
parentb84c4c9d8c90f3d3fd5a60de282278912fad2f04 (diff)
downloadteachos-66ffd2ad8c793c4eea1527848fe4772e42595718.tar.xz
teachos-66ffd2ad8c793c4eea1527848fe4772e42595718.zip
kapi: extract common bus code
Diffstat (limited to 'arch/x86_64')
-rw-r--r--arch/x86_64/include/arch/bus/isa.hpp15
-rw-r--r--arch/x86_64/src/bus/isa.cpp44
2 files changed, 0 insertions, 59 deletions
diff --git a/arch/x86_64/include/arch/bus/isa.hpp b/arch/x86_64/include/arch/bus/isa.hpp
index 41dda93..bd92b2e 100644
--- a/arch/x86_64/include/arch/bus/isa.hpp
+++ b/arch/x86_64/include/arch/bus/isa.hpp
@@ -2,10 +2,6 @@
#define TEACHOS_X86_64_BUS_ISA_HPP
#include "kapi/devices/bus.hpp"
-#include "kapi/devices/device.hpp"
-
-#include <kstd/memory>
-#include <kstd/vector>
namespace arch::bus
{
@@ -13,17 +9,6 @@ namespace arch::bus
struct isa final : public kapi::devices::bus
{
isa();
-
- auto add_child(kstd::unique_ptr<device> child) -> void override;
-
- [[nodiscard]] auto children() const -> kstd::vector<kstd::observer_ptr<device>> const & override;
-
- auto init() -> bool override;
-
- private:
- kstd::vector<kstd::unique_ptr<device>> m_devices{};
- kstd::vector<kstd::observer_ptr<device>> m_observers{};
- bool m_initialized{};
};
} // namespace arch::bus
diff --git a/arch/x86_64/src/bus/isa.cpp b/arch/x86_64/src/bus/isa.cpp
index 3fe4f6f..2ad4d21 100644
--- a/arch/x86_64/src/bus/isa.cpp
+++ b/arch/x86_64/src/bus/isa.cpp
@@ -1,15 +1,6 @@
#include "arch/bus/isa.hpp"
#include "kapi/devices.hpp"
-#include "kapi/devices/device.hpp"
-#include "kapi/system.hpp"
-
-#include <kstd/memory>
-#include <kstd/print>
-#include <kstd/vector>
-
-#include <algorithm>
-#include <utility>
namespace arch::bus
{
@@ -18,39 +9,4 @@ namespace arch::bus
: kapi::devices::bus(kapi::devices::allocate_major_number(), 0, "isa")
{}
- auto isa::add_child(kstd::unique_ptr<device> child) -> void
- {
- auto observer = m_observers.emplace_back(child.get());
- m_devices.push_back(std::move(child));
-
- if (m_initialized)
- {
- kstd::println("[bus:{}} Initializing child device '{}'", name(), observer->name());
- if (!observer->init())
- {
- kapi::system::panic("[x86_64:devices] Failed to initialize child device");
- }
- }
- }
-
- auto isa::children() const -> kstd::vector<kstd::observer_ptr<device>> const &
- {
- return m_observers;
- }
-
- auto isa::init() -> bool
- {
- if (m_initialized)
- {
- kapi::system::panic("[x86_64:devices] ISA bus already initialized!");
- }
-
- m_initialized = std::ranges::fold_left(m_devices, true, [](bool acc, auto & child) -> bool {
- kstd::println("[x86_64:devices] Initializing child device '{}'", child->name());
- return acc && child->init();
- });
-
- return m_initialized;
- }
-
} // namespace arch::bus \ No newline at end of file