mirror of
https://github.com/openvswitch/ovs
synced 2025-09-01 14:55:18 +00:00
util: New function raw_ctz().
This will acquire a user in an upcoming commit. Signed-off-by: Ben Pfaff <blp@nicira.com>
This commit is contained in:
16
lib/util.c
16
lib/util.c
@@ -790,18 +790,15 @@ log_2_ceil(uint32_t n)
|
|||||||
return log_2_floor(n) + !IS_POW2(n);
|
return log_2_floor(n) + !IS_POW2(n);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Returns the number of trailing 0-bits in 'n', or 32 if 'n' is 0. */
|
/* Returns the number of trailing 0-bits in 'n'. Undefined if 'n' == 0. */
|
||||||
int
|
|
||||||
ctz(uint32_t n)
|
|
||||||
{
|
|
||||||
if (!n) {
|
|
||||||
return 32;
|
|
||||||
} else {
|
|
||||||
#if !defined(UINT_MAX) || !defined(UINT32_MAX)
|
#if !defined(UINT_MAX) || !defined(UINT32_MAX)
|
||||||
#error "Someone screwed up the #includes."
|
#error "Someone screwed up the #includes."
|
||||||
#elif __GNUC__ >= 4 && UINT_MAX == UINT32_MAX
|
#elif __GNUC__ >= 4 && UINT_MAX == UINT32_MAX
|
||||||
return __builtin_ctz(n);
|
/* Defined inline in util.h. */
|
||||||
#else
|
#else
|
||||||
|
static int
|
||||||
|
raw_ctz(uint32_t n)
|
||||||
|
{
|
||||||
unsigned int k;
|
unsigned int k;
|
||||||
int count = 31;
|
int count = 31;
|
||||||
|
|
||||||
@@ -819,9 +816,8 @@ ctz(uint32_t n)
|
|||||||
#undef CTZ_STEP
|
#undef CTZ_STEP
|
||||||
|
|
||||||
return count;
|
return count;
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Returns the number of 1-bits in 'x', between 0 and 32 inclusive. */
|
/* Returns the number of 1-bits in 'x', between 0 and 32 inclusive. */
|
||||||
int
|
int
|
||||||
|
25
lib/util.h
25
lib/util.h
@@ -242,9 +242,32 @@ char *xreadlink(const char *filename);
|
|||||||
char *follow_symlinks(const char *filename);
|
char *follow_symlinks(const char *filename);
|
||||||
|
|
||||||
void ignore(bool x OVS_UNUSED);
|
void ignore(bool x OVS_UNUSED);
|
||||||
|
|
||||||
|
/* Returns the number of trailing 0-bits in 'n'. Undefined if 'n' == 0.
|
||||||
|
*
|
||||||
|
* This compiles to a single machine instruction ("bsf") with GCC on x86. */
|
||||||
|
#if !defined(UINT_MAX) || !defined(UINT32_MAX)
|
||||||
|
#error "Someone screwed up the #includes."
|
||||||
|
#elif __GNUC__ >= 4 && UINT_MAX == UINT32_MAX
|
||||||
|
static inline int
|
||||||
|
raw_ctz(uint32_t n)
|
||||||
|
{
|
||||||
|
return __builtin_ctz(n);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
/* Defined in util.c. */
|
||||||
|
int raw_ctz(uint32_t n);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Returns the number of trailing 0-bits in 'n', or 32 if 'n' is 0. */
|
||||||
|
static inline int
|
||||||
|
ctz(uint32_t n)
|
||||||
|
{
|
||||||
|
return n ? raw_ctz(n) : 32;
|
||||||
|
}
|
||||||
|
|
||||||
int log_2_floor(uint32_t);
|
int log_2_floor(uint32_t);
|
||||||
int log_2_ceil(uint32_t);
|
int log_2_ceil(uint32_t);
|
||||||
int ctz(uint32_t);
|
|
||||||
int popcount(uint32_t);
|
int popcount(uint32_t);
|
||||||
|
|
||||||
bool is_all_zeros(const uint8_t *, size_t);
|
bool is_all_zeros(const uint8_t *, size_t);
|
||||||
|
Reference in New Issue
Block a user