aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm64/include/asm/pgtable-hwdef.h
diff options
context:
space:
mode:
authorWill Deacon <will.deacon@arm.com>2018-12-12 11:51:40 +0000
committerWill Deacon <will.deacon@arm.com>2018-12-12 11:51:40 +0000
commit9b31cf493ffa40914e02998381993116e574c651 (patch)
tree424c97293f7f941af7e3aa207dda3f9e08de0091 /arch/arm64/include/asm/pgtable-hwdef.h
parentarm64: fix ARM64_USER_VA_BITS_52 builds (diff)
downloadlinux-dev-9b31cf493ffa40914e02998381993116e574c651.tar.xz
linux-dev-9b31cf493ffa40914e02998381993116e574c651.zip
arm64: mm: Introduce MAX_USER_VA_BITS definition
With the introduction of 52-bit virtual addressing for userspace, we are now in a position where the virtual addressing capability of userspace may exceed that of the kernel. Consequently, the VA_BITS definition cannot be used blindly, since it reflects only the size of kernel virtual addresses. This patch introduces MAX_USER_VA_BITS which is either VA_BITS or 52 depending on whether 52-bit virtual addressing has been configured at build time, removing a few places where the 52 is open-coded based on explicit CONFIG_ guards. Signed-off-by: Will Deacon <will.deacon@arm.com>
Diffstat (limited to 'arch/arm64/include/asm/pgtable-hwdef.h')
-rw-r--r--arch/arm64/include/asm/pgtable-hwdef.h6
1 files changed, 1 insertions, 5 deletions
diff --git a/arch/arm64/include/asm/pgtable-hwdef.h b/arch/arm64/include/asm/pgtable-hwdef.h
index 2a700f7b12d2..54a37660b8c9 100644
--- a/arch/arm64/include/asm/pgtable-hwdef.h
+++ b/arch/arm64/include/asm/pgtable-hwdef.h
@@ -80,11 +80,7 @@
#define PGDIR_SHIFT ARM64_HW_PGTABLE_LEVEL_SHIFT(4 - CONFIG_PGTABLE_LEVELS)
#define PGDIR_SIZE (_AC(1, UL) << PGDIR_SHIFT)
#define PGDIR_MASK (~(PGDIR_SIZE-1))
-#ifdef CONFIG_ARM64_USER_VA_BITS_52
-#define PTRS_PER_PGD (1 << (52 - PGDIR_SHIFT))
-#else
-#define PTRS_PER_PGD (1 << (VA_BITS - PGDIR_SHIFT))
-#endif
+#define PTRS_PER_PGD (1 << (MAX_USER_VA_BITS - PGDIR_SHIFT))
/*
* Section address mask and size definitions.