123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 |
- /*
- * Copyright (c) 2020-2021, Liav A. <liavalb@hotmail.co.il>
- *
- * SPDX-License-Identifier: BSD-2-Clause
- */
- #pragma once
- #include <AK/RefPtr.h>
- #include <AK/Types.h>
- #include <Kernel/CommandLine.h>
- #include <Kernel/FileSystem/SysFSComponent.h>
- #include <Kernel/Firmware/ACPI/Definitions.h>
- #include <Kernel/Firmware/ACPI/Initialize.h>
- #include <Kernel/Firmware/SysFSFirmware.h>
- #include <Kernel/Interrupts/IRQHandler.h>
- #include <Kernel/Memory/Region.h>
- #include <Kernel/PhysicalAddress.h>
- #include <Kernel/VirtualAddress.h>
- namespace Kernel::ACPI {
- class ACPISysFSDirectory : public SysFSDirectory {
- public:
- static ErrorOr<NonnullRefPtr<ACPISysFSDirectory>> try_create(FirmwareSysFSDirectory& firmware_directory);
- private:
- explicit ACPISysFSDirectory(FirmwareSysFSDirectory& firmware_directory);
- };
- class ACPISysFSComponent : public SysFSComponent {
- public:
- static NonnullRefPtr<ACPISysFSComponent> create(String name, PhysicalAddress, size_t table_size);
- virtual ErrorOr<size_t> read_bytes(off_t, size_t, UserOrKernelBuffer&, OpenFileDescription*) const override;
- protected:
- ErrorOr<NonnullOwnPtr<KBuffer>> try_to_generate_buffer() const;
- ACPISysFSComponent(String name, PhysicalAddress, size_t table_size);
- PhysicalAddress m_paddr;
- size_t m_length;
- };
- class Parser final : public IRQHandler {
- public:
- static Parser* the();
- static void must_initialize(PhysicalAddress rsdp, PhysicalAddress fadt, u8 irq_number);
- virtual StringView purpose() const override { return "ACPI Parser"sv; }
- virtual bool handle_irq(const RegisterState&) override;
- Optional<PhysicalAddress> find_table(StringView signature);
- void try_acpi_reboot();
- bool can_reboot();
- void try_acpi_shutdown();
- bool can_shutdown() { return false; }
- void enable_aml_parsing();
- PhysicalAddress rsdp() const { return m_rsdp; }
- PhysicalAddress main_system_description_table() const { return m_main_system_description_table; }
- bool is_xsdt_supported() const { return m_xsdt_supported; }
- void enumerate_static_tables(Function<void(StringView, PhysicalAddress, size_t)>);
- virtual bool have_8042() const
- {
- return m_x86_specific_flags.keyboard_8042;
- }
- const FADTFlags::HardwareFeatures& hardware_features() const { return m_hardware_flags; }
- const FADTFlags::x86_Specific_Flags& x86_specific_flags() const { return m_x86_specific_flags; }
- ~Parser() = default;
- private:
- Parser(PhysicalAddress rsdp, PhysicalAddress fadt, u8 irq_number);
- void locate_static_data();
- void locate_main_system_description_table();
- void initialize_main_system_description_table();
- size_t get_table_size(PhysicalAddress);
- u8 get_table_revision(PhysicalAddress);
- void process_fadt_data();
- bool validate_reset_register();
- void access_generic_address(const Structures::GenericAddressStructure&, u32 value);
- PhysicalAddress m_rsdp;
- PhysicalAddress m_main_system_description_table;
- Vector<PhysicalAddress> m_sdt_pointers;
- PhysicalAddress m_fadt;
- bool m_xsdt_supported { false };
- bool m_can_process_bytecode { false };
- FADTFlags::HardwareFeatures m_hardware_flags;
- FADTFlags::x86_Specific_Flags m_x86_specific_flags;
- };
- }
|