x86: Fix bit corruption at CPU resume time
In commit 78d77df715
("x86-64, init: Do not set NX bits on non-NX
capable hardware") we added the early_pmd_flags that gets the NX bit set
when a CPU supports NX. However, the new variable was marked __initdata,
because the main _use_ of this is in an __init routine.
However, the bit setting happens from secondary_startup_64(), which is
called not only at bootup, but on every secondary CPU start. Including
resuming from STR and at CPU hotplug time. So the value cannot be
__initdata.
Reported-bisected-and-tested-by: Michal Hocko <mhocko@suse.cz>
Cc: stable@vger.kernel.org # v3.9
Acked-by: Peter Anvin <hpa@linux.intel.com>
Cc: Fernando Luis Vázquez Cao <fernando@oss.ntt.co.jp>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
2c2c0e5231
commit
5e427ec2d0
1 changed files with 1 additions and 1 deletions
|
@ -34,7 +34,7 @@
|
||||||
extern pgd_t early_level4_pgt[PTRS_PER_PGD];
|
extern pgd_t early_level4_pgt[PTRS_PER_PGD];
|
||||||
extern pmd_t early_dynamic_pgts[EARLY_DYNAMIC_PAGE_TABLES][PTRS_PER_PMD];
|
extern pmd_t early_dynamic_pgts[EARLY_DYNAMIC_PAGE_TABLES][PTRS_PER_PMD];
|
||||||
static unsigned int __initdata next_early_pgt = 2;
|
static unsigned int __initdata next_early_pgt = 2;
|
||||||
pmdval_t __initdata early_pmd_flags = __PAGE_KERNEL_LARGE & ~(_PAGE_GLOBAL | _PAGE_NX);
|
pmdval_t early_pmd_flags = __PAGE_KERNEL_LARGE & ~(_PAGE_GLOBAL | _PAGE_NX);
|
||||||
|
|
||||||
/* Wipe all early page tables except for the kernel symbol map */
|
/* Wipe all early page tables except for the kernel symbol map */
|
||||||
static void __init reset_early_page_tables(void)
|
static void __init reset_early_page_tables(void)
|
||||||
|
|
Loading…
Reference in a new issue