x86 mmu_init(): Sum up the physical memory we ignore for whatever reason --
stored in kernel_args::ignored_physical_memory. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@37116 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
61d2b06c40
commit
84e9db7fb7
@ -54,6 +54,7 @@ typedef struct kernel_args {
|
|||||||
addr_range virtual_allocated_range[MAX_VIRTUAL_ALLOCATED_RANGE];
|
addr_range virtual_allocated_range[MAX_VIRTUAL_ALLOCATED_RANGE];
|
||||||
uint32 num_kernel_args_ranges;
|
uint32 num_kernel_args_ranges;
|
||||||
addr_range kernel_args_range[MAX_KERNEL_ARGS_RANGE];
|
addr_range kernel_args_range[MAX_KERNEL_ARGS_RANGE];
|
||||||
|
uint64 ignored_physical_memory;
|
||||||
|
|
||||||
uint32 num_cpus;
|
uint32 num_cpus;
|
||||||
addr_range cpu_kstack[MAX_BOOT_CPUS];
|
addr_range cpu_kstack[MAX_BOOT_CPUS];
|
||||||
|
@ -653,7 +653,8 @@ mmu_init(void)
|
|||||||
// Type 1 is available memory
|
// Type 1 is available memory
|
||||||
if (extMemoryBlock[i].type == 1) {
|
if (extMemoryBlock[i].type == 1) {
|
||||||
uint64 base = extMemoryBlock[i].base_addr;
|
uint64 base = extMemoryBlock[i].base_addr;
|
||||||
uint64 end = base + extMemoryBlock[i].length;
|
uint64 length = extMemoryBlock[i].length;
|
||||||
|
uint64 end = base + length;
|
||||||
|
|
||||||
// round everything up to page boundaries, exclusive of pages
|
// round everything up to page boundaries, exclusive of pages
|
||||||
// it partially occupies
|
// it partially occupies
|
||||||
@ -675,6 +676,9 @@ mmu_init(void)
|
|||||||
if (base < 0x100000)
|
if (base < 0x100000)
|
||||||
base = 0x100000;
|
base = 0x100000;
|
||||||
|
|
||||||
|
gKernelArgs.ignored_physical_memory
|
||||||
|
+= length - (max_c(end, base) - base);
|
||||||
|
|
||||||
if (end <= base)
|
if (end <= base)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
@ -682,6 +686,9 @@ mmu_init(void)
|
|||||||
panic("mmu_init(): Failed to add physical memory range "
|
panic("mmu_init(): Failed to add physical memory range "
|
||||||
"%#" B_PRIx64 " - %#" B_PRIx64 "\n", base, end);
|
"%#" B_PRIx64 " - %#" B_PRIx64 "\n", base, end);
|
||||||
}
|
}
|
||||||
|
} else if (extMemoryBlock[i].type == 3) {
|
||||||
|
// ACPI reclaim -- physical memory we could actually use later
|
||||||
|
gKernelArgs.ignored_physical_memory += extMemoryBlock[i].length;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user