diff options
Diffstat (limited to 'tools/include/linux/bitmap.h')
| -rw-r--r-- | tools/include/linux/bitmap.h | 30 | 
1 files changed, 30 insertions, 0 deletions
| diff --git a/tools/include/linux/bitmap.h b/tools/include/linux/bitmap.h index 05dca5c203f3..477a1cae513f 100644 --- a/tools/include/linux/bitmap.h +++ b/tools/include/linux/bitmap.h @@ -15,6 +15,8 @@ void __bitmap_or(unsigned long *dst, const unsigned long *bitmap1,  		 const unsigned long *bitmap2, int bits);  int __bitmap_and(unsigned long *dst, const unsigned long *bitmap1,  		 const unsigned long *bitmap2, unsigned int bits); +int __bitmap_equal(const unsigned long *bitmap1, +		   const unsigned long *bitmap2, unsigned int bits);  void bitmap_clear(unsigned long *map, unsigned int start, int len);  #define BITMAP_FIRST_WORD_MASK(start) (~0UL << ((start) & (BITS_PER_LONG - 1))) @@ -124,6 +126,15 @@ static inline unsigned long *bitmap_alloc(int nbits)  }  /* + * bitmap_free - Free bitmap + * @bitmap: pointer to bitmap + */ +static inline void bitmap_free(unsigned long *bitmap) +{ +	free(bitmap); +} + +/*   * bitmap_scnprintf - print bitmap list into buffer   * @bitmap: bitmap   * @nbits: size of bitmap @@ -148,4 +159,23 @@ static inline int bitmap_and(unsigned long *dst, const unsigned long *src1,  	return __bitmap_and(dst, src1, src2, nbits);  } +#ifdef __LITTLE_ENDIAN +#define BITMAP_MEM_ALIGNMENT 8 +#else +#define BITMAP_MEM_ALIGNMENT (8 * sizeof(unsigned long)) +#endif +#define BITMAP_MEM_MASK (BITMAP_MEM_ALIGNMENT - 1) +#define IS_ALIGNED(x, a) (((x) & ((typeof(x))(a) - 1)) == 0) + +static inline int bitmap_equal(const unsigned long *src1, +			const unsigned long *src2, unsigned int nbits) +{ +	if (small_const_nbits(nbits)) +		return !((*src1 ^ *src2) & BITMAP_LAST_WORD_MASK(nbits)); +	if (__builtin_constant_p(nbits & BITMAP_MEM_MASK) && +	    IS_ALIGNED(nbits, BITMAP_MEM_ALIGNMENT)) +		return !memcmp(src1, src2, nbits / 8); +	return __bitmap_equal(src1, src2, nbits); +} +  #endif /* _PERF_BITOPS_H */ | 
