diff options
-rw-r--r-- | arch/x86/kernel/head64.c | 3 | ||||
-rw-r--r-- | arch/x86/kernel/head_64.S | 1 |
2 files changed, 3 insertions, 1 deletions
diff --git a/arch/x86/kernel/head64.c b/arch/x86/kernel/head64.c index 101ac1a9263e..dab95a85f7f8 100644 --- a/arch/x86/kernel/head64.c +++ b/arch/x86/kernel/head64.c | |||
@@ -34,6 +34,7 @@ | |||
34 | extern pgd_t early_level4_pgt[PTRS_PER_PGD]; | 34 | extern pgd_t early_level4_pgt[PTRS_PER_PGD]; |
35 | extern pmd_t early_dynamic_pgts[EARLY_DYNAMIC_PAGE_TABLES][PTRS_PER_PMD]; | 35 | extern pmd_t early_dynamic_pgts[EARLY_DYNAMIC_PAGE_TABLES][PTRS_PER_PMD]; |
36 | static unsigned int __initdata next_early_pgt = 2; | 36 | static unsigned int __initdata next_early_pgt = 2; |
37 | pmdval_t __initdata early_pmd_flags = __PAGE_KERNEL_LARGE & ~(_PAGE_GLOBAL | _PAGE_NX); | ||
37 | 38 | ||
38 | /* Wipe all early page tables except for the kernel symbol map */ | 39 | /* Wipe all early page tables except for the kernel symbol map */ |
39 | static void __init reset_early_page_tables(void) | 40 | static void __init reset_early_page_tables(void) |
@@ -99,7 +100,7 @@ again: | |||
99 | pmd_p[i] = 0; | 100 | pmd_p[i] = 0; |
100 | *pud_p = (pudval_t)pmd_p - __START_KERNEL_map + phys_base + _KERNPG_TABLE; | 101 | *pud_p = (pudval_t)pmd_p - __START_KERNEL_map + phys_base + _KERNPG_TABLE; |
101 | } | 102 | } |
102 | pmd = (physaddr & PMD_MASK) + (__PAGE_KERNEL_LARGE & ~_PAGE_GLOBAL); | 103 | pmd = (physaddr & PMD_MASK) + early_pmd_flags; |
103 | pmd_p[pmd_index(address)] = pmd; | 104 | pmd_p[pmd_index(address)] = pmd; |
104 | 105 | ||
105 | return 0; | 106 | return 0; |
diff --git a/arch/x86/kernel/head_64.S b/arch/x86/kernel/head_64.S index 6859e9626442..08f7e8039099 100644 --- a/arch/x86/kernel/head_64.S +++ b/arch/x86/kernel/head_64.S | |||
@@ -200,6 +200,7 @@ ENTRY(secondary_startup_64) | |||
200 | btl $20,%edi /* No Execute supported? */ | 200 | btl $20,%edi /* No Execute supported? */ |
201 | jnc 1f | 201 | jnc 1f |
202 | btsl $_EFER_NX, %eax | 202 | btsl $_EFER_NX, %eax |
203 | btsq $_PAGE_BIT_NX,early_pmd_flags(%rip) | ||
203 | 1: wrmsr /* Make changes effective */ | 204 | 1: wrmsr /* Make changes effective */ |
204 | 205 | ||
205 | /* Setup cr0 */ | 206 | /* Setup cr0 */ |