我试图在内核系统调用中覆盖文件中的所有数据(是的,我知道我不应该在内核中读取/写入文件,但我只是尝试一下!)基于这里的答案{{3 }}
以下是代码:
int sys_mycompleteerase(const char __user * inputFileUser) {
struct file* filp = NULL;
int err = 0,count = 0;
unsigned long long offset =0;
mm_segment_t old_fs;
old_fs = get_fs();
set_fs(KERNEL_DS);
filp = filp_open(inputFileUser, O_WRONLY, 0644);
if(IS_ERR(filp)) {
err = PTR_ERR(filp);
return NULL;
}
do {
count = vfs_write(filp," ",sizeof(" "), &offset);
offset+=sizeof(" ");
}while(count > 0);
filp_close(filp, NULL);
set_fs(old_fs);
return 0;
}
如果我在用户空间程序中提供了正确的文件名,它就会不停地写入。为什么呢?
答案 0 :(得分:1)
看起来您不断写入文件,因此文件长度不断增加。 vfs_write没有理由失败。如果我理解正确,您要做的是覆盖整个文件。所以你必须首先找到文件的大小,然后将那么多字节写入文件,然后关闭文件。就目前而言,您只是使用“空格”字符来增加文件。