blob: e1773e76e4324649cfdbeecf8bd0a1790738014c (
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
61
62
63
64
65
|
#include "kapi/devices.hpp"
#include "kapi/acpi.hpp"
#include "kapi/boot.hpp"
#include "arch/boot/boot.hpp"
#include "arch/bus/isa.hpp"
#include "arch/devices/legacy_pit.hpp"
#include <kstd/memory>
#include <kstd/print>
#include <cstdint>
#include <utility>
namespace kapi::devices
{
namespace
{
constexpr auto pit_frequency_in_hz = std::uint32_t{100u};
}
auto init_platform_devices() -> void
{
auto const & mbi = boot::bootstrap_information.mbi;
auto system_description_pointer = static_cast<acpi::root_system_description_pointer const *>(nullptr);
if (auto const & xsdp = mbi->maybe_acpi_xsdp())
{
auto data = xsdp->pointer().data();
system_description_pointer = reinterpret_cast<kapi::acpi::root_system_description_pointer const *>(data);
}
else if (auto const & rsdp = mbi->maybe_acpi_rsdp())
{
auto data = rsdp->pointer().data();
system_description_pointer = reinterpret_cast<kapi::acpi::root_system_description_pointer const *>(data);
}
if (system_description_pointer)
{
if (!kapi::acpi::init(*system_description_pointer))
{
kstd::println(kstd::print_sink::stderr, "[x86_64:DEV] ACPI initialization failed. No tables loaded.");
}
}
else
{
kstd::println(kstd::print_sink::stderr, "[x86_64:DEV] No ACPI RSDP found. Most devices will not be available.");
}
kstd::println("[x86_64:DEV] Initializing ISA bus...");
auto isa_major_number = kapi::devices::allocate_major_number();
auto isa_bus = kstd::make_unique<arch::bus::isa>(isa_major_number);
auto pit_major_number = kapi::devices::allocate_major_number();
auto pit = kstd::make_unique<arch::devices::legacy_pit>(pit_major_number, pit_frequency_in_hz);
isa_bus->add_child(std::move(pit));
auto & root_bus = get_root_bus();
root_bus.add_child(std::move(isa_bus));
}
} // namespace kapi::devices
|