About Social Code
aboutsummaryrefslogtreecommitdiff
path: root/src/util/bitset.h
diff options
context:
space:
mode:
authorChristian Gmeiner <christian.gmeiner@gmail.com>2021-07-09 14:13:51 +0200
committerMarge Bot <eric+marge@anholt.net>2021-09-21 20:25:31 +0000
commit6171bc22436ef3958fd21d1126db55fea4a7e14b (patch)
treefedff7f8fd86efc37c6457645e238151f449debe /src/util/bitset.h
parent0c243b3f9800951da8c78faa8529d0c8d2341858 (diff)
util/bitset: add left shift
Signed-off-by: Christian Gmeiner <christian.gmeiner@gmail.com> Reviewed-by: Rob Clark <robdclark@chromium.org> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/11321>
Diffstat (limited to 'src/util/bitset.h')
-rw-r--r--src/util/bitset.h44
1 files changed, 44 insertions, 0 deletions
diff --git a/src/util/bitset.h b/src/util/bitset.h
index edda9f3406f..88c3673a35b 100644
--- a/src/util/bitset.h
+++ b/src/util/bitset.h
@@ -121,6 +121,21 @@ __bitset_rotate_right(BITSET_WORD *x, unsigned amount, unsigned n)
}
static inline void
+__bitset_rotate_left(BITSET_WORD *x, unsigned amount, unsigned n)
+{
+ assert(amount < BITSET_WORDBITS);
+
+ if (amount == 0)
+ return;
+
+ for (int i = n - 1; i > 0; i--) {
+ x[i] = (x[i] << amount) | (x[i - 1] >> (BITSET_WORDBITS - amount));
+ }
+
+ x[0] = x[0] << amount;
+}
+
+static inline void
__bitset_shr(BITSET_WORD *x, unsigned amount, unsigned n)
{
const unsigned int words = amount / BITSET_WORDBITS;
@@ -143,9 +158,38 @@ __bitset_shr(BITSET_WORD *x, unsigned amount, unsigned n)
__bitset_rotate_right(x, amount, n);
}
+
+static inline void
+__bitset_shl(BITSET_WORD *x, unsigned amount, unsigned n)
+{
+ const int words = amount / BITSET_WORDBITS;
+
+ if (amount == 0)
+ return;
+
+ if (words) {
+ int i;
+
+ for (i = n - 1; i >= words; i--) {
+ x[i] = x[i - words];
+ }
+
+ while (i >= 0) {
+ x[i--] = 0;
+ }
+
+ amount %= BITSET_WORDBITS;
+ }
+
+ __bitset_rotate_left(x, amount, n);
+}
+
#define BITSET_SHR(x, n) \
__bitset_shr(x, n, ARRAY_SIZE(x));
+#define BITSET_SHL(x, n) \
+ __bitset_shl(x, n, ARRAY_SIZE(x));
+
/* bit range operations
*/
#define BITSET_TEST_RANGE(x, b, e) \