Commit 26456dcf authored by Michael Neuling's avatar Michael Neuling Committed by Benjamin Herrenschmidt

powerpc/vsx: Fix VSX alignment handler for regs 32-63

Fix the VSX alignment handler for VSX registers > 32.  32-63 are stored
in the VMX part of the thread_struct not the FPR part.
Signed-off-by: default avatarMichael Neuling <mikey@neuling.org>
CC: stable@kernel.org (2.6.27 & .28 please)
Signed-off-by: default avatarBenjamin Herrenschmidt <benh@kernel.crashing.org>
parent 0047656e
...@@ -646,11 +646,16 @@ static int emulate_vsx(unsigned char __user *addr, unsigned int reg, ...@@ -646,11 +646,16 @@ static int emulate_vsx(unsigned char __user *addr, unsigned int reg,
unsigned int areg, struct pt_regs *regs, unsigned int areg, struct pt_regs *regs,
unsigned int flags, unsigned int length) unsigned int flags, unsigned int length)
{ {
char *ptr = (char *) &current->thread.TS_FPR(reg); char *ptr;
int ret = 0; int ret = 0;
flush_vsx_to_thread(current); flush_vsx_to_thread(current);
if (reg < 32)
ptr = (char *) &current->thread.TS_FPR(reg);
else
ptr = (char *) &current->thread.vr[reg - 32];
if (flags & ST) if (flags & ST)
ret = __copy_to_user(addr, ptr, length); ret = __copy_to_user(addr, ptr, length);
else { else {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment