实现对debugfs文件的写入功能

时间:2014-10-09 06:51:59

标签: linux kernel

我尝试对debugfs文件实现write函数。我希望我可以使用echo "hello" > /sys/kernel/debugfs/mydir/myfile将字符串写入文件。并使用echo "world" >> /sys/kernel/debugfs/mydir/myfileworld之后附加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);

1 个答案:

答案 0 :(得分:0)

  

一个是如果输入字符串的长度为,则echo命令会卡住   超过缓冲区大小。

这是因为它会在每次尝试失败时继续重试写入文件。

  

另一个是回声&#34;世界&#34; &GT;&GT;   / sys / kernel / debugfs / mydir / myfile永远不会附加字符串。相反,它   新的字符串。

这是您的实施所期望的。如果要附加它,则需要将新的字符串捕获到现有字符串。也就是说,您需要保留字符串长度的记录。但这是 不同于特定于进程的打开文件的f_pos。

  

如何识别用户将使用哪些命令(echo&gt;或echo&gt;&gt;)?

所以你的意思是用户是否截断了&#39;打开后的文件?  debugfs似乎不支持搜索,但我想你可以提供你的.open函数和.llseek函数来实现它。如果是APPEND,则需要在打开文件时查看文件的末尾。

很抱歉,我无法提供完整的代码,只是提供了一些指示。