]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
[POWERPC] Flush registers to proper task context
authorKumar Gala <galak@kernel.crashing.org>
Sat, 6 Oct 2007 21:36:26 +0000 (23:36 +0200)
committerAdrian Bunk <bunk@kernel.org>
Sat, 6 Oct 2007 21:36:26 +0000 (23:36 +0200)
When we flush register state for FP, Altivec, or SPE in flush_*_to_thread
we need to respect the task_struct that the caller has passed to us.

Most cases we are called with current, however sometimes (ptrace) we may
be passed a different task_struct.

This showed up when using gdbserver debugging a simple program that used
floating point. When gdb tried to show the FP regs they all showed up as 0,
because the child's FP registers were never properly flushed to memory.

Signed-off-by: Kumar Gala <galak@kernel.crashing.org>
Signed-off-by: Adrian Bunk <bunk@kernel.org>
arch/powerpc/kernel/process.c

index c225cf154bfeb0f415a4f46cd83cf169c0dfd184..b7b3588bfaabdc92dbeb16948509fa197f029201 100644 (file)
@@ -87,7 +87,7 @@ void flush_fp_to_thread(struct task_struct *tsk)
                         */
                        BUG_ON(tsk != current);
 #endif
-                       giveup_fpu(current);
+                       giveup_fpu(tsk);
                }
                preempt_enable();
        }
@@ -147,7 +147,7 @@ void flush_altivec_to_thread(struct task_struct *tsk)
 #ifdef CONFIG_SMP
                        BUG_ON(tsk != current);
 #endif
-                       giveup_altivec(current);
+                       giveup_altivec(tsk);
                }
                preempt_enable();
        }
@@ -186,7 +186,7 @@ void flush_spe_to_thread(struct task_struct *tsk)
 #ifdef CONFIG_SMP
                        BUG_ON(tsk != current);
 #endif
-                       giveup_spe(current);
+                       giveup_spe(tsk);
                }
                preempt_enable();
        }