refactor: isrm to centeralize interrupt/irq resources management.
[lunaix-os.git] / lunaix-os / includes / hal / acpi / acpi.h
index 892624497c1d274bf78ca8f30b36284cec98164d..46713b8f54f618fed20db0bed74bed181831dd13 100644 (file)
@@ -1,41 +1,53 @@
 #ifndef __LUNAIX_ACPI_ACPI_H
 #define __LUNAIX_ACPI_ACPI_H
 
-#include <stdint.h>
-#include <stddef.h>
 #include <arch/x86/boot/multiboot.h>
+#include <stddef.h>
+#include <stdint.h>
 
-#include "sdt.h"
+#include "fadt.h"
 #include "madt.h"
+#include "mcfg.h"
+#include "sdt.h"
 
-#define ACPI_RSDP_SIG_L       0x20445352      // 'RSD '
-#define ACPI_RSDP_SIG_H      0x20525450      // 'PTR '
+// * for quick conversion from a table name into ACPI favoured signature
+// * use `echo <TableName> | xxd -eg4`
 
-#define ACPI_MADT_SIG        0x43495041      // 'APIC'
+#define ACPI_RSDP_SIG_L 0x20445352 // 'RSD '
+#define ACPI_RSDP_SIG_H 0x20525450 // 'PTR '
 
-typedef struct {
+#define ACPI_MADT_SIG 0x43495041 // 'APIC'
+#define ACPI_FADT_SIG 0x50434146 // 'FACP' Notice that it is not 'FADT'.
+
+// 'MCFG' (Not part of ACPI standard. See PCI Firmware Spec.)
+#define ACPI_MCFG_SIG 0x4746434d
+
+typedef struct
+{
     uint32_t signature_l;
     uint32_t signature_h;
     uint8_t chksum;
-    uint8_t oem_id[6];
+    char oem_id[6];
     // Revision
     uint8_t rev;
     acpi_rsdt_t* rsdt;
     uint32_t length;
     acpi_sdthdr_t* xsdt;
     uint8_t x_chksum;
-    char reserved[3];    // Reserved field
+    char reserved[3]; // Reserved field
 } __attribute__((packed)) acpi_rsdp_t;
 
 /**
  * @brief Main TOC of ACPI tables, provide hassle-free access of ACPI info.
- * 
+ *
  */
 typedef struct
 {
     // Make it as null terminated
     char oem_id[7];
     acpi_madt_toc_t madt;
+    acpi_fadt_t fadt;
+    struct acpi_mcfg_toc mcfg;
 } acpi_context;
 
 int
@@ -44,4 +56,7 @@ acpi_init(multiboot_info_t* mb_info);
 acpi_context*
 acpi_get_context();
 
+uint8_t
+acpi_gistranslate(uint8_t old_irq);
+
 #endif /* __LUNAIX_ACPI_ACPI_H */