|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-devel] [PATCH v2 2/3] xen/arm: update page table walk to handle 4 level page table
From: Vijaya Kumar K <Vijaya.Kumar@xxxxxxxxxxxxxxxxxx>
ARM64 supports 4-level page tables. Update page
table walk function to handle 4 levels
Signed-off-by: Vijaya Kumar K <Vijaya.Kumar@xxxxxxxxxxxxxxxxxx>
---
xen/arch/arm/mm.c | 19 +++++++++++++++++--
1 file changed, 17 insertions(+), 2 deletions(-)
diff --git a/xen/arch/arm/mm.c b/xen/arch/arm/mm.c
index 04e3182..ef3c53e 100644
--- a/xen/arch/arm/mm.c
+++ b/xen/arch/arm/mm.c
@@ -162,13 +162,25 @@ static inline void
check_memory_layout_alignment_constraints(void) {
#endif
}
-void dump_pt_walk(lpae_t *first, paddr_t addr)
+void dump_pt_walk(lpae_t *root, paddr_t addr)
{
lpae_t *second = NULL, *third = NULL;
+ lpae_t *first = NULL;
+#ifdef CONFIG_ARM_64
+ if ( zeroeth_table_offset(addr) >= LPAE_ENTRIES )
+ return;
+ printk("0TH[0x%x] = 0x%"PRIpaddr"\n", zeroeth_table_offset(addr),
+ root[zeroeth_table_offset(addr)].bits);
+ if ( !root[zeroeth_table_offset(addr)].walk.valid )
+ goto done;
+
+ first = map_domain_page(root[zeroeth_table_offset(addr)].walk.base);
+#else
+ first = root;
if ( first_table_offset(addr) >= LPAE_ENTRIES )
return;
-
+#endif
printk("1ST[0x%x] = 0x%"PRIpaddr"\n", first_table_offset(addr),
first[first_table_offset(addr)].bits);
if ( !first[first_table_offset(addr)].walk.valid ||
@@ -189,6 +201,9 @@ void dump_pt_walk(lpae_t *first, paddr_t addr)
done:
if (third) unmap_domain_page(third);
if (second) unmap_domain_page(second);
+#ifdef CONFIG_ARM_64
+ if ( first ) unmap_domain_page(first);
+#endif
}
--
1.7.9.5
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |