forked from Bananymous/banan-os
Kernel: Move ACPI to its own directory and namespace
This commit is contained in:
parent
7d34bd8f82
commit
e0011d22f2
|
@ -10,7 +10,7 @@ endif()
|
||||||
|
|
||||||
set(KERNEL_SOURCES
|
set(KERNEL_SOURCES
|
||||||
font/prefs.psf.o
|
font/prefs.psf.o
|
||||||
kernel/ACPI.cpp
|
kernel/ACPI/ACPI.cpp
|
||||||
kernel/APIC.cpp
|
kernel/APIC.cpp
|
||||||
kernel/BootInfo.cpp
|
kernel/BootInfo.cpp
|
||||||
kernel/CPUID.cpp
|
kernel/CPUID.cpp
|
||||||
|
|
|
@ -1,144 +0,0 @@
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#include <BAN/Vector.h>
|
|
||||||
#include <kernel/Memory/Types.h>
|
|
||||||
|
|
||||||
namespace Kernel
|
|
||||||
{
|
|
||||||
|
|
||||||
class ACPI
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
struct GAS
|
|
||||||
{
|
|
||||||
uint8_t address_space_id;
|
|
||||||
uint8_t register_bit_width;
|
|
||||||
uint8_t register_bit_offset;
|
|
||||||
uint8_t access_size;
|
|
||||||
uint64_t address;
|
|
||||||
} __attribute__((packed));
|
|
||||||
|
|
||||||
struct SDTHeader
|
|
||||||
{
|
|
||||||
uint8_t signature[4];
|
|
||||||
uint32_t length;
|
|
||||||
uint8_t revision;
|
|
||||||
uint8_t checksum;
|
|
||||||
uint8_t oemid[6];
|
|
||||||
uint64_t oem_table_id;
|
|
||||||
uint32_t oem_revision;
|
|
||||||
uint32_t creator_id;
|
|
||||||
uint32_t creator_revision;
|
|
||||||
} __attribute__((packed));
|
|
||||||
|
|
||||||
struct FADT : public SDTHeader
|
|
||||||
{
|
|
||||||
uint32_t firmware_ctrl;
|
|
||||||
uint32_t dsdt;
|
|
||||||
uint8_t __reserved;
|
|
||||||
uint8_t preferred_pm_profile;
|
|
||||||
uint16_t sci_int;
|
|
||||||
uint32_t smi_cmd;
|
|
||||||
uint8_t acpi_enable;
|
|
||||||
uint8_t acpi_disable;
|
|
||||||
uint8_t s4bios_req;
|
|
||||||
uint8_t pstate_cnt;
|
|
||||||
uint32_t pm1a_evt_blk;
|
|
||||||
uint32_t pm1b_evt_blk;
|
|
||||||
uint32_t pm1a_cnt_blk;
|
|
||||||
uint32_t pm1b_cnt_blk;
|
|
||||||
uint32_t pm2_cnt_blk;
|
|
||||||
uint32_t pm_tmr_blk;
|
|
||||||
uint32_t gpe0_blk;
|
|
||||||
uint32_t gpe1_blk;
|
|
||||||
uint8_t pm1_evt_len;
|
|
||||||
uint8_t pm1_cnt_len;
|
|
||||||
uint8_t pm2_cnt_len;
|
|
||||||
uint8_t pm_tmr_len;
|
|
||||||
uint8_t gpe0_blk_len;
|
|
||||||
uint8_t gpe1_blk_len;
|
|
||||||
uint8_t gpe1_base;
|
|
||||||
uint8_t cst_cnt;
|
|
||||||
uint16_t p_lvl2_lat;
|
|
||||||
uint16_t p_lvl3_lat;
|
|
||||||
uint16_t flush_size;
|
|
||||||
uint16_t flush_stride;
|
|
||||||
uint8_t duty_offset;
|
|
||||||
uint8_t duty_width;
|
|
||||||
uint8_t day_alrm;
|
|
||||||
uint8_t mon_alrm;
|
|
||||||
uint8_t century;
|
|
||||||
uint16_t iapc_boot_arch;
|
|
||||||
uint8_t __reserved2;
|
|
||||||
uint32_t flags;
|
|
||||||
uint8_t reset_reg[12];
|
|
||||||
uint8_t reset_value;
|
|
||||||
uint16_t arm_boot_arch;
|
|
||||||
uint8_t fadt_minor_version;
|
|
||||||
uint64_t x_firmware_version;
|
|
||||||
uint64_t x_dsdt;
|
|
||||||
uint8_t x_pm1a_evt_blk[12];
|
|
||||||
uint8_t x_pm1b_evt_blk[12];
|
|
||||||
uint8_t x_pm1a_cnt_blk[12];
|
|
||||||
uint8_t x_pm1b_cnt_blk[12];
|
|
||||||
uint8_t x_pm2_cnt_blk[12];
|
|
||||||
uint8_t x_pm_tmr_blk[12];
|
|
||||||
uint8_t x_gpe0_blk[12];
|
|
||||||
uint8_t x_gpe1_blk[12];
|
|
||||||
uint8_t sleep_control_reg[12];
|
|
||||||
uint8_t sleep_status_reg[12];
|
|
||||||
uint64_t hypervison_vendor_identity;
|
|
||||||
} __attribute__((packed));
|
|
||||||
|
|
||||||
struct HPET : public SDTHeader
|
|
||||||
{
|
|
||||||
uint8_t hardware_rev_id;
|
|
||||||
uint8_t comparator_count : 5;
|
|
||||||
uint8_t count_size_cap : 1;
|
|
||||||
uint8_t reserved : 1;
|
|
||||||
uint8_t legacy_replacement_irq_routing_cable : 1;
|
|
||||||
uint16_t pci_vendor_id;
|
|
||||||
GAS base_address;
|
|
||||||
uint8_t hpet_number;
|
|
||||||
uint16_t main_counter_minimum_clock_tick;
|
|
||||||
uint8_t page_protection_and_oem_attribute;
|
|
||||||
} __attribute__((packed));
|
|
||||||
|
|
||||||
public:
|
|
||||||
static BAN::ErrorOr<void> initialize();
|
|
||||||
static ACPI& get();
|
|
||||||
|
|
||||||
const SDTHeader* get_header(BAN::StringView signature, uint32_t index);
|
|
||||||
|
|
||||||
private:
|
|
||||||
ACPI() = default;
|
|
||||||
BAN::ErrorOr<void> initialize_impl();
|
|
||||||
|
|
||||||
private:
|
|
||||||
paddr_t m_header_table_paddr = 0;
|
|
||||||
vaddr_t m_header_table_vaddr = 0;
|
|
||||||
uint32_t m_entry_size = 0;
|
|
||||||
|
|
||||||
struct MappedPage
|
|
||||||
{
|
|
||||||
Kernel::paddr_t paddr;
|
|
||||||
Kernel::vaddr_t vaddr;
|
|
||||||
|
|
||||||
SDTHeader* as_header() { return (SDTHeader*)vaddr; }
|
|
||||||
};
|
|
||||||
BAN::Vector<MappedPage> m_mapped_headers;
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
namespace BAN::Formatter
|
|
||||||
{
|
|
||||||
template<typename F>
|
|
||||||
void print_argument(F putc, const Kernel::ACPI::SDTHeader& header, const ValueFormat& format)
|
|
||||||
{
|
|
||||||
putc(header.signature[0]);
|
|
||||||
putc(header.signature[1]);
|
|
||||||
putc(header.signature[2]);
|
|
||||||
putc(header.signature[3]);
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -0,0 +1,38 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <BAN/Vector.h>
|
||||||
|
#include <kernel/ACPI/AML.h>
|
||||||
|
#include <kernel/ACPI/Headers.h>
|
||||||
|
#include <kernel/Memory/Types.h>
|
||||||
|
|
||||||
|
namespace Kernel::ACPI
|
||||||
|
{
|
||||||
|
|
||||||
|
class ACPI
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
static BAN::ErrorOr<void> initialize();
|
||||||
|
static ACPI& get();
|
||||||
|
|
||||||
|
const SDTHeader* get_header(BAN::StringView signature, uint32_t index);
|
||||||
|
|
||||||
|
private:
|
||||||
|
ACPI() = default;
|
||||||
|
BAN::ErrorOr<void> initialize_impl();
|
||||||
|
|
||||||
|
private:
|
||||||
|
paddr_t m_header_table_paddr = 0;
|
||||||
|
vaddr_t m_header_table_vaddr = 0;
|
||||||
|
uint32_t m_entry_size = 0;
|
||||||
|
|
||||||
|
struct MappedPage
|
||||||
|
{
|
||||||
|
Kernel::paddr_t paddr;
|
||||||
|
Kernel::vaddr_t vaddr;
|
||||||
|
|
||||||
|
SDTHeader* as_header() { return (SDTHeader*)vaddr; }
|
||||||
|
};
|
||||||
|
BAN::Vector<MappedPage> m_mapped_headers;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,115 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
|
namespace Kernel::ACPI
|
||||||
|
{
|
||||||
|
|
||||||
|
struct GAS
|
||||||
|
{
|
||||||
|
uint8_t address_space_id;
|
||||||
|
uint8_t register_bit_width;
|
||||||
|
uint8_t register_bit_offset;
|
||||||
|
uint8_t access_size;
|
||||||
|
uint64_t address;
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
struct SDTHeader
|
||||||
|
{
|
||||||
|
uint8_t signature[4];
|
||||||
|
uint32_t length;
|
||||||
|
uint8_t revision;
|
||||||
|
uint8_t checksum;
|
||||||
|
uint8_t oemid[6];
|
||||||
|
uint64_t oem_table_id;
|
||||||
|
uint32_t oem_revision;
|
||||||
|
uint32_t creator_id;
|
||||||
|
uint32_t creator_revision;
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
struct FADT : public SDTHeader
|
||||||
|
{
|
||||||
|
uint32_t firmware_ctrl;
|
||||||
|
uint32_t dsdt;
|
||||||
|
uint8_t __reserved;
|
||||||
|
uint8_t preferred_pm_profile;
|
||||||
|
uint16_t sci_int;
|
||||||
|
uint32_t smi_cmd;
|
||||||
|
uint8_t acpi_enable;
|
||||||
|
uint8_t acpi_disable;
|
||||||
|
uint8_t s4bios_req;
|
||||||
|
uint8_t pstate_cnt;
|
||||||
|
uint32_t pm1a_evt_blk;
|
||||||
|
uint32_t pm1b_evt_blk;
|
||||||
|
uint32_t pm1a_cnt_blk;
|
||||||
|
uint32_t pm1b_cnt_blk;
|
||||||
|
uint32_t pm2_cnt_blk;
|
||||||
|
uint32_t pm_tmr_blk;
|
||||||
|
uint32_t gpe0_blk;
|
||||||
|
uint32_t gpe1_blk;
|
||||||
|
uint8_t pm1_evt_len;
|
||||||
|
uint8_t pm1_cnt_len;
|
||||||
|
uint8_t pm2_cnt_len;
|
||||||
|
uint8_t pm_tmr_len;
|
||||||
|
uint8_t gpe0_blk_len;
|
||||||
|
uint8_t gpe1_blk_len;
|
||||||
|
uint8_t gpe1_base;
|
||||||
|
uint8_t cst_cnt;
|
||||||
|
uint16_t p_lvl2_lat;
|
||||||
|
uint16_t p_lvl3_lat;
|
||||||
|
uint16_t flush_size;
|
||||||
|
uint16_t flush_stride;
|
||||||
|
uint8_t duty_offset;
|
||||||
|
uint8_t duty_width;
|
||||||
|
uint8_t day_alrm;
|
||||||
|
uint8_t mon_alrm;
|
||||||
|
uint8_t century;
|
||||||
|
uint16_t iapc_boot_arch;
|
||||||
|
uint8_t __reserved2;
|
||||||
|
uint32_t flags;
|
||||||
|
uint8_t reset_reg[12];
|
||||||
|
uint8_t reset_value;
|
||||||
|
uint16_t arm_boot_arch;
|
||||||
|
uint8_t fadt_minor_version;
|
||||||
|
uint64_t x_firmware_version;
|
||||||
|
uint64_t x_dsdt;
|
||||||
|
uint8_t x_pm1a_evt_blk[12];
|
||||||
|
uint8_t x_pm1b_evt_blk[12];
|
||||||
|
uint8_t x_pm1a_cnt_blk[12];
|
||||||
|
uint8_t x_pm1b_cnt_blk[12];
|
||||||
|
uint8_t x_pm2_cnt_blk[12];
|
||||||
|
uint8_t x_pm_tmr_blk[12];
|
||||||
|
uint8_t x_gpe0_blk[12];
|
||||||
|
uint8_t x_gpe1_blk[12];
|
||||||
|
uint8_t sleep_control_reg[12];
|
||||||
|
uint8_t sleep_status_reg[12];
|
||||||
|
uint64_t hypervison_vendor_identity;
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
struct HPET : public SDTHeader
|
||||||
|
{
|
||||||
|
uint8_t hardware_rev_id;
|
||||||
|
uint8_t comparator_count : 5;
|
||||||
|
uint8_t count_size_cap : 1;
|
||||||
|
uint8_t reserved : 1;
|
||||||
|
uint8_t legacy_replacement_irq_routing_cable : 1;
|
||||||
|
uint16_t pci_vendor_id;
|
||||||
|
GAS base_address;
|
||||||
|
uint8_t hpet_number;
|
||||||
|
uint16_t main_counter_minimum_clock_tick;
|
||||||
|
uint8_t page_protection_and_oem_attribute;
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace BAN::Formatter
|
||||||
|
{
|
||||||
|
template<typename F>
|
||||||
|
void print_argument(F putc, const Kernel::ACPI::SDTHeader& header, const struct ValueFormat&)
|
||||||
|
{
|
||||||
|
putc(header.signature[0]);
|
||||||
|
putc(header.signature[1]);
|
||||||
|
putc(header.signature[2]);
|
||||||
|
putc(header.signature[3]);
|
||||||
|
}
|
||||||
|
}
|
|
@ -1,6 +1,6 @@
|
||||||
#include <BAN/ScopeGuard.h>
|
#include <BAN/ScopeGuard.h>
|
||||||
#include <BAN/StringView.h>
|
#include <BAN/StringView.h>
|
||||||
#include <kernel/ACPI.h>
|
#include <kernel/ACPI/ACPI.h>
|
||||||
#include <kernel/BootInfo.h>
|
#include <kernel/BootInfo.h>
|
||||||
#include <kernel/Memory/PageTable.h>
|
#include <kernel/Memory/PageTable.h>
|
||||||
|
|
||||||
|
@ -9,15 +9,15 @@
|
||||||
#define RSPD_SIZE 20
|
#define RSPD_SIZE 20
|
||||||
#define RSPDv2_SIZE 36
|
#define RSPDv2_SIZE 36
|
||||||
|
|
||||||
namespace Kernel
|
namespace Kernel::ACPI
|
||||||
{
|
{
|
||||||
|
|
||||||
struct RSDT : public ACPI::SDTHeader
|
struct RSDT : public SDTHeader
|
||||||
{
|
{
|
||||||
uint32_t entries[];
|
uint32_t entries[];
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
struct XSDT : public ACPI::SDTHeader
|
struct XSDT : public SDTHeader
|
||||||
{
|
{
|
||||||
uint64_t entries[];
|
uint64_t entries[];
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
@ -82,7 +82,7 @@ namespace Kernel
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool is_valid_std_header(const ACPI::SDTHeader* header)
|
static bool is_valid_std_header(const SDTHeader* header)
|
||||||
{
|
{
|
||||||
uint8_t sum = 0;
|
uint8_t sum = 0;
|
||||||
for (uint32_t i = 0; i < header->length; i++)
|
for (uint32_t i = 0; i < header->length; i++)
|
||||||
|
@ -225,7 +225,7 @@ namespace Kernel
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
const ACPI::SDTHeader* ACPI::get_header(BAN::StringView signature, uint32_t index)
|
const SDTHeader* ACPI::get_header(BAN::StringView signature, uint32_t index)
|
||||||
{
|
{
|
||||||
if (signature.size() != 4)
|
if (signature.size() != 4)
|
||||||
{
|
{
|
|
@ -1,5 +1,5 @@
|
||||||
#include <BAN/ScopeGuard.h>
|
#include <BAN/ScopeGuard.h>
|
||||||
#include <kernel/ACPI.h>
|
#include <kernel/ACPI/ACPI.h>
|
||||||
#include <kernel/APIC.h>
|
#include <kernel/APIC.h>
|
||||||
#include <kernel/CPUID.h>
|
#include <kernel/CPUID.h>
|
||||||
#include <kernel/Debug.h>
|
#include <kernel/Debug.h>
|
||||||
|
@ -132,7 +132,7 @@ namespace Kernel
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
const MADT* madt = (const MADT*)Kernel::ACPI::get().get_header("APIC"sv, 0);
|
const MADT* madt = (const MADT*)ACPI::ACPI::get().get_header("APIC"sv, 0);
|
||||||
if (madt == nullptr)
|
if (madt == nullptr)
|
||||||
{
|
{
|
||||||
dprintln("Could not find MADT header");
|
dprintln("Could not find MADT header");
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#include <BAN/ScopeGuard.h>
|
#include <BAN/ScopeGuard.h>
|
||||||
#include <kernel/ACPI.h>
|
#include <kernel/ACPI/ACPI.h>
|
||||||
#include <kernel/FS/DevFS/FileSystem.h>
|
#include <kernel/FS/DevFS/FileSystem.h>
|
||||||
#include <kernel/IDT.h>
|
#include <kernel/IDT.h>
|
||||||
#include <kernel/Input/PS2/Config.h>
|
#include <kernel/Input/PS2/Config.h>
|
||||||
|
@ -244,7 +244,7 @@ namespace Kernel::Input
|
||||||
// FIXME: Initialise USB Controllers
|
// FIXME: Initialise USB Controllers
|
||||||
|
|
||||||
// Determine if the PS/2 Controller Exists
|
// Determine if the PS/2 Controller Exists
|
||||||
auto* fadt = static_cast<const ACPI::FADT*>(ACPI::get().get_header("FACP"sv, 0));
|
auto* fadt = static_cast<const ACPI::FADT*>(ACPI::ACPI::get().get_header("FACP"sv, 0));
|
||||||
if (fadt && fadt->revision > 1 && !(fadt->iapc_boot_arch & (1 << 1)))
|
if (fadt && fadt->revision > 1 && !(fadt->iapc_boot_arch & (1 << 1)))
|
||||||
{
|
{
|
||||||
dwarnln_if(DEBUG_PS2, "No PS/2 available");
|
dwarnln_if(DEBUG_PS2, "No PS/2 available");
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
#include <BAN/ScopeGuard.h>
|
#include <BAN/ScopeGuard.h>
|
||||||
#include <kernel/ACPI.h>
|
#include <kernel/ACPI/ACPI.h>
|
||||||
#include <kernel/IDT.h>
|
#include <kernel/IDT.h>
|
||||||
#include <kernel/InterruptController.h>
|
#include <kernel/InterruptController.h>
|
||||||
#include <kernel/Memory/PageTable.h>
|
#include <kernel/Memory/PageTable.h>
|
||||||
|
@ -131,7 +131,7 @@ namespace Kernel
|
||||||
|
|
||||||
BAN::ErrorOr<void> HPET::initialize(bool force_pic)
|
BAN::ErrorOr<void> HPET::initialize(bool force_pic)
|
||||||
{
|
{
|
||||||
auto* header = static_cast<const ACPI::HPET*>(ACPI::get().get_header("HPET"sv, 0));
|
auto* header = static_cast<const ACPI::HPET*>(ACPI::ACPI::get().get_header("HPET"sv, 0));
|
||||||
if (header == nullptr)
|
if (header == nullptr)
|
||||||
return BAN::Error::from_errno(ENODEV);
|
return BAN::Error::from_errno(ENODEV);
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
#include <kernel/ACPI.h>
|
#include <kernel/ACPI/ACPI.h>
|
||||||
#include <kernel/Arch.h>
|
#include <kernel/Arch.h>
|
||||||
#include <kernel/BootInfo.h>
|
#include <kernel/BootInfo.h>
|
||||||
#include <kernel/Debug.h>
|
#include <kernel/Debug.h>
|
||||||
|
@ -116,7 +116,7 @@ extern "C" void kernel_main(uint32_t boot_magic, uint32_t boot_info)
|
||||||
parse_command_line();
|
parse_command_line();
|
||||||
dprintln("command line parsed, root='{}', console='{}'", cmdline.root, cmdline.console);
|
dprintln("command line parsed, root='{}', console='{}'", cmdline.root, cmdline.console);
|
||||||
|
|
||||||
MUST(ACPI::initialize());
|
MUST(ACPI::ACPI::initialize());
|
||||||
dprintln("ACPI initialized");
|
dprintln("ACPI initialized");
|
||||||
|
|
||||||
InterruptController::initialize(cmdline.force_pic);
|
InterruptController::initialize(cmdline.force_pic);
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
#include <kernel/ACPI.h>
|
#include <kernel/ACPI/ACPI.h>
|
||||||
#include <kernel/IO.h>
|
#include <kernel/IO.h>
|
||||||
#include <kernel/Memory/kmalloc.h>
|
#include <kernel/Memory/kmalloc.h>
|
||||||
#include <kernel/Memory/PageTable.h>
|
#include <kernel/Memory/PageTable.h>
|
||||||
|
@ -51,7 +51,7 @@ void laihost_panic(const char* msg)
|
||||||
|
|
||||||
void* laihost_scan(const char* sig, size_t index)
|
void* laihost_scan(const char* sig, size_t index)
|
||||||
{
|
{
|
||||||
return (void*)ACPI::get().get_header(sig, index);
|
return (void*)ACPI::ACPI::get().get_header(sig, index);
|
||||||
}
|
}
|
||||||
|
|
||||||
void* laihost_map(size_t address, size_t count)
|
void* laihost_map(size_t address, size_t count)
|
||||||
|
|
Loading…
Reference in New Issue