powerpc/e500: Save SPEFCSR in flush_spe_to_thread()
authoryu liu <yu.liu@freescale.com>
Tue, 14 Jun 2011 23:34:25 +0000 (18:34 -0500)
committerAvi Kivity <avi@redhat.com>
Tue, 12 Jul 2011 10:16:30 +0000 (13:16 +0300)
commit685659ee70db0bac47ffd619c726cf600e504fd7
tree80d17e740132295a77732b539ce620203c3646ba
parenta22a2daccfa3ade5cdd9ef1e8a05cf1e6ffca42b
powerpc/e500: Save SPEFCSR in flush_spe_to_thread()

giveup_spe() saves the SPE state which is protected by MSR[SPE].
However, modifying SPEFSCR does not trap when MSR[SPE]=0.
And since SPEFSCR is already saved/restored in _switch(),
not all the callers want to save SPEFSCR again.
Thus, saving SPEFSCR should not belong to giveup_spe().

This patch moves SPEFSCR saving to flush_spe_to_thread(),
and cleans up the caller that needs to save SPEFSCR accordingly.

Signed-off-by: Liu Yu <yu.liu@freescale.com>
Acked-by: Kumar Gala <galak@kernel.crashing.org>
Signed-off-by: Scott Wood <scottwood@freescale.com>
Signed-off-by: Alexander Graf <agraf@suse.de>
arch/powerpc/kernel/head_fsl_booke.S
arch/powerpc/kernel/process.c
arch/powerpc/kernel/traps.c