MIPS: kernel: process: Do not allow FR=0 on MIPS R6
[cascardo/linux.git] / arch / mips / kernel / process.c
index 4677b4c..696d59e 100644 (file)
@@ -581,6 +581,10 @@ int mips_set_process_fp_mode(struct task_struct *task, unsigned int value)
        if ((value & PR_FP_MODE_FRE) && cpu_has_fpu && !cpu_has_fre)
                return -EOPNOTSUPP;
 
+       /* FR = 0 not supported in MIPS R6 */
+       if (!(value & PR_FP_MODE_FR) && cpu_has_fpu && cpu_has_mips_r6)
+               return -EOPNOTSUPP;
+
        /* Save FP & vector context, then disable FPU & MSA */
        if (task->signal == current->signal)
                lose_fpu(1);