我需要实现一个Linux内核驱动程序,(在第一步中)只将所有文件操作转发到另一个文件(在后面的步骤中,这应该被管理和操作,但我不想在这里讨论)
我的想法如下,但在阅读时,内核崩溃了:
static struct {
struct file *file;
char *file_name;
int open;
} file_out_data = {
.file_name = "/any_file",
.open = 0,
};
int memory_open(struct inode *inode, struct file *filp) {
PRINTK("<1>open memory module\n");
/*
* We don't want to talk to two processes at the same time
*/
if (file_out_data.open)
return -EBUSY;
/*
* Initialize the message
*/
Message_Ptr = Message;
try_module_get(THIS_MODULE);
file_out_data.file = filp_open(file_out_data.file_name, filp->f_flags, filp->f_mode); //here should be another return handling in case of fail
file_out_data.open++;
/* Success */
return 0;
}
int memory_release(struct inode *inode, struct file *filp) {
PRINTK("<1>release memory module\n");
/*
* We're now ready for our next caller
*/
file_out_data.open--;
filp_close(file_out_data.file,NULL);
module_put(THIS_MODULE);
/* Success */
return 0;
}
ssize_t memory_read(struct file *filp, char *buf,
size_t count, loff_t *f_pos) {
PRINTK("<1>read memory module \n");
ret=file_out_data.file->f_op->read(file_out_data.file,buf,count,f_pos); //corrected one, false one is to find in the history
return ret;
}
那么,有人可以告诉我为什么吗?
答案 0 :(得分:2)
为什么要递增file_out_data.open
两次并递减一次?这可能会导致您在关闭后使用file_out_data.file
。
答案 1 :(得分:2)
set_fs()
,因为没有理由这样做。file->f_fop->read()
代替vfs_read
。请查看file和file_operations结构。答案 2 :(得分:0)
你想在你的文件中写下你的内存吗? 因为你正在阅读而不是写作...... 可能我错了