Blame test/testmod/testmod_drv.c

Packit c71e3f
#define pr_fmt(fmt) "testmod: " fmt
Packit c71e3f
Packit c71e3f
#include <linux/module.h>
Packit c71e3f
#include <linux/kernel.h>
Packit c71e3f
#include <linux/kobject.h>
Packit c71e3f
#include <linux/sysfs.h>
Packit c71e3f
Packit c71e3f
static struct kobject *testmod_kobj;
Packit c71e3f
int value = 2;
Packit c71e3f
Packit c71e3f
static ssize_t value_show(struct kobject *kobj,
Packit c71e3f
                          struct kobj_attribute *attr, char *buf)
Packit c71e3f
{
Packit c71e3f
	return sprintf(buf, "%d\n", value);
Packit c71e3f
}
Packit c71e3f
Packit c71e3f
static struct kobj_attribute testmod_value_attr = __ATTR_RO(value);
Packit c71e3f
Packit c71e3f
static int testmod_init(void)
Packit c71e3f
{
Packit c71e3f
	int ret;
Packit c71e3f
Packit c71e3f
	testmod_kobj = kobject_create_and_add("testmod", kernel_kobj);
Packit c71e3f
	if (!testmod_kobj)
Packit c71e3f
		return -ENOMEM;
Packit c71e3f
Packit c71e3f
	ret = sysfs_create_file(testmod_kobj, &testmod_value_attr.attr);
Packit c71e3f
	if (ret) {
Packit c71e3f
		kobject_put(testmod_kobj);
Packit c71e3f
		return ret;
Packit c71e3f
	}
Packit c71e3f
Packit c71e3f
	return 0;
Packit c71e3f
}
Packit c71e3f
Packit c71e3f
static void testmod_exit(void)
Packit c71e3f
{
Packit c71e3f
	sysfs_remove_file(testmod_kobj, &testmod_value_attr.attr);
Packit c71e3f
	kobject_put(testmod_kobj);
Packit c71e3f
}
Packit c71e3f
Packit c71e3f
module_init(testmod_init);
Packit c71e3f
module_exit(testmod_exit);
Packit c71e3f
MODULE_LICENSE("GPL");