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: decouple i386 specific instruction invocation
[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 419b1360fc17c16f7aaec63f795a2d632b3537c7..559befef9f2c76895ecfaab27ca9fa8b382227a3 100644
(file)
--- a/
lunaix-os/hal/acpi/acpi.c
+++ b/
lunaix-os/hal/acpi/acpi.c
@@
-58,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*
@@
-70,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);
}
@@
-79,14
+81,14
@@
acpi_rsdp_validate(acpi_rsdp_t* rsdp)
return sum == 0;
}
return sum == 0;
}
-u
int
8_t
-acpi_gistranslate(u
int
8_t old_irq)
+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];
{
if (old_irq >= 24) {
return old_irq;
}
acpi_intso_t* int_override = ctx->madt.irq_exception[old_irq];
- return int_override ? (u
int
8_t)int_override->gsi : old_irq;
+ return int_override ? (u8_t)int_override->gsi : old_irq;
}
#define VIRTUAL_BOX_PROBLEM
}
#define VIRTUAL_BOX_PROBLEM
@@
-110,7
+112,7
@@
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) {
u32_t sig_low = *((u32_t*)(mem_start + j));
size_t len = entry.len_low;
for (size_t j = 0; j < len; j += 16) {
u32_t sig_low = *((u32_t*)(mem_start + j));
@@
-123,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) {
- u32_t sig_low = *((u32_t*)
(mem_start)
);
+ u32_t sig_low = *((u32_t*)
mem_start
);
// XXX: do we need to compare this as well?
// u32_t sig_high = *((u32_t*)(mem_start+j) + 1);
// XXX: do we need to compare this as well?
// 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;
}
}