diff options
Diffstat (limited to 'arch/nds32/kernel/setup.c')
| -rw-r--r-- | arch/nds32/kernel/setup.c | 22 | 
1 files changed, 19 insertions, 3 deletions
| diff --git a/arch/nds32/kernel/setup.c b/arch/nds32/kernel/setup.c index eacc79024879..31d29d92478e 100644 --- a/arch/nds32/kernel/setup.c +++ b/arch/nds32/kernel/setup.c @@ -15,6 +15,7 @@  #include <asm/proc-fns.h>  #include <asm/cache_info.h>  #include <asm/elf.h> +#include <asm/fpu.h>  #include <nds32_intrinsic.h>  #define HWCAP_MFUSR_PC		0x000001 @@ -38,8 +39,10 @@  #define HWCAP_FPU_DP		0x040000  #define HWCAP_V2		0x080000  #define HWCAP_DX_REGS		0x100000 +#define HWCAP_HWPRE		0x200000  unsigned long cpu_id, cpu_rev, cpu_cfgid; +bool has_fpu = false;  char cpu_series;  char *endianness = NULL; @@ -70,8 +73,10 @@ static const char *hwcap_str[] = {  	"div",  	"mac",  	"l2c", -	"dx_regs", +	"fpu_dp",  	"v2", +	"dx_regs", +	"hw_pre",  	NULL,  }; @@ -136,6 +141,11 @@ static void __init dump_cpu_info(int cpu)  		    (aliasing_num - 1) << PAGE_SHIFT;  	}  #endif +#ifdef CONFIG_FPU +	/* Disable fpu and enable when it is used. */ +	if (has_fpu) +		disable_fpu(); +#endif  }  static void __init setup_cpuinfo(void) @@ -180,9 +190,10 @@ static void __init setup_cpuinfo(void)  	if (cpu_cfgid & 0x0004)  		elf_hwcap |= HWCAP_EXT2; -	if (cpu_cfgid & 0x0008) +	if (cpu_cfgid & 0x0008) {  		elf_hwcap |= HWCAP_FPU; - +		has_fpu = true; +	}  	if (cpu_cfgid & 0x0010)  		elf_hwcap |= HWCAP_STRING; @@ -212,6 +223,11 @@ static void __init setup_cpuinfo(void)  	if (__nds32__mfsr(NDS32_SR_MSC_CFG) & MSC_CFG_mskL2C)  		elf_hwcap |= HWCAP_L2C; +#ifdef CONFIG_HW_PRE +	if (__nds32__mfsr(NDS32_SR_MISC_CTL) & MISC_CTL_makHWPRE_EN) +		elf_hwcap |= HWCAP_HWPRE; +#endif +  	tmp = __nds32__mfsr(NDS32_SR_CACHE_CTL);  	if (!IS_ENABLED(CONFIG_CPU_DCACHE_DISABLE))  		tmp |= CACHE_CTL_mskDC_EN; | 
