This source file includes following definitions.
- bitmap_find_next_zero_area
- bitmap_zero
- bitmap_fill
- bitmap_copy
- bitmap_copy_clear_tail
- bitmap_and
- bitmap_or
- bitmap_xor
- bitmap_andnot
- bitmap_complement
- bitmap_equal
- bitmap_or_equal
- bitmap_intersects
- bitmap_subset
- bitmap_empty
- bitmap_full
- bitmap_weight
- bitmap_set
- bitmap_clear
- bitmap_shift_right
- bitmap_shift_left
- bitmap_parse
- bitmap_from_u64
   1 
   2 #ifndef __LINUX_BITMAP_H
   3 #define __LINUX_BITMAP_H
   4 
   5 #ifndef __ASSEMBLY__
   6 
   7 #include <linux/types.h>
   8 #include <linux/bitops.h>
   9 #include <linux/string.h>
  10 #include <linux/kernel.h>
  11 
  12 
  13 
  14 
  15 
  16 
  17 
  18 
  19 
  20 
  21 
  22 
  23 
  24 
  25 
  26 
  27 
  28 
  29 
  30 
  31 
  32 
  33 
  34 
  35 
  36 
  37 
  38 
  39 
  40 
  41 
  42 
  43 
  44 
  45 
  46 
  47 
  48 
  49 
  50 
  51 
  52 
  53 
  54 
  55 
  56 
  57 
  58 
  59 
  60 
  61 
  62 
  63 
  64 
  65 
  66 
  67 
  68 
  69 
  70 
  71 
  72 
  73 
  74 
  75 
  76 
  77 
  78 
  79 
  80 
  81 
  82 
  83 
  84 
  85 
  86 
  87 
  88 
  89 
  90 
  91 
  92 
  93 
  94 
  95 
  96 
  97 
  98 
  99 
 100 
 101 
 102 
 103 
 104 
 105 
 106 
 107 
 108 
 109 
 110 
 111 extern unsigned long *bitmap_alloc(unsigned int nbits, gfp_t flags);
 112 extern unsigned long *bitmap_zalloc(unsigned int nbits, gfp_t flags);
 113 extern void bitmap_free(const unsigned long *bitmap);
 114 
 115 
 116 
 117 
 118 
 119 extern int __bitmap_empty(const unsigned long *bitmap, unsigned int nbits);
 120 extern int __bitmap_full(const unsigned long *bitmap, unsigned int nbits);
 121 extern int __bitmap_equal(const unsigned long *bitmap1,
 122                           const unsigned long *bitmap2, unsigned int nbits);
 123 extern bool __pure __bitmap_or_equal(const unsigned long *src1,
 124                                      const unsigned long *src2,
 125                                      const unsigned long *src3,
 126                                      unsigned int nbits);
 127 extern void __bitmap_complement(unsigned long *dst, const unsigned long *src,
 128                         unsigned int nbits);
 129 extern void __bitmap_shift_right(unsigned long *dst, const unsigned long *src,
 130                                 unsigned int shift, unsigned int nbits);
 131 extern void __bitmap_shift_left(unsigned long *dst, const unsigned long *src,
 132                                 unsigned int shift, unsigned int nbits);
 133 extern int __bitmap_and(unsigned long *dst, const unsigned long *bitmap1,
 134                         const unsigned long *bitmap2, unsigned int nbits);
 135 extern void __bitmap_or(unsigned long *dst, const unsigned long *bitmap1,
 136                         const unsigned long *bitmap2, unsigned int nbits);
 137 extern void __bitmap_xor(unsigned long *dst, const unsigned long *bitmap1,
 138                         const unsigned long *bitmap2, unsigned int nbits);
 139 extern int __bitmap_andnot(unsigned long *dst, const unsigned long *bitmap1,
 140                         const unsigned long *bitmap2, unsigned int nbits);
 141 extern int __bitmap_intersects(const unsigned long *bitmap1,
 142                         const unsigned long *bitmap2, unsigned int nbits);
 143 extern int __bitmap_subset(const unsigned long *bitmap1,
 144                         const unsigned long *bitmap2, unsigned int nbits);
 145 extern int __bitmap_weight(const unsigned long *bitmap, unsigned int nbits);
 146 extern void __bitmap_set(unsigned long *map, unsigned int start, int len);
 147 extern void __bitmap_clear(unsigned long *map, unsigned int start, int len);
 148 
 149 extern unsigned long bitmap_find_next_zero_area_off(unsigned long *map,
 150                                                     unsigned long size,
 151                                                     unsigned long start,
 152                                                     unsigned int nr,
 153                                                     unsigned long align_mask,
 154                                                     unsigned long align_offset);
 155 
 156 
 157 
 158 
 159 
 160 
 161 
 162 
 163 
 164 
 165 
 166 
 167 
 168 static inline unsigned long
 169 bitmap_find_next_zero_area(unsigned long *map,
 170                            unsigned long size,
 171                            unsigned long start,
 172                            unsigned int nr,
 173                            unsigned long align_mask)
 174 {
 175         return bitmap_find_next_zero_area_off(map, size, start, nr,
 176                                               align_mask, 0);
 177 }
 178 
 179 extern int __bitmap_parse(const char *buf, unsigned int buflen, int is_user,
 180                         unsigned long *dst, int nbits);
 181 extern int bitmap_parse_user(const char __user *ubuf, unsigned int ulen,
 182                         unsigned long *dst, int nbits);
 183 extern int bitmap_parselist(const char *buf, unsigned long *maskp,
 184                         int nmaskbits);
 185 extern int bitmap_parselist_user(const char __user *ubuf, unsigned int ulen,
 186                         unsigned long *dst, int nbits);
 187 extern void bitmap_remap(unsigned long *dst, const unsigned long *src,
 188                 const unsigned long *old, const unsigned long *new, unsigned int nbits);
 189 extern int bitmap_bitremap(int oldbit,
 190                 const unsigned long *old, const unsigned long *new, int bits);
 191 extern void bitmap_onto(unsigned long *dst, const unsigned long *orig,
 192                 const unsigned long *relmap, unsigned int bits);
 193 extern void bitmap_fold(unsigned long *dst, const unsigned long *orig,
 194                 unsigned int sz, unsigned int nbits);
 195 extern int bitmap_find_free_region(unsigned long *bitmap, unsigned int bits, int order);
 196 extern void bitmap_release_region(unsigned long *bitmap, unsigned int pos, int order);
 197 extern int bitmap_allocate_region(unsigned long *bitmap, unsigned int pos, int order);
 198 
 199 #ifdef __BIG_ENDIAN
 200 extern void bitmap_copy_le(unsigned long *dst, const unsigned long *src, unsigned int nbits);
 201 #else
 202 #define bitmap_copy_le bitmap_copy
 203 #endif
 204 extern unsigned int bitmap_ord_to_pos(const unsigned long *bitmap, unsigned int ord, unsigned int nbits);
 205 extern int bitmap_print_to_pagebuf(bool list, char *buf,
 206                                    const unsigned long *maskp, int nmaskbits);
 207 
 208 #define BITMAP_FIRST_WORD_MASK(start) (~0UL << ((start) & (BITS_PER_LONG - 1)))
 209 #define BITMAP_LAST_WORD_MASK(nbits) (~0UL >> (-(nbits) & (BITS_PER_LONG - 1)))
 210 
 211 
 212 
 213 
 214 
 215 
 216 #define small_const_nbits(nbits) \
 217         (__builtin_constant_p(nbits) && (nbits) <= BITS_PER_LONG && (nbits) > 0)
 218 
 219 static inline void bitmap_zero(unsigned long *dst, unsigned int nbits)
 220 {
 221         unsigned int len = BITS_TO_LONGS(nbits) * sizeof(unsigned long);
 222         memset(dst, 0, len);
 223 }
 224 
 225 static inline void bitmap_fill(unsigned long *dst, unsigned int nbits)
 226 {
 227         unsigned int len = BITS_TO_LONGS(nbits) * sizeof(unsigned long);
 228         memset(dst, 0xff, len);
 229 }
 230 
 231 static inline void bitmap_copy(unsigned long *dst, const unsigned long *src,
 232                         unsigned int nbits)
 233 {
 234         unsigned int len = BITS_TO_LONGS(nbits) * sizeof(unsigned long);
 235         memcpy(dst, src, len);
 236 }
 237 
 238 
 239 
 240 
 241 static inline void bitmap_copy_clear_tail(unsigned long *dst,
 242                 const unsigned long *src, unsigned int nbits)
 243 {
 244         bitmap_copy(dst, src, nbits);
 245         if (nbits % BITS_PER_LONG)
 246                 dst[nbits / BITS_PER_LONG] &= BITMAP_LAST_WORD_MASK(nbits);
 247 }
 248 
 249 
 250 
 251 
 252 
 253 #if BITS_PER_LONG == 64
 254 extern void bitmap_from_arr32(unsigned long *bitmap, const u32 *buf,
 255                                                         unsigned int nbits);
 256 extern void bitmap_to_arr32(u32 *buf, const unsigned long *bitmap,
 257                                                         unsigned int nbits);
 258 #else
 259 #define bitmap_from_arr32(bitmap, buf, nbits)                   \
 260         bitmap_copy_clear_tail((unsigned long *) (bitmap),      \
 261                         (const unsigned long *) (buf), (nbits))
 262 #define bitmap_to_arr32(buf, bitmap, nbits)                     \
 263         bitmap_copy_clear_tail((unsigned long *) (buf),         \
 264                         (const unsigned long *) (bitmap), (nbits))
 265 #endif
 266 
 267 static inline int bitmap_and(unsigned long *dst, const unsigned long *src1,
 268                         const unsigned long *src2, unsigned int nbits)
 269 {
 270         if (small_const_nbits(nbits))
 271                 return (*dst = *src1 & *src2 & BITMAP_LAST_WORD_MASK(nbits)) != 0;
 272         return __bitmap_and(dst, src1, src2, nbits);
 273 }
 274 
 275 static inline void bitmap_or(unsigned long *dst, const unsigned long *src1,
 276                         const unsigned long *src2, unsigned int nbits)
 277 {
 278         if (small_const_nbits(nbits))
 279                 *dst = *src1 | *src2;
 280         else
 281                 __bitmap_or(dst, src1, src2, nbits);
 282 }
 283 
 284 static inline void bitmap_xor(unsigned long *dst, const unsigned long *src1,
 285                         const unsigned long *src2, unsigned int nbits)
 286 {
 287         if (small_const_nbits(nbits))
 288                 *dst = *src1 ^ *src2;
 289         else
 290                 __bitmap_xor(dst, src1, src2, nbits);
 291 }
 292 
 293 static inline int bitmap_andnot(unsigned long *dst, const unsigned long *src1,
 294                         const unsigned long *src2, unsigned int nbits)
 295 {
 296         if (small_const_nbits(nbits))
 297                 return (*dst = *src1 & ~(*src2) & BITMAP_LAST_WORD_MASK(nbits)) != 0;
 298         return __bitmap_andnot(dst, src1, src2, nbits);
 299 }
 300 
 301 static inline void bitmap_complement(unsigned long *dst, const unsigned long *src,
 302                         unsigned int nbits)
 303 {
 304         if (small_const_nbits(nbits))
 305                 *dst = ~(*src);
 306         else
 307                 __bitmap_complement(dst, src, nbits);
 308 }
 309 
 310 #ifdef __LITTLE_ENDIAN
 311 #define BITMAP_MEM_ALIGNMENT 8
 312 #else
 313 #define BITMAP_MEM_ALIGNMENT (8 * sizeof(unsigned long))
 314 #endif
 315 #define BITMAP_MEM_MASK (BITMAP_MEM_ALIGNMENT - 1)
 316 
 317 static inline int bitmap_equal(const unsigned long *src1,
 318                         const unsigned long *src2, unsigned int nbits)
 319 {
 320         if (small_const_nbits(nbits))
 321                 return !((*src1 ^ *src2) & BITMAP_LAST_WORD_MASK(nbits));
 322         if (__builtin_constant_p(nbits & BITMAP_MEM_MASK) &&
 323             IS_ALIGNED(nbits, BITMAP_MEM_ALIGNMENT))
 324                 return !memcmp(src1, src2, nbits / 8);
 325         return __bitmap_equal(src1, src2, nbits);
 326 }
 327 
 328 
 329 
 330 
 331 
 332 
 333 
 334 
 335 
 336 
 337 static inline bool bitmap_or_equal(const unsigned long *src1,
 338                                    const unsigned long *src2,
 339                                    const unsigned long *src3,
 340                                    unsigned int nbits)
 341 {
 342         if (!small_const_nbits(nbits))
 343                 return __bitmap_or_equal(src1, src2, src3, nbits);
 344 
 345         return !(((*src1 | *src2) ^ *src3) & BITMAP_LAST_WORD_MASK(nbits));
 346 }
 347 
 348 static inline int bitmap_intersects(const unsigned long *src1,
 349                         const unsigned long *src2, unsigned int nbits)
 350 {
 351         if (small_const_nbits(nbits))
 352                 return ((*src1 & *src2) & BITMAP_LAST_WORD_MASK(nbits)) != 0;
 353         else
 354                 return __bitmap_intersects(src1, src2, nbits);
 355 }
 356 
 357 static inline int bitmap_subset(const unsigned long *src1,
 358                         const unsigned long *src2, unsigned int nbits)
 359 {
 360         if (small_const_nbits(nbits))
 361                 return ! ((*src1 & ~(*src2)) & BITMAP_LAST_WORD_MASK(nbits));
 362         else
 363                 return __bitmap_subset(src1, src2, nbits);
 364 }
 365 
 366 static inline int bitmap_empty(const unsigned long *src, unsigned nbits)
 367 {
 368         if (small_const_nbits(nbits))
 369                 return ! (*src & BITMAP_LAST_WORD_MASK(nbits));
 370 
 371         return find_first_bit(src, nbits) == nbits;
 372 }
 373 
 374 static inline int bitmap_full(const unsigned long *src, unsigned int nbits)
 375 {
 376         if (small_const_nbits(nbits))
 377                 return ! (~(*src) & BITMAP_LAST_WORD_MASK(nbits));
 378 
 379         return find_first_zero_bit(src, nbits) == nbits;
 380 }
 381 
 382 static __always_inline int bitmap_weight(const unsigned long *src, unsigned int nbits)
 383 {
 384         if (small_const_nbits(nbits))
 385                 return hweight_long(*src & BITMAP_LAST_WORD_MASK(nbits));
 386         return __bitmap_weight(src, nbits);
 387 }
 388 
 389 static __always_inline void bitmap_set(unsigned long *map, unsigned int start,
 390                 unsigned int nbits)
 391 {
 392         if (__builtin_constant_p(nbits) && nbits == 1)
 393                 __set_bit(start, map);
 394         else if (__builtin_constant_p(start & BITMAP_MEM_MASK) &&
 395                  IS_ALIGNED(start, BITMAP_MEM_ALIGNMENT) &&
 396                  __builtin_constant_p(nbits & BITMAP_MEM_MASK) &&
 397                  IS_ALIGNED(nbits, BITMAP_MEM_ALIGNMENT))
 398                 memset((char *)map + start / 8, 0xff, nbits / 8);
 399         else
 400                 __bitmap_set(map, start, nbits);
 401 }
 402 
 403 static __always_inline void bitmap_clear(unsigned long *map, unsigned int start,
 404                 unsigned int nbits)
 405 {
 406         if (__builtin_constant_p(nbits) && nbits == 1)
 407                 __clear_bit(start, map);
 408         else if (__builtin_constant_p(start & BITMAP_MEM_MASK) &&
 409                  IS_ALIGNED(start, BITMAP_MEM_ALIGNMENT) &&
 410                  __builtin_constant_p(nbits & BITMAP_MEM_MASK) &&
 411                  IS_ALIGNED(nbits, BITMAP_MEM_ALIGNMENT))
 412                 memset((char *)map + start / 8, 0, nbits / 8);
 413         else
 414                 __bitmap_clear(map, start, nbits);
 415 }
 416 
 417 static inline void bitmap_shift_right(unsigned long *dst, const unsigned long *src,
 418                                 unsigned int shift, unsigned int nbits)
 419 {
 420         if (small_const_nbits(nbits))
 421                 *dst = (*src & BITMAP_LAST_WORD_MASK(nbits)) >> shift;
 422         else
 423                 __bitmap_shift_right(dst, src, shift, nbits);
 424 }
 425 
 426 static inline void bitmap_shift_left(unsigned long *dst, const unsigned long *src,
 427                                 unsigned int shift, unsigned int nbits)
 428 {
 429         if (small_const_nbits(nbits))
 430                 *dst = (*src << shift) & BITMAP_LAST_WORD_MASK(nbits);
 431         else
 432                 __bitmap_shift_left(dst, src, shift, nbits);
 433 }
 434 
 435 static inline int bitmap_parse(const char *buf, unsigned int buflen,
 436                         unsigned long *maskp, int nmaskbits)
 437 {
 438         return __bitmap_parse(buf, buflen, 0, maskp, nmaskbits);
 439 }
 440 
 441 
 442 
 443 
 444 
 445 
 446 
 447 
 448 
 449 
 450 
 451 
 452 
 453 
 454 
 455 
 456 
 457 
 458 
 459 
 460 
 461 
 462 
 463 
 464 
 465 
 466 
 467 #if __BITS_PER_LONG == 64
 468 #define BITMAP_FROM_U64(n) (n)
 469 #else
 470 #define BITMAP_FROM_U64(n) ((unsigned long) ((u64)(n) & ULONG_MAX)), \
 471                                 ((unsigned long) ((u64)(n) >> 32))
 472 #endif
 473 
 474 
 475 
 476 
 477 
 478 
 479 
 480 
 481 
 482 
 483 
 484 static inline void bitmap_from_u64(unsigned long *dst, u64 mask)
 485 {
 486         dst[0] = mask & ULONG_MAX;
 487 
 488         if (sizeof(mask) > sizeof(unsigned long))
 489                 dst[1] = mask >> 32;
 490 }
 491 
 492 #endif 
 493 
 494 #endif