Parser.h 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. /*
  2. * Copyright (c) 2020-2021, Liav A. <liavalb@hotmail.co.il>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/RefPtr.h>
  8. #include <AK/Types.h>
  9. #include <Kernel/CommandLine.h>
  10. #include <Kernel/FileSystem/SysFSComponent.h>
  11. #include <Kernel/Firmware/ACPI/Definitions.h>
  12. #include <Kernel/Firmware/ACPI/Initialize.h>
  13. #include <Kernel/Firmware/SysFSFirmware.h>
  14. #include <Kernel/Interrupts/IRQHandler.h>
  15. #include <Kernel/Memory/Region.h>
  16. #include <Kernel/PhysicalAddress.h>
  17. #include <Kernel/VirtualAddress.h>
  18. namespace Kernel::ACPI {
  19. class ACPISysFSDirectory : public SysFSDirectory {
  20. public:
  21. virtual StringView name() const override { return "acpi"sv; }
  22. static NonnullRefPtr<ACPISysFSDirectory> must_create(FirmwareSysFSDirectory& firmware_directory);
  23. private:
  24. void find_tables_and_register_them_as_components();
  25. explicit ACPISysFSDirectory(FirmwareSysFSDirectory& firmware_directory);
  26. };
  27. class ACPISysFSComponent : public SysFSComponent {
  28. public:
  29. static NonnullRefPtr<ACPISysFSComponent> create(StringView name, PhysicalAddress, size_t table_size);
  30. virtual StringView name() const override { return m_table_name->view(); }
  31. virtual ErrorOr<size_t> read_bytes(off_t, size_t, UserOrKernelBuffer&, OpenFileDescription*) const override;
  32. protected:
  33. ErrorOr<NonnullOwnPtr<KBuffer>> try_to_generate_buffer() const;
  34. ACPISysFSComponent(NonnullOwnPtr<KString> table_name, PhysicalAddress, size_t table_size);
  35. PhysicalAddress m_paddr;
  36. size_t m_length;
  37. NonnullOwnPtr<KString> m_table_name;
  38. };
  39. class Parser final : public IRQHandler {
  40. public:
  41. static Parser* the();
  42. static void must_initialize(PhysicalAddress rsdp, PhysicalAddress fadt, u8 irq_number);
  43. virtual StringView purpose() const override { return "ACPI Parser"sv; }
  44. virtual bool handle_irq(const RegisterState&) override;
  45. Optional<PhysicalAddress> find_table(StringView signature);
  46. void try_acpi_reboot();
  47. bool can_reboot();
  48. void try_acpi_shutdown();
  49. bool can_shutdown() { return false; }
  50. void enable_aml_parsing();
  51. PhysicalAddress rsdp() const { return m_rsdp; }
  52. PhysicalAddress main_system_description_table() const { return m_main_system_description_table; }
  53. bool is_xsdt_supported() const { return m_xsdt_supported; }
  54. void enumerate_static_tables(Function<void(StringView, PhysicalAddress, size_t)>);
  55. virtual bool have_8042() const
  56. {
  57. return m_x86_specific_flags.keyboard_8042;
  58. }
  59. const FADTFlags::HardwareFeatures& hardware_features() const { return m_hardware_flags; }
  60. const FADTFlags::x86_Specific_Flags& x86_specific_flags() const { return m_x86_specific_flags; }
  61. ~Parser() = default;
  62. private:
  63. Parser(PhysicalAddress rsdp, PhysicalAddress fadt, u8 irq_number);
  64. void locate_static_data();
  65. void locate_main_system_description_table();
  66. void initialize_main_system_description_table();
  67. size_t get_table_size(PhysicalAddress);
  68. u8 get_table_revision(PhysicalAddress);
  69. void process_fadt_data();
  70. bool validate_reset_register();
  71. void access_generic_address(const Structures::GenericAddressStructure&, u32 value);
  72. PhysicalAddress m_rsdp;
  73. PhysicalAddress m_main_system_description_table;
  74. Vector<PhysicalAddress> m_sdt_pointers;
  75. PhysicalAddress m_fadt;
  76. bool m_xsdt_supported { false };
  77. bool m_can_process_bytecode { false };
  78. FADTFlags::HardwareFeatures m_hardware_flags;
  79. FADTFlags::x86_Specific_Flags m_x86_specific_flags;
  80. };
  81. }