diff options
Diffstat (limited to 'arch/x86/boot/compressed/pgtable_64.c')
| -rw-r--r-- | arch/x86/boot/compressed/pgtable_64.c | 28 | 
1 files changed, 28 insertions, 0 deletions
| diff --git a/arch/x86/boot/compressed/pgtable_64.c b/arch/x86/boot/compressed/pgtable_64.c new file mode 100644 index 000000000000..b4469a37e9a1 --- /dev/null +++ b/arch/x86/boot/compressed/pgtable_64.c @@ -0,0 +1,28 @@ +#include <asm/processor.h> + +/* + * __force_order is used by special_insns.h asm code to force instruction + * serialization. + * + * It is not referenced from the code, but GCC < 5 with -fPIE would fail + * due to an undefined symbol. Define it to make these ancient GCCs work. + */ +unsigned long __force_order; + +int l5_paging_required(void) +{ +	/* Check if leaf 7 is supported. */ + +	if (native_cpuid_eax(0) < 7) +		return 0; + +	/* Check if la57 is supported. */ +	if (!(native_cpuid_ecx(7) & (1 << (X86_FEATURE_LA57 & 31)))) +		return 0; + +	/* Check if 5-level paging has already been enabled. */ +	if (native_read_cr4() & X86_CR4_LA57) +		return 0; + +	return 1; +} |