Linux的位图

版权声明:转载请声明 https://blog.csdn.net/qq_40732350/article/details/83045200

可以参考:

https://www.cnblogs.com/zpcdbky/p/5825849.html

重要宏定义:

#define DYNAMIC_MINORS 64 /* like dynamic majors */

#define DECLARE_BITMAP(name,bits) \
	unsigned long name[BITS_TO_LONGS(bits)]
#define BITS_PER_LONG __WORDSIZE
#define BITS_PER_BYTE           8
#define BITS_TO_LONGS(nr)       DIV_ROUND_UP(nr, BITS_PER_BYTE * sizeof(long))
#define DIV_ROUND_UP(n,d) (((n) + (d) - 1) / (d))

首先注册一个位图数组:

static DECLARE_BITMAP(misc_minors, DYNAMIC_MINORS);

int i = find_first_zero_bit(misc_minors, DYNAMIC_MINORS); //查找第一个为零的bit位

函数:查找第一个为零的bit位

unsigned long find_first_zero_bit(const unsigned long *addr, unsigned long size)
{
	const unsigned long *p = addr;
	unsigned long result = 0;
	unsigned long tmp;

	while (size & ~(BITS_PER_LONG-1)) {
		if (~(tmp = *(p++)))
			goto found;
		result += BITS_PER_LONG;
		size -= BITS_PER_LONG;
	}
	if (!size)
		return result;

	tmp = (*p) | (~0UL << size);
	if (tmp == ~0UL)	/* Are any bits zero? */
		return result + size;	/* Nope. */
found:
	return result + ffz(tmp);
}

函数:查找第一个不为零的bit位

unsigned long find_first_bit(const unsigned long *addr, unsigned long size)
{
	const unsigned long *p = addr;
	unsigned long result = 0;
	unsigned long tmp;

	while (size & ~(BITS_PER_LONG-1)) {
		if ((tmp = *(p++)))
			goto found;
		result += BITS_PER_LONG;
		size -= BITS_PER_LONG;
	}
	if (!size)
		return result;

	tmp = (*p) & (~0UL >> (BITS_PER_LONG - size));
	if (tmp == 0UL)		/* Are any bits set? */
		return result + size;	/* Nope. */
found:
	return result + __ffs(tmp);
}

函数:设置bit位

static inline void set_bit(int nr, unsigned long *addr)
{
	addr[nr / BITS_PER_LONG] |= 1UL << (nr % BITS_PER_LONG);
}

测试代码:

#include <stdio.h>
#define DYNAMIC_MINORS 64 /* like dynamic majors */

#define DECLARE_BITMAP(name,bits) \
	unsigned long name[BITS_TO_LONGS(bits)]
#define BITS_PER_LONG __WORDSIZE
#define BITS_PER_BYTE           8
#define BITS_TO_LONGS(nr)       DIV_ROUND_UP(nr, BITS_PER_BYTE * sizeof(long))
#define DIV_ROUND_UP(n,d) (((n) + (d) - 1) / (d))

static DECLARE_BITMAP(misc_minors, DYNAMIC_MINORS);
int
main(void)
{
	
	printf("数组个数 = %d\n", sizeof(misc_minors) / sizeof(unsigned long));
	printf("long size = %d\n", sizeof(long));
	printf("size = %d\n", DIV_ROUND_UP(64,32));
	printf("size = %d\n", BITS_TO_LONGS(64));	
}

运行结果:

数组个数 = 2
long size = 4
size = 2
size = 2

猜你喜欢

转载自blog.csdn.net/qq_40732350/article/details/83045200