mirror of
https://github.com/cathugger/mkp224o.git
synced 2025-01-09 02:57:21 -03:00
32 lines
601 B
C
32 lines
601 B
C
|
|
#ifdef EXPANDMASK
|
|
|
|
#ifdef __GNUC__
|
|
|
|
static IFT ifilter_bitsum(IFT x)
|
|
{
|
|
if (sizeof(IFT) == 16)
|
|
return (((IFT) 1) <<
|
|
(__builtin_popcountll((unsigned long long) (x >> (sizeof(IFT) * 8 / 2))) +
|
|
__builtin_popcountll((unsigned long long) x))) - 1;
|
|
if (sizeof(IFT) == 8)
|
|
return (((IFT) 1) << __builtin_popcountll((unsigned long long) x)) - 1;
|
|
|
|
return (((IFT) 1) << __builtin_popcount((unsigned int) x)) - 1;
|
|
}
|
|
|
|
#else // __GNUC__
|
|
|
|
static IFT ifilter_bitsum(IFT x)
|
|
{
|
|
int v = 0;
|
|
while (x != 0) {
|
|
x &= x - 1;
|
|
v++;
|
|
}
|
|
return (((IFT) 1) << v) - 1;
|
|
}
|
|
|
|
#endif // __GNUC__
|
|
|
|
#endif // EXPANDMASK
|