2021-07-22 06:35:24 +08:00
|
|
|
/*
|
2021-08-08 01:24:59 +08:00
|
|
|
* hello-sysfs.c sysfs example
|
2021-07-22 06:35:24 +08:00
|
|
|
*/
|
|
|
|
#include <linux/fs.h>
|
2021-07-22 06:58:13 +08:00
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/kobject.h>
|
|
|
|
#include <linux/module.h>
|
2021-07-22 06:35:24 +08:00
|
|
|
#include <linux/string.h>
|
2021-07-22 06:58:13 +08:00
|
|
|
#include <linux/sysfs.h>
|
2021-07-22 06:35:24 +08:00
|
|
|
|
|
|
|
static struct kobject *mymodule;
|
|
|
|
|
|
|
|
/* the variable you want to be able to change */
|
|
|
|
static int myvariable = 0;
|
|
|
|
|
|
|
|
static ssize_t myvariable_show(struct kobject *kobj,
|
2021-09-02 15:15:07 +08:00
|
|
|
struct kobj_attribute *attr, char *buf)
|
2021-07-22 06:35:24 +08:00
|
|
|
{
|
|
|
|
return sprintf(buf, "%d\n", myvariable);
|
|
|
|
}
|
|
|
|
|
|
|
|
static ssize_t myvariable_store(struct kobject *kobj,
|
2024-10-08 00:34:36 +08:00
|
|
|
struct kobj_attribute *attr, const char *buf,
|
2021-07-22 06:58:13 +08:00
|
|
|
size_t count)
|
2021-07-22 06:35:24 +08:00
|
|
|
{
|
2024-10-08 11:35:39 +08:00
|
|
|
sscanf(buf, "%d", &myvariable);
|
2021-07-22 06:35:24 +08:00
|
|
|
return count;
|
|
|
|
}
|
|
|
|
|
|
|
|
static struct kobj_attribute myvariable_attribute =
|
2024-10-08 00:34:36 +08:00
|
|
|
__ATTR(myvariable, 0660, myvariable_show, myvariable_store);
|
2021-07-22 06:35:24 +08:00
|
|
|
|
2021-07-22 06:58:13 +08:00
|
|
|
static int __init mymodule_init(void)
|
2021-07-22 06:35:24 +08:00
|
|
|
{
|
|
|
|
int error = 0;
|
|
|
|
|
2024-01-30 15:49:03 +08:00
|
|
|
pr_info("mymodule: initialized\n");
|
2021-07-22 06:35:24 +08:00
|
|
|
|
2021-07-22 06:58:13 +08:00
|
|
|
mymodule = kobject_create_and_add("mymodule", kernel_kobj);
|
2021-07-22 06:35:24 +08:00
|
|
|
if (!mymodule)
|
|
|
|
return -ENOMEM;
|
|
|
|
|
|
|
|
error = sysfs_create_file(mymodule, &myvariable_attribute.attr);
|
|
|
|
if (error) {
|
2024-11-05 19:48:42 +08:00
|
|
|
kobject_put(mymodule);
|
2021-09-02 15:15:07 +08:00
|
|
|
pr_info("failed to create the myvariable file "
|
|
|
|
"in /sys/kernel/mymodule\n");
|
2021-07-22 06:35:24 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return error;
|
|
|
|
}
|
|
|
|
|
2021-07-22 06:58:13 +08:00
|
|
|
static void __exit mymodule_exit(void)
|
2021-07-22 06:35:24 +08:00
|
|
|
{
|
|
|
|
pr_info("mymodule: Exit success\n");
|
|
|
|
kobject_put(mymodule);
|
|
|
|
}
|
|
|
|
|
|
|
|
module_init(mymodule_init);
|
|
|
|
module_exit(mymodule_exit);
|
2021-08-08 01:24:59 +08:00
|
|
|
|
|
|
|
MODULE_LICENSE("GPL");
|