Commit f9cca244 authored by Ard Biesheuvel's avatar Ard Biesheuvel Committed by Catalin Marinas

arm64: ptdump: Discover start of vmemmap region at runtime

We will soon reclaim the part of the vmemmap region that covers VA space
that is not addressable by the hardware. To avoid confusion, ensure that
the 'vmemmap start' marker points at the start of the region that is
actually being used for the struct page array, rather than the start of
the region we set aside for it at build time.
Signed-off-by: default avatarArd Biesheuvel <ardb@kernel.org>
Link: https://lore.kernel.org/r/20231213084024.2367360-13-ardb@google.comSigned-off-by: default avatarCatalin Marinas <catalin.marinas@arm.com>
Acked-by: default avatarMark Rutland <mark.rutland@arm.com>
parent 34f879fb
...@@ -346,6 +346,8 @@ void ptdump_check_wx(void) ...@@ -346,6 +346,8 @@ void ptdump_check_wx(void)
static int __init ptdump_init(void) static int __init ptdump_init(void)
{ {
u64 page_offset = _PAGE_OFFSET(vabits_actual);
u64 vmemmap_start = (u64)virt_to_page((void *)page_offset);
struct addr_marker m[] = { struct addr_marker m[] = {
{ PAGE_OFFSET, "Linear Mapping start" }, { PAGE_OFFSET, "Linear Mapping start" },
{ PAGE_END, "Linear Mapping end" }, { PAGE_END, "Linear Mapping end" },
...@@ -357,7 +359,7 @@ static int __init ptdump_init(void) ...@@ -357,7 +359,7 @@ static int __init ptdump_init(void)
{ MODULES_END, "Modules end" }, { MODULES_END, "Modules end" },
{ VMALLOC_START, "vmalloc() area" }, { VMALLOC_START, "vmalloc() area" },
{ VMALLOC_END, "vmalloc() end" }, { VMALLOC_END, "vmalloc() end" },
{ VMEMMAP_START, "vmemmap start" }, { vmemmap_start, "vmemmap start" },
{ VMEMMAP_END, "vmemmap end" }, { VMEMMAP_END, "vmemmap end" },
{ PCI_IO_START, "PCI I/O start" }, { PCI_IO_START, "PCI I/O start" },
{ PCI_IO_END, "PCI I/O end" }, { PCI_IO_END, "PCI I/O end" },
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment