|
@@ -341,6 +341,27 @@ GLOBAL(early_recursion_flag)
|
|
|
.balign PAGE_SIZE; \
|
|
|
GLOBAL(name)
|
|
|
|
|
|
+#ifdef CONFIG_PAGE_TABLE_ISOLATION
|
|
|
+/*
|
|
|
+ * Each PGD needs to be 8k long and 8k aligned. We do not
|
|
|
+ * ever go out to userspace with these, so we do not
|
|
|
+ * strictly *need* the second page, but this allows us to
|
|
|
+ * have a single set_pgd() implementation that does not
|
|
|
+ * need to worry about whether it has 4k or 8k to work
|
|
|
+ * with.
|
|
|
+ *
|
|
|
+ * This ensures PGDs are 8k long:
|
|
|
+ */
|
|
|
+#define PTI_USER_PGD_FILL 512
|
|
|
+/* This ensures they are 8k-aligned: */
|
|
|
+#define NEXT_PGD_PAGE(name) \
|
|
|
+ .balign 2 * PAGE_SIZE; \
|
|
|
+GLOBAL(name)
|
|
|
+#else
|
|
|
+#define NEXT_PGD_PAGE(name) NEXT_PAGE(name)
|
|
|
+#define PTI_USER_PGD_FILL 0
|
|
|
+#endif
|
|
|
+
|
|
|
/* Automate the creation of 1 to 1 mapping pmd entries */
|
|
|
#define PMDS(START, PERM, COUNT) \
|
|
|
i = 0 ; \
|
|
@@ -350,13 +371,14 @@ GLOBAL(name)
|
|
|
.endr
|
|
|
|
|
|
__INITDATA
|
|
|
-NEXT_PAGE(early_top_pgt)
|
|
|
+NEXT_PGD_PAGE(early_top_pgt)
|
|
|
.fill 511,8,0
|
|
|
#ifdef CONFIG_X86_5LEVEL
|
|
|
.quad level4_kernel_pgt - __START_KERNEL_map + _PAGE_TABLE_NOENC
|
|
|
#else
|
|
|
.quad level3_kernel_pgt - __START_KERNEL_map + _PAGE_TABLE_NOENC
|
|
|
#endif
|
|
|
+ .fill PTI_USER_PGD_FILL,8,0
|
|
|
|
|
|
NEXT_PAGE(early_dynamic_pgts)
|
|
|
.fill 512*EARLY_DYNAMIC_PAGE_TABLES,8,0
|
|
@@ -364,13 +386,14 @@ NEXT_PAGE(early_dynamic_pgts)
|
|
|
.data
|
|
|
|
|
|
#if defined(CONFIG_XEN_PV) || defined(CONFIG_XEN_PVH)
|
|
|
-NEXT_PAGE(init_top_pgt)
|
|
|
+NEXT_PGD_PAGE(init_top_pgt)
|
|
|
.quad level3_ident_pgt - __START_KERNEL_map + _KERNPG_TABLE_NOENC
|
|
|
.org init_top_pgt + PGD_PAGE_OFFSET*8, 0
|
|
|
.quad level3_ident_pgt - __START_KERNEL_map + _KERNPG_TABLE_NOENC
|
|
|
.org init_top_pgt + PGD_START_KERNEL*8, 0
|
|
|
/* (2^48-(2*1024*1024*1024))/(2^39) = 511 */
|
|
|
.quad level3_kernel_pgt - __START_KERNEL_map + _PAGE_TABLE_NOENC
|
|
|
+ .fill PTI_USER_PGD_FILL,8,0
|
|
|
|
|
|
NEXT_PAGE(level3_ident_pgt)
|
|
|
.quad level2_ident_pgt - __START_KERNEL_map + _KERNPG_TABLE_NOENC
|
|
@@ -381,8 +404,9 @@ NEXT_PAGE(level2_ident_pgt)
|
|
|
*/
|
|
|
PMDS(0, __PAGE_KERNEL_IDENT_LARGE_EXEC, PTRS_PER_PMD)
|
|
|
#else
|
|
|
-NEXT_PAGE(init_top_pgt)
|
|
|
+NEXT_PGD_PAGE(init_top_pgt)
|
|
|
.fill 512,8,0
|
|
|
+ .fill PTI_USER_PGD_FILL,8,0
|
|
|
#endif
|
|
|
|
|
|
#ifdef CONFIG_X86_5LEVEL
|