Linux内核数据结构队列-kfifo

前言

kfifo巧妙的运用了无符号变量位运算的特点。使得代码巧妙。

数据结构

struct kfifo {
	unsigned char *buffer;	/* 存放数据的buff */
	unsigned int size;		/* 分配到的buff的大小 */
	unsigned int in;		/* data写入时的偏移量 (in % size) */
	unsigned int out;		/* data is extracted from off. (out % size) */
};

初始化

对于kfifo的初始化分为两种,静态初始化动态初始化

在初始化中,我们会发现,它分配的buffer大小一定是2的幂次数,如果参数不是2的幂次数,会进行向上取舍。为什么这么设计呢?先放个悬念。其中_kfifo_init(fifo, buffer, size)是分配内存和设置参数的函数调用。

 /** 静态初始化:使用一个预分配好的buffer进行初始化一个kfifo */
void kfifo_init(struct kfifo *fifo, void *buffer, unsigned int size)
{
	/* size must be a power of 2 */
	BUG_ON(!is_power_of_2(size));

	_kfifo_init(fifo, buffer, size);
}

/* 分配一个size大小的fifo **/
int kfifo_alloc
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值