git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
refactor: striped more arch-related code from the kernel code base
[lunaix-os.git]
/
lunaix-os
/
hal
/
acpi
/
acpi.c
diff --git
a/lunaix-os/hal/acpi/acpi.c
b/lunaix-os/hal/acpi/acpi.c
index 5c1eb17d408d95af26137acc3c24e7e4524741de..559befef9f2c76895ecfaab27ca9fa8b382227a3 100644
(file)
--- a/
lunaix-os/hal/acpi/acpi.c
+++ b/
lunaix-os/hal/acpi/acpi.c
@@
-1,6
+1,6
@@
#include <hal/acpi/acpi.h>
#include <hal/acpi/acpi.h>
-#include <lunaix/mm/
k
alloc.h>
+#include <lunaix/mm/
v
alloc.h>
#include <lunaix/spike.h>
#include <lunaix/syslog.h>
#include <lunaix/spike.h>
#include <lunaix/syslog.h>
@@
-28,7
+28,7
@@
acpi_init(multiboot_info_t* mb_info)
acpi_rsdt_t* rsdt = rsdp->rsdt;
acpi_rsdt_t* rsdt = rsdp->rsdt;
- ctx =
lxcalloc(1,
sizeof(acpi_context));
+ ctx =
vzalloc(
sizeof(acpi_context));
assert_msg(ctx, "Fail to create ACPI context");
strncpy(ctx->oem_id, rsdt->header.oem_id, 6);
assert_msg(ctx, "Fail to create ACPI context");
strncpy(ctx->oem_id, rsdt->header.oem_id, 6);
@@
-36,16
+36,20
@@
acpi_init(multiboot_info_t* mb_info)
size_t entry_n = (rsdt->header.length - sizeof(acpi_sdthdr_t)) >> 2;
for (size_t i = 0; i < entry_n; i++) {
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];
+ acpi_sdthdr_t* sdthdr =
+ (acpi_sdthdr_t*)((acpi_apic_t**)&(rsdt->entry))[i];
switch (sdthdr->signature) {
case ACPI_MADT_SIG:
switch (sdthdr->signature) {
case ACPI_MADT_SIG:
+ kprintf(KINFO "MADT: %p\n", sdthdr);
madt_parse((acpi_madt_t*)sdthdr, ctx);
break;
case ACPI_FADT_SIG:
// FADT just a plain structure, no need to parse.
madt_parse((acpi_madt_t*)sdthdr, ctx);
break;
case ACPI_FADT_SIG:
// FADT just a plain structure, no need to parse.
+ kprintf(KINFO "FADT: %p\n", sdthdr);
ctx->fadt = *(acpi_fadt_t*)sdthdr;
break;
case ACPI_MCFG_SIG:
ctx->fadt = *(acpi_fadt_t*)sdthdr;
break;
case ACPI_MCFG_SIG:
+ kprintf(KINFO "MCFG: %p\n", sdthdr);
mcfg_parse(sdthdr, ctx);
break;
default:
mcfg_parse(sdthdr, ctx);
break;
default:
@@
-54,6
+58,8
@@
acpi_init(multiboot_info_t* mb_info)
}
kprintf(KINFO "ACPI: %s\n", ctx->oem_id);
}
kprintf(KINFO "ACPI: %s\n", ctx->oem_id);
+
+ return 0;
}
acpi_context*
}
acpi_context*
@@
-66,8
+72,8
@@
acpi_get_context()
int
acpi_rsdp_validate(acpi_rsdp_t* rsdp)
{
int
acpi_rsdp_validate(acpi_rsdp_t* rsdp)
{
- u
int
8_t sum = 0;
- u
int8_t* rsdp_ptr = (uint
8_t*)rsdp;
+ u8_t sum = 0;
+ u
8_t* rsdp_ptr = (u
8_t*)rsdp;
for (size_t i = 0; i < 20; i++) {
sum += *(rsdp_ptr + i);
}
for (size_t i = 0; i < 20; i++) {
sum += *(rsdp_ptr + i);
}
@@
-75,6
+81,16
@@
acpi_rsdp_validate(acpi_rsdp_t* rsdp)
return sum == 0;
}
return sum == 0;
}
+u8_t
+acpi_gistranslate(u8_t old_irq)
+{
+ if (old_irq >= 24) {
+ return old_irq;
+ }
+ acpi_intso_t* int_override = ctx->madt.irq_exception[old_irq];
+ return int_override ? (u8_t)int_override->gsi : old_irq;
+}
+
#define VIRTUAL_BOX_PROBLEM
acpi_rsdp_t*
#define VIRTUAL_BOX_PROBLEM
acpi_rsdp_t*
@@
-96,11
+112,11
@@
acpi_locate_rsdp(multiboot_info_t* mb_info)
continue;
}
continue;
}
- u
int
8_t* mem_start = entry.addr_low & ~0xf;
+ u8_t* mem_start = entry.addr_low & ~0xf;
size_t len = entry.len_low;
for (size_t j = 0; j < len; j += 16) {
size_t len = entry.len_low;
for (size_t j = 0; j < len; j += 16) {
- u
int32_t sig_low = *((uint
32_t*)(mem_start + j));
- // u
int32_t sig_high = *((uint
32_t*)(mem_start+j) + 1);
+ u
32_t sig_low = *((u
32_t*)(mem_start + j));
+ // u
32_t sig_high = *((u
32_t*)(mem_start+j) + 1);
if (sig_low == ACPI_RSDP_SIG_L) {
rsdp = (acpi_rsdp_t*)(mem_start + j);
break;
if (sig_low == ACPI_RSDP_SIG_L) {
rsdp = (acpi_rsdp_t*)(mem_start + j);
break;
@@
-109,13
+125,14
@@
acpi_locate_rsdp(multiboot_info_t* mb_info)
}
#else
// You know what, I just search the entire 1MiB for Celestia's sake.
}
#else
// You know what, I just search the entire 1MiB for Celestia's sake.
-
uint8_t*
mem_start = 0x4000;
+
ptr_t
mem_start = 0x4000;
for (; mem_start < 0x100000; mem_start += 16) {
for (; mem_start < 0x100000; mem_start += 16) {
- u
int32_t sig_low = *((uint32_t*)(mem_start)
);
+ u
32_t sig_low = *((u32_t*)mem_start
);
// XXX: do we need to compare this as well?
// XXX: do we need to compare this as well?
- // uint32_t sig_high = *((uint32_t*)(mem_start+j) + 1);
+ // u32_t sig_high = *((u32_t*)(mem_start+j) + 1);
+
if (sig_low == ACPI_RSDP_SIG_L) {
if (sig_low == ACPI_RSDP_SIG_L) {
- rsdp = (acpi_rsdp_t*)
(mem_start)
;
+ rsdp = (acpi_rsdp_t*)
mem_start
;
break;
}
}
break;
}
}