关于/ proc读写函数

时间:2012-02-01 18:15:31

标签: c linux device-driver

我编写了一个从/ proc文件读取和写入的模块。代码显示警告,如代码所示,并在代码后显示。代码如下:

#include<linux/module.h>
#include<linux/init.h>
#include<linux/proc_fs.h>
#include<asm/uaccess.h>

#define proc_fs_max 1024
#define proc_entry "my_test"

static struct proc_dir_entry *our_proc_file;
static char procfs_buffer[proc_fs_max];
static int proc_buffer_size = 0;

int proc_read(char *buffer,char **buffer_location,off_t offset,int buffer_length,int 
*eof,void *data)
{
    int ret;
    printk(KERN_ALERT"\n in read function");

    if(offset > 0){
        ret = 0;
    } else {
        memcpy(buffer,procfs_buffer,proc_buffer_size);
        ret = proc_buffer_size;
    }
    return ret;
}

int proc_write(struct file *file, const char *buffer, unsigned long count,void *data)
{
    printk(KERN_ALERT"\nin write function\n");
    proc_buffer_size = count;
    if(proc_buffer_size > proc_fs_max)
        proc_buffer_size = proc_fs_max; 
    if(copy_from_user(procfs_buffer,buffer,proc_buffer_size)) //showing comments on    warning as below
        return -EFAULT;
    return proc_buffer_size;
}

int proc_open(struct inode *inode,struct file *filp)
{
    try_module_get(THIS_MODULE);
    return 0;
}

int proc_close(struct inode *inode,struct file *filp)
{
    module_put(THIS_MODULE);
    return 0;
}

static struct file_operations dev_proc_ops = {
    .owner = THIS_MODULE,
    .read = proc_read,    //warning initialization from incompatible pointer type
    .write = proc_write,  //warning initialization from incompatible pointer type
    .open = proc_open,
    .release = proc_close,
};

static int dev_init(void)
{
    our_proc_file = create_proc_entry(proc_entry,0644,NULL);
    our_proc_file->proc_fops = &dev_proc_ops;
    return 0;
}

static void dev_clean(void)
{
    remove_proc_entry(proc_entry,NULL);
}

module_init(dev_init);
module_exit(dev_clean);

在将副本用于用户时编译时显示警告,如下所示:

在/usr/src/linux-2.6.34.10-0.6/arch/x86/include/asm/uaccess.h:571:0中包含的文件中,                  来自/home/karan/practice/procf/testproc.c:4:

在函数'copy_from_user'中,     在/home/karan/practice/procf/testproc.c:33:18从'proc_write'内联:

当我使用insmod然后echo hi>/dev/mytestcat /dev/mytest分别在/var/log/messages中写入函数和读取函数时给出消息。但终端上没有输出。

实际上,我将read和write函数指向file_operations读写函数而不是proc_dir_entry,并且没有检查计数。

1 个答案:

答案 0 :(得分:4)

proc_readproc_write的函数与您使用它们的位置不匹配,正如编译器指出的警告一样。在您的struct file_operations中:

int proc_read(char *buffer,char **buffer_location,off_t offset,int buffer_length,int 
*eof,void *data);

int proc_write(struct file *file, const char *buffer, unsigned long count,void *data);

这些都在struct file_operations中使用,但在include/linux/fs.h struct中的函数指针类型是:

ssize_t (*read) (struct file *, char __user *, size_t, loff_t *);
ssize_t (*write) (struct file *, const char __user *, size_t, loff_t *);

如果int不一样,则ssize_t intsize_t不同(不一定是签名而另一个不签名),那么你会发现问题,但是您的read存在更严重的问题 - 您有一个char **,它需要char *

编译器非常乐意接受你的意思,这就是你的意思,但我认为不是。

read看起来更像read_proc_t中的struct proc_dir_entry,但这不是您在dev_proc_ops中设置的内容。

(作为旁注,我认为您可能还希望完成其余的函数static,因为它们是通过函数指针公开的)

相关问题