linux 内核 队列 kfifo

本文探讨了在Linux内核中使用kfifo作为队列数据结构的情况。作者在尝试自定义队列时遇到多线程操作的问题,最终转向使用内核自带的kfifo,该结构从2.6.10版开始引入。文中提到了kfifo_alloc的内存限制,并通过示例展示了如何创建一个kfifo实例。此外,还解释了kfifo_len函数返回的是FIFO中的数据长度,而非可用空间。
摘要由CSDN通过智能技术生成

在模块里尝试自己实现了个队列, 在多进程(内核里应该叫做多线程吧)操作时会出问题。

也曾尝试解决遇到的问题,但由于自己内核开发功夫上签,最终还是失败了 ....

后来还是采取了内核的实现 kfifo(include/linux/kfifo.h), kfifo在 linux 标准内核>=2.6.10 添加, 这里标准内核是因为 RHEL4.8 的内核版本是2.6.9(小于2.6.10)但是也有此数据结构,然后标准内核(www.kernel.org) <2.6.10 就没有此数据结构了

写了个简单的实现如下:

#include <linux/init.h>
#include <linux/module.h>
#include <linux/kfifo.h>
#include <linux/err.h>
#define STR_LEN 64
#define KFF_LEN 512*256
struct kfifo *my_kfifo = NULL;
spinlock_t my_fifo_lock;
static int my_put(int num)
{
    int i;
    char buff[STR_LEN];
    for(i=0; i<num; i++)
    {
        sprintf(buff,"My data: %d ...", i);
        if(kfifo_put(my_kfifo, buff, STR_LEN) <= 0)
        {
            printk("<2>""%s failed\n", buff);
        }
    }
    return num;
}

static int my_get(
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值