From: Nicolai Hähnle Date: Fri, 22 Apr 2016 17:48:19 +0000 (-0500) Subject: gallium/util: add u_bit_consecutive for generating a consecutive range of bits X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=91fb4bb2e999accfca3394a5720516d03868c521;p=mesa.git gallium/util: add u_bit_consecutive for generating a consecutive range of bits There are some undefined behavior subtleties, so having a function to match the u_bit_scan_consecutive_range makes sense. Reviewed-by: Marek Olšák --- diff --git a/src/gallium/auxiliary/util/u_math.h b/src/gallium/auxiliary/util/u_math.h index 4e58e505572..ecb1d636fcc 100644 --- a/src/gallium/auxiliary/util/u_math.h +++ b/src/gallium/auxiliary/util/u_math.h @@ -545,6 +545,18 @@ u_bit_scan_consecutive_range64(uint64_t *mask, int *start, int *count) *mask &= ~(((1llu << *count) - 1) << *start); } +/* Returns a bitfield in which the first count bits starting at start are + * set. + */ +static inline unsigned +u_bit_consecutive(unsigned start, unsigned count) +{ + assert(start + count <= 32); + if (count == 32) + return ~0; + return ((1u << count) - 1) << start; +} + /** * Return float bits. */