cregit-Linux how code gets into the kernel

Release 4.7 samples/kobject/kobject-example.c

Directory: samples/kobject
/*
 * Sample kobject implementation
 *
 * Copyright (C) 2004-2007 Greg Kroah-Hartman <greg@kroah.com>
 * Copyright (C) 2007 Novell Inc.
 *
 * Released under the GPL version 2 only.
 *
 */
#include <linux/kobject.h>
#include <linux/string.h>
#include <linux/sysfs.h>
#include <linux/module.h>
#include <linux/init.h>

/*
 * This module shows how to create a simple subdirectory in sysfs called
 * /sys/kernel/kobject-example  In that directory, 3 files are created:
 * "foo", "baz", and "bar".  If an integer is written to these files, it can be
 * later read out of it.
 */


static int foo;

static int baz;

static int bar;

/*
 * The "foo" file where a static variable is read from and written to.
 */

static ssize_t foo_show(struct kobject *kobj, struct kobj_attribute *attr, char *buf) { return sprintf(buf, "%d\n", foo); }

Contributors

PersonTokensPropCommitsCommitProp
greg kroah-hartmangreg kroah-hartman30100.00%1100.00%
Total30100.00%1100.00%


static ssize_t foo_store(struct kobject *kobj, struct kobj_attribute *attr, const char *buf, size_t count) { int ret; ret = kstrtoint(buf, 10, &foo); if (ret < 0) return ret; return count; }

Contributors

PersonTokensPropCommitsCommitProp
greg kroah-hartmangreg kroah-hartman3568.63%150.00%
rastislav barlikrastislav barlik1631.37%150.00%
Total51100.00%2100.00%

/* Sysfs attributes cannot be world-writable. */ static struct kobj_attribute foo_attribute = __ATTR(foo, 0664, foo_show, foo_store); /* * More complex function where we determine which variable is being accessed by * looking at the attribute for the "baz" and "bar" files. */
static ssize_t b_show(struct kobject *kobj, struct kobj_attribute *attr, char *buf) { int var; if (strcmp(attr->attr.name, "baz") == 0) var = baz; else var = bar; return sprintf(buf, "%d\n", var); }

Contributors

PersonTokensPropCommitsCommitProp
greg kroah-hartmangreg kroah-hartman57100.00%1100.00%
Total57100.00%1100.00%


static ssize_t b_store(struct kobject *kobj, struct kobj_attribute *attr, const char *buf, size_t count) { int var, ret; ret = kstrtoint(buf, 10, &var); if (ret < 0) return ret; if (strcmp(attr->attr.name, "baz") == 0) baz = var; else bar = var; return count; }

Contributors

PersonTokensPropCommitsCommitProp
greg kroah-hartmangreg kroah-hartman6280.52%150.00%
rastislav barlikrastislav barlik1519.48%150.00%
Total77100.00%2100.00%

static struct kobj_attribute baz_attribute = __ATTR(baz, 0664, b_show, b_store); static struct kobj_attribute bar_attribute = __ATTR(bar, 0664, b_show, b_store); /* * Create a group of attributes so that we can create and destroy them all * at once. */ static struct attribute *attrs[] = { &foo_attribute.attr, &baz_attribute.attr, &bar_attribute.attr, NULL, /* need to NULL terminate the list of attributes */ }; /* * An unnamed attribute group will put all of the attributes directly in * the kobject directory. If we specify a name, a subdirectory will be * created for the attributes with the directory being the name of the * attribute group. */ static struct attribute_group attr_group = { .attrs = attrs, }; static struct kobject *example_kobj;
static int __init example_init(void) { int retval; /* * Create a simple kobject with the name of "kobject_example", * located under /sys/kernel/ * * As this is a simple directory, no uevent will be sent to * userspace. That is why this function should not be used for * any type of dynamic kobjects, where the name and number are * not known ahead of time. */ example_kobj = kobject_create_and_add("kobject_example", kernel_kobj); if (!example_kobj) return -ENOMEM; /* Create the files associated with this kobject */ retval = sysfs_create_group(example_kobj, &attr_group); if (retval) kobject_put(example_kobj); return retval; }

Contributors

PersonTokensPropCommitsCommitProp
greg kroah-hartmangreg kroah-hartman5398.15%150.00%
qinghuang fengqinghuang feng11.85%150.00%
Total54100.00%2100.00%


static void __exit example_exit(void) { kobject_put(example_kobj); }

Contributors

PersonTokensPropCommitsCommitProp
greg kroah-hartmangreg kroah-hartman1392.86%150.00%
qinghuang fengqinghuang feng17.14%150.00%
Total14100.00%2100.00%

module_init(example_init); module_exit(example_exit); MODULE_LICENSE("GPL v2"); MODULE_AUTHOR("Greg Kroah-Hartman <greg@kroah.com>");

Overall Contributors

PersonTokensPropCommitsCommitProp
greg kroah-hartmangreg kroah-hartman39290.95%233.33%
rastislav barlikrastislav barlik317.19%116.67%
rusty russellrusty russell40.93%116.67%
radu voicilasradu voicilas20.46%116.67%
qinghuang fengqinghuang feng20.46%116.67%
Total431100.00%6100.00%
Directory: samples/kobject
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.
{% endraw %}