-acpi_rsdp_t*
-acpi_locate_rsdp(multiboot_info_t* mb_info);
-
-int
-acpi_init(multiboot_info_t* mb_info)
-{
- acpi_rsdp_t* rsdp = acpi_locate_rsdp(mb_info);
-
- assert_msg(rsdp, "Fail to locate ACPI_RSDP");
- assert_msg(acpi_rsdp_validate(rsdp), "Invalid ACPI_RSDP (checksum failed)");
-
- kprintf(KINFO "RSDP found at %p, RSDT: %p\n", rsdp, rsdp->rsdt);
-
- acpi_rsdt_t* rsdt = rsdp->rsdt;
-
- toc = lxcalloc(1, sizeof(acpi_context));
- assert_msg(toc, "Fail to create ACPI context");
-
- strncpy(toc->oem_id, rsdt->header.oem_id, 6);
- toc->oem_id[6] = '\0';
-
- size_t entry_n = (rsdt->header.length - sizeof(acpi_sdthdr_t)) >> 2;
- for (size_t i = 0; i < entry_n; i++) {
- acpi_sdthdr_t* sdthdr = ((acpi_apic_t**)&(rsdt->entry))[i];
- switch (sdthdr->signature) {
- case ACPI_MADT_SIG:
- madt_parse((acpi_madt_t*)sdthdr, toc);
- break;
- default:
- break;
- }
- }
-
- kprintf(KINFO "OEM: %s\n", toc->oem_id);
- kprintf(KINFO "IOAPIC address: %p\n", toc->madt.ioapic->ioapic_addr);
- kprintf(KINFO "APIC address: %p\n", toc->madt.apic_addr);
-
- for (size_t i = 0; i < 24; i++) {
- acpi_intso_t* intso = toc->madt.irq_exception[i];
- if (!intso)
- continue;
-
- kprintf(KINFO "IRQ #%u -> GSI #%u\n", intso->source, intso->gsi);
- }
-}
-