mirror of
https://github.com/openvswitch/ovs
synced 2025-09-01 06:45:17 +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);
|
||||
}
|
||||
|
||||
/* Returns the number of trailing 0-bits in 'n', or 32 if 'n' is 0. */
|
||||
int
|
||||
ctz(uint32_t n)
|
||||
{
|
||||
if (!n) {
|
||||
return 32;
|
||||
} else {
|
||||
/* Returns the number of trailing 0-bits in 'n'. Undefined if 'n' == 0. */
|
||||
#if !defined(UINT_MAX) || !defined(UINT32_MAX)
|
||||
#error "Someone screwed up the #includes."
|
||||
#elif __GNUC__ >= 4 && UINT_MAX == UINT32_MAX
|
||||
return __builtin_ctz(n);
|
||||
/* Defined inline in util.h. */
|
||||
#else
|
||||
static int
|
||||
raw_ctz(uint32_t n)
|
||||
{
|
||||
unsigned int k;
|
||||
int count = 31;
|
||||
|
||||
@@ -819,9 +816,8 @@ ctz(uint32_t n)
|
||||
#undef CTZ_STEP
|
||||
|
||||
return count;
|
||||
#endif
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
/* Returns the number of 1-bits in 'x', between 0 and 32 inclusive. */
|
||||
int
|
||||
|
25
lib/util.h
25
lib/util.h
@@ -242,9 +242,32 @@ char *xreadlink(const char *filename);
|
||||
char *follow_symlinks(const char *filename);
|
||||
|
||||
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_ceil(uint32_t);
|
||||
int ctz(uint32_t);
|
||||
int popcount(uint32_t);
|
||||
|
||||
bool is_all_zeros(const uint8_t *, size_t);
|
||||
|
Reference in New Issue
Block a user