Correct ppc popcntb logic, implement popcntw and popcntd
commiteaabeef2688cdc7da462e9389fce64b1178de8ce
authorDavid Gibson <dwg@au1.ibm.com>
Fri, 1 Apr 2011 04:15:13 +0000 (1 15:15 +1100)
committerAlexander Graf <agraf@suse.de>
Fri, 1 Apr 2011 16:34:54 +0000 (1 18:34 +0200)
treeef6cdeb809d8570b404d859faa7d4a25864b18e7
parent3a7f009abc010827815f10805e3558aa64c98e59
Correct ppc popcntb logic, implement popcntw and popcntd

qemu already includes support for the popcntb instruction introduced
in POWER5 (although it doesn't actually allow you to choose POWER5).

However, the logic is slightly incorrect: it will generate results
truncated to 32-bits when the CPU is in 32-bit mode.  This is not
normal for powerpc - generally arithmetic instructions on a 64-bit
powerpc cpu will generate full 64 bit results, it's just that only the
low 32 bits will be significant for condition codes.

This patch corrects this nit, which actually simplifies the code slightly.

In addition, this patch implements the popcntw and popcntd
instructions added in POWER7, in preparation for allowing POWER7 as an
emulated CPU.

Signed-off-by: David Gibson <dwg@au1.ibm.com>
Signed-off-by: Alexander Graf <agraf@suse.de>
target-ppc/cpu.h
target-ppc/helper.h
target-ppc/op_helper.c
target-ppc/translate.c