diff options
| author | Edward O'Callaghan <eocallaghan@auroraux.org> | 2009-08-07 20:30:09 +0000 |
|---|---|---|
| committer | Edward O'Callaghan <eocallaghan@auroraux.org> | 2009-08-07 20:30:09 +0000 |
| commit | 5583632adfc69f3fc056cacdeeb5192a1acba042 (patch) | |
| tree | 9ab45422927f7142d2600dccdd4568a517d08a77 /compiler-rt/lib/popcountti2.c | |
| parent | 40134e71bee0d7a233925b8ed67954ccc5ede6cf (diff) | |
| download | bcm5719-llvm-5583632adfc69f3fc056cacdeeb5192a1acba042.tar.gz bcm5719-llvm-5583632adfc69f3fc056cacdeeb5192a1acba042.zip | |
Code style and Readability fixes. Credit to Craig van Vliet.
llvm-svn: 78403
Diffstat (limited to 'compiler-rt/lib/popcountti2.c')
| -rw-r--r-- | compiler-rt/lib/popcountti2.c | 43 |
1 files changed, 22 insertions, 21 deletions
diff --git a/compiler-rt/lib/popcountti2.c b/compiler-rt/lib/popcountti2.c index 9ac052d9127..16f89b7abab 100644 --- a/compiler-rt/lib/popcountti2.c +++ b/compiler-rt/lib/popcountti2.c @@ -1,21 +1,22 @@ -//===-- popcountti2.c - Implement __popcountti2 ----------------------------===// -// -// The LLVM Compiler Infrastructure -// -// This file is distributed under the University of Illinois Open Source -// License. See LICENSE.TXT for details. -// -//===----------------------------------------------------------------------===// -// -// This file implements __popcountti2 for the compiler_rt library. -// -//===----------------------------------------------------------------------===// +/* ===-- popcountti2.c - Implement __popcountti2 ----------------------------=== + * + * The LLVM Compiler Infrastructure + * + * This file is distributed under the University of Illinois Open Source + * License. See LICENSE.TXT for details. + * + * ===----------------------------------------------------------------------=== + * + * This file implements __popcountti2 for the compiler_rt library. + * + * ===----------------------------------------------------------------------=== + */ #if __x86_64 #include "int_lib.h" -// Returns: count of 1 bits +/* Returns: count of 1 bits */ si_int __popcountti2(ti_int a) @@ -23,21 +24,21 @@ __popcountti2(ti_int a) tu_int x3 = (tu_int)a; x3 = x3 - ((x3 >> 1) & (((tu_int)0x5555555555555555uLL << 64) | 0x5555555555555555uLL)); - // Every 2 bits holds the sum of every pair of bits (64) + /* Every 2 bits holds the sum of every pair of bits (64) */ x3 = ((x3 >> 2) & (((tu_int)0x3333333333333333uLL << 64) | 0x3333333333333333uLL)) + (x3 & (((tu_int)0x3333333333333333uLL << 64) | 0x3333333333333333uLL)); - // Every 4 bits holds the sum of every 4-set of bits (3 significant bits) (32) + /* Every 4 bits holds the sum of every 4-set of bits (3 significant bits) (32) */ x3 = (x3 + (x3 >> 4)) & (((tu_int)0x0F0F0F0F0F0F0F0FuLL << 64) | 0x0F0F0F0F0F0F0F0FuLL); - // Every 8 bits holds the sum of every 8-set of bits (4 significant bits) (16) + /* Every 8 bits holds the sum of every 8-set of bits (4 significant bits) (16) */ du_int x2 = (du_int)(x3 + (x3 >> 64)); - // Every 8 bits holds the sum of every 8-set of bits (5 significant bits) (8) + /* Every 8 bits holds the sum of every 8-set of bits (5 significant bits) (8) */ su_int x = (su_int)(x2 + (x2 >> 32)); - // Every 8 bits holds the sum of every 8-set of bits (6 significant bits) (4) + /* Every 8 bits holds the sum of every 8-set of bits (6 significant bits) (4) */ x = x + (x >> 16); - // Every 8 bits holds the sum of every 8-set of bits (7 significant bits) (2) - // Upper 16 bits are garbage - return (x + (x >> 8)) & 0xFF; // (8 significant bits) + /* Every 8 bits holds the sum of every 8-set of bits (7 significant bits) (2) */ + /* Upper 16 bits are garbage */ + return (x + (x >> 8)) & 0xFF; /* (8 significant bits) */ } #endif |

