Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'source/blender/blenlib/intern/math_bits_inline.c')
-rw-r--r--source/blender/blenlib/intern/math_bits_inline.c106
1 files changed, 59 insertions, 47 deletions
diff --git a/source/blender/blenlib/intern/math_bits_inline.c b/source/blender/blenlib/intern/math_bits_inline.c
index d86b2924e17..ec2408e30a1 100644
--- a/source/blender/blenlib/intern/math_bits_inline.c
+++ b/source/blender/blenlib/intern/math_bits_inline.c
@@ -30,121 +30,133 @@
MINLINE int bitscan_forward_i(int a)
{
- BLI_assert(a != 0);
+ BLI_assert(a != 0);
#ifdef _MSC_VER
- unsigned long ctz;
- _BitScanForward(&ctz, a);
- return ctz;
+ unsigned long ctz;
+ _BitScanForward(&ctz, a);
+ return ctz;
#else
- return __builtin_ctz((unsigned int)a);
+ return __builtin_ctz((unsigned int)a);
#endif
}
MINLINE unsigned int bitscan_forward_uint(unsigned int a)
{
- return (unsigned int)bitscan_forward_i((int)a);
+ return (unsigned int)bitscan_forward_i((int)a);
}
MINLINE int bitscan_forward_clear_i(int *a)
{
- int i = bitscan_forward_i(*a);
- *a &= (*a) - 1;
- return i;
+ int i = bitscan_forward_i(*a);
+ *a &= (*a) - 1;
+ return i;
}
MINLINE unsigned int bitscan_forward_clear_uint(unsigned int *a)
{
- return (unsigned int)bitscan_forward_clear_i((int *)a);
+ return (unsigned int)bitscan_forward_clear_i((int *)a);
}
MINLINE int bitscan_reverse_i(int a)
{
- BLI_assert(a != 0);
+ BLI_assert(a != 0);
#ifdef _MSC_VER
- unsigned long clz;
- _BitScanReverse(&clz, a);
- return clz;
+ unsigned long clz;
+ _BitScanReverse(&clz, a);
+ return clz;
#else
- return __builtin_clz((unsigned int)a);
+ return __builtin_clz((unsigned int)a);
#endif
}
MINLINE unsigned int bitscan_reverse_uint(unsigned int a)
{
- return (unsigned int)bitscan_reverse_i((int)a);
+ return (unsigned int)bitscan_reverse_i((int)a);
}
MINLINE int bitscan_reverse_clear_i(int *a)
{
- int i = bitscan_reverse_i(*a);
- /* TODO(sergey): This could probably be optimized. */
- *a &= ~(1 << (sizeof(int) * 8 - i - 1));
- return i;
+ int i = bitscan_reverse_i(*a);
+ /* TODO(sergey): This could probably be optimized. */
+ *a &= ~(1 << (sizeof(int) * 8 - i - 1));
+ return i;
}
MINLINE unsigned int bitscan_reverse_clear_uint(unsigned int *a)
{
- return (unsigned int)bitscan_reverse_clear_i((int *)a);
+ return (unsigned int)bitscan_reverse_clear_i((int *)a);
}
MINLINE unsigned int highest_order_bit_uint(unsigned int n)
{
- if (n == 0) {
- return 0;
- }
- return 1 << (sizeof(unsigned int) * 8 - bitscan_reverse_uint(n));
+ if (n == 0) {
+ return 0;
+ }
+ return 1 << (sizeof(unsigned int) * 8 - bitscan_reverse_uint(n));
}
MINLINE unsigned short highest_order_bit_s(unsigned short n)
{
- n |= (n >> 1);
- n |= (n >> 2);
- n |= (n >> 4);
- n |= (n >> 8);
- return (unsigned short)(n - (n >> 1));
+ n |= (n >> 1);
+ n |= (n >> 2);
+ n |= (n >> 4);
+ n |= (n >> 8);
+ return (unsigned short)(n - (n >> 1));
}
#ifndef __GNUC__
MINLINE int count_bits_i(unsigned int i)
{
- /* variable-precision SWAR algorithm. */
- i = i - ((i >> 1) & 0x55555555);
- i = (i & 0x33333333) + ((i >> 2) & 0x33333333);
- return (((i + (i >> 4)) & 0x0F0F0F0F) * 0x01010101) >> 24;
+ /* variable-precision SWAR algorithm. */
+ i = i - ((i >> 1) & 0x55555555);
+ i = (i & 0x33333333) + ((i >> 2) & 0x33333333);
+ return (((i + (i >> 4)) & 0x0F0F0F0F) * 0x01010101) >> 24;
}
#endif
MINLINE int float_as_int(float f)
{
- union { int i; float f; } u;
- u.f = f;
- return u.i;
+ union {
+ int i;
+ float f;
+ } u;
+ u.f = f;
+ return u.i;
}
MINLINE unsigned int float_as_uint(float f)
{
- union { unsigned int i; float f; } u;
- u.f = f;
- return u.i;
+ union {
+ unsigned int i;
+ float f;
+ } u;
+ u.f = f;
+ return u.i;
}
MINLINE float int_as_float(int i)
{
- union { int i; float f; } u;
- u.i = i;
- return u.f;
+ union {
+ int i;
+ float f;
+ } u;
+ u.i = i;
+ return u.f;
}
MINLINE float uint_as_float(unsigned int i)
{
- union { unsigned int i; float f; } u;
- u.i = i;
- return u.f;
+ union {
+ unsigned int i;
+ float f;
+ } u;
+ u.i = i;
+ return u.f;
}
MINLINE float xor_fl(float x, int y)
{
- return int_as_float(float_as_int(x) ^ y);
+ return int_as_float(float_as_int(x) ^ y);
}
#endif /* __MATH_BITS_INLINE_C__ */