为什么这个内核函数会进入无限循环?

时间:2012-10-26 00:51:44

标签: c linux file-io kernel

我试图在内核系统调用中覆盖文件中的所有数据(是的,我知道我不应该在内核中读取/写入文件,但我只是尝试一下!)基于这里的答案{{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;

}

如果我在用户空间程序中提供了正确的文件名,它就会不停地写入。为什么呢?

1 个答案:

答案 0 :(得分:1)

看起来您不断写入文件,因此文件长度不断增加。 vfs_write没有理由失败。如果我理解正确,您要做的是覆盖整个文件。所以你必须首先找到文件的大小,然后将那么多字节写入文件,然后关闭文件。就目前而言,您只是使用“空格”字符来增加文件。