1 // SPDX-License-Identifier: GPL-2.0-only 1 2 /* 3 * From lib/bitmap.c 4 * Helper functions for bitmap.h. 5 */ 6 #include <linux/bitmap.h> 7 8 unsigned int __bitmap_weight(const unsigned lo 9 { 10 unsigned int k, w = 0, lim = bits/BITS 11 12 for (k = 0; k < lim; k++) 13 w += hweight_long(bitmap[k]); 14 15 if (bits % BITS_PER_LONG) 16 w += hweight_long(bitmap[k] & 17 18 return w; 19 } 20 21 void __bitmap_or(unsigned long *dst, const uns 22 const unsigned long *bitmap2, 23 { 24 int k; 25 int nr = BITS_TO_LONGS(bits); 26 27 for (k = 0; k < nr; k++) 28 dst[k] = bitmap1[k] | bitmap2[ 29 } 30 31 size_t bitmap_scnprintf(unsigned long *bitmap, 32 char *buf, size_t size 33 { 34 /* current bit is 'cur', most recently 35 unsigned int cur, rbot, rtop; 36 bool first = true; 37 size_t ret = 0; 38 39 rbot = cur = find_first_bit(bitmap, nb 40 while (cur < nbits) { 41 rtop = cur; 42 cur = find_next_bit(bitmap, nb 43 if (cur < nbits && cur <= rtop 44 continue; 45 46 if (!first) 47 ret += scnprintf(buf + 48 49 first = false; 50 51 ret += scnprintf(buf + ret, si 52 if (rbot < rtop) 53 ret += scnprintf(buf + 54 55 rbot = cur; 56 } 57 return ret; 58 } 59 60 bool __bitmap_and(unsigned long *dst, const un 61 const unsigned long *bitmap2, 62 { 63 unsigned int k; 64 unsigned int lim = bits/BITS_PER_LONG; 65 unsigned long result = 0; 66 67 for (k = 0; k < lim; k++) 68 result |= (dst[k] = bitmap1[k] 69 if (bits % BITS_PER_LONG) 70 result |= (dst[k] = bitmap1[k] 71 BITMAP_LAST_WORD_MA 72 return result != 0; 73 } 74 75 bool __bitmap_equal(const unsigned long *bitma 76 const unsigned long *bitma 77 { 78 unsigned int k, lim = bits/BITS_PER_LO 79 for (k = 0; k < lim; ++k) 80 if (bitmap1[k] != bitmap2[k]) 81 return false; 82 83 if (bits % BITS_PER_LONG) 84 if ((bitmap1[k] ^ bitmap2[k]) 85 return false; 86 87 return true; 88 } 89 90 bool __bitmap_intersects(const unsigned long * 91 const unsigned long * 92 { 93 unsigned int k, lim = bits/BITS_PER_LO 94 for (k = 0; k < lim; ++k) 95 if (bitmap1[k] & bitmap2[k]) 96 return true; 97 98 if (bits % BITS_PER_LONG) 99 if ((bitmap1[k] & bitmap2[k]) 100 return true; 101 return false; 102 } 103 104 void __bitmap_clear(unsigned long *map, unsign 105 { 106 unsigned long *p = map + BIT_WORD(star 107 const unsigned int size = start + len; 108 int bits_to_clear = BITS_PER_LONG - (s 109 unsigned long mask_to_clear = BITMAP_F 110 111 while (len - bits_to_clear >= 0) { 112 *p &= ~mask_to_clear; 113 len -= bits_to_clear; 114 bits_to_clear = BITS_PER_LONG; 115 mask_to_clear = ~0UL; 116 p++; 117 } 118 if (len) { 119 mask_to_clear &= BITMAP_LAST_W 120 *p &= ~mask_to_clear; 121 } 122 } 123
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.