Linux内核开发之kset实例分析

本文提供了一个关于Linux内核中KSet子系统的简单驱动示例代码,包括了驱动的初始化、卸载流程及KSet对象注册等操作,并定义了过滤、命名和UEVENT事件处理函数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、驱动源代码

#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/init.h>
#include <linux/kobject.h>

struct kset kset_p;
struct kset kset_c;


int kset_filter( struct kset *kset, struct kobject *kobj)
{
printk("Filter: kobj %s.\n",kobj->name);
return 1;
}


const char *kset_name(struct kset *kset, struct kobject *kobj)
{
static char buf[20];
printk("Name: kobj %s. \n", kobj->name);
sprintf(buf,"%s","kset_name");
return buf;
}


int kset_uevent(struct kset *kset, struct kobject *kobj, char **envp,
int num_envp, char *buffer, int buffer_size)
{
printk("uevent: kobj %s.\n",kobj->name);
return 0;
}
struct kset_uevent_ops uevent_ops=
{
.filter = kset_filter,
.name = kset_name,
.uevent = kset_uevent,
};


static int kset_test_init(void)
{
printk("kset test init.\n");
kobject_set_name(&kset_p.kobj,"kset_p");
kset_p.uevent_ops = &uevent_ops;
kset_register(&kset_p);

kobject_set_name(&kset_c.kobj,"kset_c");
kset_c.kobj.kset = &kset_p;
kset_register(&kset_c);
return 0;
}


static void kset_test_exit(void)
{
printk("kset test exit.\n");
kset_unregister(&kset_c);
kset_unregister(&kset_p);
}


module_init(kset_test_init);
module_exit(kset_test_exit);
 

MODULE_LICENSE("Dual BSD/GPL");

2、Makefile

ifeq ($(KERNELRELEASE),)
KERNELDIR ?= /lib/modules/$(shell uname -r)/build
PWD := $(shell pwd)
all:                               
        $(MAKE) -C $(KERNELDIR) M=$(PWD) modules
clean:                                             
        $(MAKE) -C $(KERNELDIR) M=$(PWD) clean
else
    obj-m := kset.o

endif

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值