Linux内核开发之kset实例分析

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

猜你喜欢

转载自blog.csdn.net/xiezhi123456/article/details/80993066