我尝试对debugfs文件实现write函数。我希望我可以使用echo "hello" > /sys/kernel/debugfs/mydir/myfile
将字符串写入文件。并使用echo "world" >> /sys/kernel/debugfs/mydir/myfile
在world
之后附加hello
。我在实现中发现了两个问题。一个是如果输入字符串的长度超过缓冲区大小,echo
命令将被卡住。另一个是echo "world" >> /sys/kernel/debugfs/mydir/myfile
永远不会附加字符串。相反,它是一个新的字符串。以下是我的实施。
#include <linux/module.h> /* Needed by all modules */
#include <linux/kernel.h> /* Needed for KERN_INFO */
#include <linux/init.h> /* Needed for the macros */
#include <linux/miscdevice.h>
#include <linux/uaccess.h>
#include <linux/debugfs.h>
#include <linux/fs.h>
#include <linux/sched.h>
MODULE_LICENSE("GPL");
#define BUF_SIZE 10
static char foo_buf[BUF_SIZE];
static struct dentry *debug_dir;
static struct dentry *debug_foo;
static ssize_t foo_read(struct file *file, char __user *buf, size_t count,
loff_t *f_pos)
{
return simple_read_from_buffer(buf, count, f_pos, foo_buf, sizeof(foo_buf));
}
static ssize_t foo_write(struct file *file, const char __user *buf, size_t count,
loff_t *f_pos)
{
size_t ret;
if (*f_pos > BUF_SIZE)
return -EINVAL;
ret = simple_write_to_buffer(foo_buf, sizeof(foo_buf), f_pos, buf, count);
if (ret < 0)
return ret;
foo_buf[ret] = '\0';
return ret;
}
static const struct file_operations foo_fops = {
.owner = THIS_MODULE,
.read = foo_read,
.write = foo_write,
};
static int __init debugfs_start(void)
{
pr_err("init debugfs");
debug_dir = debugfs_create_dir("mydir", NULL);
if (debug_dir == NULL) {
pr_err("debugfs create my dir failed");
return -ENOMEM;
}
debug_foo = debugfs_create_file("foo", 0744, debug_dir,
NULL, &foo_fops);
if (!debug_foo) {
debugfs_remove(debug_dir);
return -ENOMEM;
}
return 0;
}
static void __exit debugfs_end(void)
{
pr_err("exit debugfs");
debugfs_remove_recursive(debug_dir);
}
module_init(debugfs_start);
module_exit(debugfs_end);
答案 0 :(得分:0)
一个是如果输入字符串的长度为,则echo命令会卡住 超过缓冲区大小。
这是因为它会在每次尝试失败时继续重试写入文件。
另一个是回声&#34;世界&#34; &GT;&GT; / sys / kernel / debugfs / mydir / myfile永远不会附加字符串。相反,它 新的字符串。
这是您的实施所期望的。如果要附加它,则需要将新的字符串捕获到现有字符串。也就是说,您需要保留字符串长度的记录。但这是 不同于特定于进程的打开文件的f_pos。
如何识别用户将使用哪些命令(echo&gt;或echo&gt;&gt;)?
所以你的意思是用户是否截断了&#39;打开后的文件? debugfs似乎不支持搜索,但我想你可以提供你的.open函数和.llseek函数来实现它。如果是APPEND,则需要在打开文件时查看文件的末尾。
很抱歉,我无法提供完整的代码,只是提供了一些指示。