[Kernel] Ignore page size with base addr allocs.
Changes NtAllocateVirtualMemory so that it ignores specified page size when a base address is specified. Fixes a crash seen in N3 demo boot.
This commit is contained in:
parent
96a7908c28
commit
74c95c64d2
|
@ -96,11 +96,18 @@ dword_result_t NtAllocateVirtualMemory(lpdword_t base_addr_ptr,
|
||||||
XELOGW("Game setting EXECUTE bit on allocation");
|
XELOGW("Game setting EXECUTE bit on allocation");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint32_t page_size;
|
||||||
|
if (*base_addr_ptr != 0) {
|
||||||
|
// ignore specified page size when base address is specified.
|
||||||
|
auto heap = kernel_memory()->LookupHeap(*base_addr_ptr);
|
||||||
|
page_size = heap->page_size();
|
||||||
|
} else {
|
||||||
// Adjust size.
|
// Adjust size.
|
||||||
uint32_t page_size = 4096;
|
page_size = 4 * 1024;
|
||||||
if (alloc_type & X_MEM_LARGE_PAGES) {
|
if (alloc_type & X_MEM_LARGE_PAGES) {
|
||||||
page_size = 64 * 1024;
|
page_size = 64 * 1024;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Round the base address down to the nearest page boundary.
|
// Round the base address down to the nearest page boundary.
|
||||||
uint32_t adjusted_base = *base_addr_ptr - (*base_addr_ptr % page_size);
|
uint32_t adjusted_base = *base_addr_ptr - (*base_addr_ptr % page_size);
|
||||||
|
|
Loading…
Reference in New Issue