aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorYu-Chien Peter Lin <peter.lin@sifive.com>2026-03-11 20:51:15 +0800
committerAnup Patel <anup@brainfault.org>2026-04-08 17:58:05 +0530
commitff7d245b86daa36aa36147022fa583e79ffe25cc (patch)
treea713aeb93bbfccce15a2074f5be3f3d92874da29 /include
parent0b041e58c0787f76325da5081e41a13bf304d328 (diff)
downloadopensbi-ff7d245b86daa36aa36147022fa583e79ffe25cc.tar.gz
opensbi-ff7d245b86daa36aa36147022fa583e79ffe25cc.tar.bz2
opensbi-ff7d245b86daa36aa36147022fa583e79ffe25cc.zip
include: sbi_bitmap: add bitmap_empty() function
Add bitmap_empty() to check if bitmap has no bits set. Unlike bitmap_weight() which calls sbi_popcount() on every word, bitmap_empty() uses simple non-zero comparisons with early exit. Signed-off-by: Yu-Chien Peter Lin <peter.lin@sifive.com> Reviewed-by: Anup Patel <anup@brainfault.org> Link: https://lore.kernel.org/r/20260311125116.1401002-1-peter.lin@sifive.com Signed-off-by: Anup Patel <anup@brainfault.org>
Diffstat (limited to 'include')
-rw-r--r--include/sbi/sbi_bitmap.h16
1 files changed, 16 insertions, 0 deletions
diff --git a/include/sbi/sbi_bitmap.h b/include/sbi/sbi_bitmap.h
index 596bcc7d..80d3fe3b 100644
--- a/include/sbi/sbi_bitmap.h
+++ b/include/sbi/sbi_bitmap.h
@@ -143,4 +143,20 @@ static inline int bitmap_weight(const unsigned long *src, int nbits)
return res;
}
+static inline bool bitmap_empty(const unsigned long *src, int nbits)
+{
+ if (nbits == 0)
+ return true;
+
+ if (small_const_nbits(nbits))
+ return !(*src & BITMAP_LAST_WORD_MASK(nbits));
+ else {
+ size_t i, len = BITS_TO_LONGS(nbits);
+ for (i = 0; i < len - 1; i++)
+ if (src[i])
+ return false;
+ return !(src[len - 1] & BITMAP_LAST_WORD_MASK(nbits));
+ }
+}
+
#endif