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