mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-10 15:19:51 +00:00
[POWERPC] Flush registers to proper task context
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>
This commit is contained in:
parent
b07d68b5ca
commit
0ee6c15e7b
@ -83,7 +83,7 @@ void flush_fp_to_thread(struct task_struct *tsk)
|
||||
*/
|
||||
BUG_ON(tsk != current);
|
||||
#endif
|
||||
giveup_fpu(current);
|
||||
giveup_fpu(tsk);
|
||||
}
|
||||
preempt_enable();
|
||||
}
|
||||
@ -143,7 +143,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();
|
||||
}
|
||||
@ -182,7 +182,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();
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user