powerpc: Fix emulation of mfocrf in emulate_step()
authorAnton Blanchard <anton@samba.org>
Wed, 14 Jun 2017 23:46:39 +0000 (09:46 +1000)
committerBen Hutchings <ben@decadent.org.uk>
Thu, 12 Oct 2017 14:27:16 +0000 (15:27 +0100)
commit8712783ddcba8851207e852b6acd2e0950e496b5
treed3b4ca2058011470d5dfebacb30b870e44de05ae
parent19660de3f6528fba95eaaf322a997fbb1f241c1b
powerpc: Fix emulation of mfocrf in emulate_step()

commit 64e756c55aa46fc18fd53e8f3598b73b528d8637 upstream.

From POWER4 onwards, mfocrf() only places the specified CR field into
the destination GPR, and the rest of it is set to 0. The PowerPC AS
from version 3.0 now requires this behaviour.

The emulation code currently puts the entire CR into the destination GPR.
Fix it.

Fixes: 6888199f7fe5 ("[POWERPC] Emulate more instructions in software")
Signed-off-by: Anton Blanchard <anton@samba.org>
Acked-by: Naveen N. Rao <naveen.n.rao@linux.vnet.ibm.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
Signed-off-by: Ben Hutchings <ben@decadent.org.uk>
arch/powerpc/lib/sstep.c