Merge tag 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mst/vhost
[cris-mirror.git] / tools / lib / bitmap.c
blob38748b0e342f76f9010f927659884859e823a3b5
1 /*
2 * From lib/bitmap.c
3 * Helper functions for bitmap.h.
5 * This source code is licensed under the GNU General Public License,
6 * Version 2. See the file COPYING for more details.
7 */
8 #include <linux/bitmap.h>
10 int __bitmap_weight(const unsigned long *bitmap, int bits)
12 int k, w = 0, lim = bits/BITS_PER_LONG;
14 for (k = 0; k < lim; k++)
15 w += hweight_long(bitmap[k]);
17 if (bits % BITS_PER_LONG)
18 w += hweight_long(bitmap[k] & BITMAP_LAST_WORD_MASK(bits));
20 return w;
23 void __bitmap_or(unsigned long *dst, const unsigned long *bitmap1,
24 const unsigned long *bitmap2, int bits)
26 int k;
27 int nr = BITS_TO_LONGS(bits);
29 for (k = 0; k < nr; k++)
30 dst[k] = bitmap1[k] | bitmap2[k];
33 size_t bitmap_scnprintf(unsigned long *bitmap, int nbits,
34 char *buf, size_t size)
36 /* current bit is 'cur', most recently seen range is [rbot, rtop] */
37 int cur, rbot, rtop;
38 bool first = true;
39 size_t ret = 0;
41 rbot = cur = find_first_bit(bitmap, nbits);
42 while (cur < nbits) {
43 rtop = cur;
44 cur = find_next_bit(bitmap, nbits, cur + 1);
45 if (cur < nbits && cur <= rtop + 1)
46 continue;
48 if (!first)
49 ret += scnprintf(buf + ret, size - ret, ",");
51 first = false;
53 ret += scnprintf(buf + ret, size - ret, "%d", rbot);
54 if (rbot < rtop)
55 ret += scnprintf(buf + ret, size - ret, "-%d", rtop);
57 rbot = cur;
59 return ret;
62 int __bitmap_and(unsigned long *dst, const unsigned long *bitmap1,
63 const unsigned long *bitmap2, unsigned int bits)
65 unsigned int k;
66 unsigned int lim = bits/BITS_PER_LONG;
67 unsigned long result = 0;
69 for (k = 0; k < lim; k++)
70 result |= (dst[k] = bitmap1[k] & bitmap2[k]);
71 if (bits % BITS_PER_LONG)
72 result |= (dst[k] = bitmap1[k] & bitmap2[k] &
73 BITMAP_LAST_WORD_MASK(bits));
74 return result != 0;