Parser.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. /*
  2. * Copyright (c) 2020, Liav A. <liavalb@hotmail.co.il>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/Types.h>
  8. #include <AK/Vector.h>
  9. #include <Kernel/Memory/PhysicalAddress.h>
  10. #include <Kernel/Memory/Region.h>
  11. #include <Kernel/Memory/VirtualAddress.h>
  12. namespace Kernel {
  13. namespace MultiProcessor {
  14. struct [[gnu::packed]] FloatingPointer {
  15. char sig[4];
  16. u32 physical_address_ptr;
  17. u8 length;
  18. u8 specification_revision;
  19. u8 checksum;
  20. u8 feature_info[5];
  21. };
  22. struct [[gnu::packed]] EntryHeader {
  23. u8 entry_type;
  24. };
  25. struct [[gnu::packed]] ConfigurationTableHeader {
  26. char sig[4];
  27. u16 length;
  28. u8 specification_revision;
  29. u8 checksum;
  30. char oem_id[8];
  31. char product_id[12];
  32. u32 oem_table_ptr;
  33. u16 oem_table_size;
  34. u16 entry_count;
  35. u32 local_apic_address;
  36. u16 ext_table_length;
  37. u8 ext_table_checksum;
  38. u8 reserved;
  39. EntryHeader entries[];
  40. };
  41. enum class ConfigurationTableEntryType {
  42. Processor = 0,
  43. Bus = 1,
  44. IOAPIC = 2,
  45. IO_Interrupt_Assignment = 3,
  46. Local_Interrupt_Assignment = 4,
  47. SystemAddressSpaceMapping = 128,
  48. BusHierarchyDescriptor = 129,
  49. CompatibilityBusAddressSpaceModifier = 130
  50. };
  51. struct [[gnu::packed]] ExtEntryHeader {
  52. u8 entry_type;
  53. u8 entry_length;
  54. };
  55. struct [[gnu::packed]] ProcessorEntry {
  56. EntryHeader h;
  57. u8 local_apic_id;
  58. u8 local_apic_version;
  59. u8 cpu_flags;
  60. u32 cpu_signature;
  61. u32 feature_flags;
  62. u8 reserved[8];
  63. };
  64. struct [[gnu::packed]] BusEntry {
  65. EntryHeader h;
  66. u8 bus_id;
  67. char bus_type[6];
  68. };
  69. struct [[gnu::packed]] IOAPICEntry {
  70. EntryHeader h;
  71. u8 ioapic_id;
  72. u8 ioapic_version;
  73. u8 ioapic_flags;
  74. u32 ioapic_address;
  75. };
  76. enum class InterruptType {
  77. INT = 0,
  78. NMI = 1,
  79. SMI = 2,
  80. ExtINT = 3,
  81. };
  82. struct [[gnu::packed]] IOInterruptAssignmentEntry {
  83. EntryHeader h;
  84. u8 interrupt_type;
  85. u8 polarity;
  86. u8 trigger_mode;
  87. u8 source_bus_id;
  88. u8 source_bus_irq;
  89. u8 destination_ioapic_id;
  90. u8 destination_ioapic_intin_pin;
  91. };
  92. struct [[gnu::packed]] LocalInterruptAssignmentEntry {
  93. EntryHeader h;
  94. u8 interrupt_type;
  95. u8 polarity;
  96. u8 trigger_mode;
  97. u8 source_bus_id;
  98. u8 source_bus_irq;
  99. u8 destination_lapic_id;
  100. u8 destination_lapic_lintin_pin;
  101. };
  102. enum class SystemAddressType {
  103. IO = 0,
  104. Memory = 1,
  105. Prefetch = 2,
  106. };
  107. struct [[gnu::packed]] SystemAddressSpaceMappingEntry {
  108. ExtEntryHeader h;
  109. u8 bus_id;
  110. u8 address_type;
  111. u64 address_base;
  112. u64 length;
  113. };
  114. struct [[gnu::packed]] BusHierarchyDescriptorEntry {
  115. ExtEntryHeader h;
  116. u8 bus_id;
  117. u8 bus_info;
  118. u8 parent_bus;
  119. u8 reserved[3];
  120. };
  121. struct [[gnu::packed]] CompatibilityBusAddressSpaceModifierEntry {
  122. ExtEntryHeader h;
  123. u8 bus_id;
  124. u8 address_modifier;
  125. u32 predefined_range_list;
  126. };
  127. }
  128. class PCIInterruptOverrideMetadata;
  129. class MultiProcessorParser final {
  130. public:
  131. static OwnPtr<MultiProcessorParser> autodetect();
  132. Vector<PCIInterruptOverrideMetadata> get_pci_interrupt_redirections();
  133. private:
  134. explicit MultiProcessorParser(PhysicalAddress floating_pointer);
  135. void parse_configuration_table();
  136. void parse_floating_pointer_data();
  137. Vector<u8> get_pci_bus_ids() const;
  138. static Optional<PhysicalAddress> find_floating_pointer();
  139. PhysicalAddress m_floating_pointer;
  140. PhysicalAddress m_configuration_table;
  141. Vector<MultiProcessor::IOInterruptAssignmentEntry> m_io_interrupt_assignment_entries;
  142. Vector<MultiProcessor::BusEntry> m_bus_entries;
  143. };
  144. }