Zeroing data blocks

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



I am trying to zero data blocks whenever an unlink is invoked as part
of a secure delete filesystem.
I tried to zero the file by writing a buffer (of file size) with
zeroes onto the file.
But the system hangs.
I see the printk "In page_left loop" being printed, but nothing after that.
Could someone let me know what might be happening with the code below?
Also could you recommend me what is the best operation for writing
zeroes onto a file?

Thanks,
Avinash.

I saw that the file size is 12, with page_number being 0 and page_left 12.

Code:
=====

int overwrite(dentry_t *dentry, int overwrite_num)
{
     int err = 0;
     int n, m;
     file_t *fip, *fop;
     char *readbuf, *writebuf;
     mm_segment_t oldfs;
     int size = 0;
     int page_number, page_left;
     int i, j;
     oldfs.seg = 0;

     printk("overwrite number is %d\n", overwrite_num);
     printk("Overwriting file name %s\n", dentry->d_name.name);
     fip = filp_open(dentry->d_name.name, O_RDONLY, 0);
     if(!S_ISREG(fip->f_dentry->d_inode->i_mode))
     {
             printk("%s is not a regular file\n", dentry->d_name.name);
             err = -EINVAL;
             goto error;
     }
     if(!fip || IS_ERR(fip))
     {
             err = -EPERM;
             printk("Cannot open input file\n");
             goto error;
     }
     if(!fip->f_op->read)
     {
             err = -EPERM;
             printk("Cannot read from input file\n");
             goto error;
     }
     fop = filp_open(dentry->d_name.name, O_WRONLY, 0);
     if(!S_ISREG(fop->f_dentry->d_inode->i_mode))
     {
             printk("%s is not a regular file\n", dentry->d_name.name);
             err = -EINVAL;
             goto error;
     }
     if(!fop || IS_ERR(fop))
     {
             err = -EPERM;
             printk("Cannot open input file\n");
             goto error;
     }
     if(!fop->f_op->write)
     {
             err = -EPERM;
             printk("Cannot write to input file\n");
             goto error;
     }
     fip->f_pos = 0;
     fop->f_pos = 0;
     oldfs = get_fs();
     set_fs(KERNEL_DS);
     readbuf = kmalloc(PAGE_CACHE_SIZE,GFP_KERNEL);
     if( !readbuf)
     {
             err = -ENOMEM;
             printk("Could not allocate buffer for reading\n");
             goto error;
     }
     writebuf = kmalloc(PAGE_CACHE_SIZE,GFP_KERNEL);
     if( !writebuf)
     {
             err = -ENOMEM;
             printk("Could not allocate buffer for writing\n");
             goto error;
     }
     printk("After allocating read/write buffers\n");
     memset(readbuf,0,PAGE_CACHE_SIZE);
     memset(writebuf,0,PAGE_CACHE_SIZE);
     printk("After memsetting...\n");
     while((n=fip->f_op->read(fip,readbuf,PAGE_CACHE_SIZE,&fip->f_pos))>0)
     {
             size += n;
     }
     if (fip) fput(fip);
     printk("After reading...\n");

     page_number = size / PAGE_CACHE_SIZE;
     page_left = size % PAGE_CACHE_SIZE;
     printk("After reading the file, size is %d, page_number is %d,
page_left is %d\n", size, page_number, page_left);
     for (i=0; i < overwrite_num; i++)
     {
             printk("In I loop i is %d\n", i);
             for (j=0; j < page_number; j++)
             {
                     printk("In J loop, j is %d\n", j);
                     if
((m=(fop->f_op->write(fop,writebuf,PAGE_CACHE_SIZE,&fop->f_pos))) < 0)
                     {
                             err = -EPERM;
                             printk("Could not write zeroes to the file\n");
                             goto error;
                     }
                     printk("After writing\n");
             }
             printk("After I loop\n");
             if (page_left)
             {
                     printk("In page_left loop\n");
                     if
((m=(fop->f_op->write(fop,writebuf,page_left,&fop->f_pos))) < 0)
                     {
                             err = -EPERM;
                             printk("Could not write zeroes to the file\n");
                     }
                     printk("After writing zeroes\n");
             }
             printk("setting f_pos to zero\n");
             fop->f_pos = 0;
             printk("After setting f_pos to zero\n");
     }
     printk("After for loop...\n");
     if (fop) fput(fop);
     printk("After putting fop\n");
     if (writebuf) kfree(writebuf);
     printk("After freeing writebuf\n");
     if (readbuf) kfree(readbuf);
     printk("After freeing readbuf\n");
     printk("After overwriting file...\n");
     error:
     set_fs(oldfs);
     return err;
}

--
Kernelnewbies: Help each other learn about the Linux kernel.
Archive:       http://mail.nl.linux.org/kernelnewbies/
FAQ:           http://kernelnewbies.org/faq/


[Index of Archives]     [Newbies FAQ]     [Linux Kernel Mentors]     [Linux Kernel Development]     [IETF Annouce]     [Git]     [Networking]     [Security]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux SCSI]     [Linux ACPI]
  Powered by Linux