aboutsummaryrefslogtreecommitdiff
path: root/arch/x86_64/kapi/platform.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86_64/kapi/platform.cpp')
-rw-r--r--arch/x86_64/kapi/platform.cpp17
1 files changed, 9 insertions, 8 deletions
diff --git a/arch/x86_64/kapi/platform.cpp b/arch/x86_64/kapi/platform.cpp
index 2e7c7e4..380fc66 100644
--- a/arch/x86_64/kapi/platform.cpp
+++ b/arch/x86_64/kapi/platform.cpp
@@ -10,7 +10,7 @@
#include <kstd/print>
#include <cstddef>
-#include <cstdint>
+#include <utility>
namespace kapi::platform
{
@@ -22,6 +22,10 @@ namespace kapi::platform
auto discover_cpu_topology(kapi::devices::bus & bus) -> bool
{
+ auto static const core_major = kapi::devices::allocate_major_number();
+ auto static const interrupt_controller_major = kapi::devices::allocate_major_number();
+ auto static core_index = 0uz;
+
auto madt = kapi::acpi::get_table("APIC");
if (!madt)
{
@@ -46,7 +50,10 @@ namespace kapi::platform
auto is_bsp = !bsp_found;
bsp_found = true;
- if (kapi::platform::cpu_detected(bus, local_apic->processor_id(), is_bsp))
+ auto lapic = kstd::make_unique<arch::devices::local_apic>(interrupt_controller_major, core_index,
+ local_apic->apic_id(), default_lapic_address);
+ if (kapi::platform::cpu_detected(bus, core_major, core_index, local_apic->processor_id(), is_bsp,
+ std::move(lapic)))
{
++core_count;
}
@@ -61,10 +68,4 @@ namespace kapi::platform
return core_count > 0;
}
- auto create_core_interrupt_controller(std::size_t major, std::size_t minor, std::uint64_t hardware_id)
- -> kstd::unique_ptr<devices::device>
- {
- return kstd::make_unique<arch::devices::local_apic>(major, minor, hardware_id, default_lapic_address);
- }
-
} // namespace kapi::platform \ No newline at end of file