Merge branch 'linus' into tracing/ftrace
[sfrench/cifs-2.6.git] / arch / x86 / kernel / process_32.c
index a30aa1f2607a7d330c0a8b93d06940222aac8902..61f7481c31ddc001d1824760ed0433fb43de6a53 100644 (file)
@@ -652,8 +652,11 @@ struct task_struct * __switch_to(struct task_struct *prev_p, struct task_struct
        /* If the task has used fpu the last 5 timeslices, just do a full
         * restore of the math state immediately to avoid the trap; the
         * chances of needing FPU soon are obviously high now
+        *
+        * tsk_used_math() checks prevent calling math_state_restore(),
+        * which can sleep in the case of !tsk_used_math()
         */
-       if (next_p->fpu_counter > 5)
+       if (tsk_used_math(next_p) && next_p->fpu_counter > 5)
                math_state_restore();
 
        /*