From: aurel32 Date: Sat, 1 Nov 2008 00:54:33 +0000 (+0000) Subject: target-ppc: optimize popcntb X-Git-Tag: stefano.display-merge-start~197 X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=6176a26d1d0fe40dea0fd6a4e1a437931cbdcb2d;p=qemu-xen-4.0-testing.git target-ppc: optimize popcntb Suggested by Andrzej Zaborowski. Signed-off-by: Aurelien Jarno git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@5592 c046a42c-6fe2-441c-8c8c-71466251a162 --- diff --git a/target-ppc/op_helper.c b/target-ppc/op_helper.c index ef1035fc..b1a88b52 100644 --- a/target-ppc/op_helper.c +++ b/target-ppc/op_helper.c @@ -222,25 +222,19 @@ target_ulong helper_srad (target_ulong value, target_ulong shift) target_ulong helper_popcntb (target_ulong val) { - uint32_t ret; - int i; - - ret = 0; - for (i = 0; i < 32; i += 8) - ret |= ctpop8((val >> i) & 0xFF) << i; - return ret; + val = (val & 0x55555555) + ((val >> 1) & 0x55555555); + val = (val & 0x33333333) + ((val >> 2) & 0x33333333); + val = (val & 0x0f0f0f0f) + ((val >> 4) & 0x0f0f0f0f); + return val; } #if defined(TARGET_PPC64) target_ulong helper_popcntb_64 (target_ulong val) { - uint64_t ret; - int i; - - ret = 0; - for (i = 0; i < 64; i += 8) - ret |= ctpop8((val >> i) & 0xFF) << i; - return ret; + val = (val & 0x5555555555555555ULL) + ((val >> 1) & 0x5555555555555555ULL); + val = (val & 0x3333333333333333ULL) + ((val >> 2) & 0x3333333333333333ULL); + val = (val & 0x0f0f0f0f0f0f0f0fULL) + ((val >> 4) & 0x0f0f0f0f0f0f0f0fULL); + return val; } #endif