]> git.kernelconcepts.de Git - karo-tx-linux.git/commitdiff
xfs: prevent swapext from operating on write-only files
authorDan Rosenberg <dan.j.rosenberg@gmail.com>
Thu, 24 Jun 2010 02:07:47 +0000 (12:07 +1000)
committerGreg Kroah-Hartman <gregkh@suse.de>
Tue, 10 Aug 2010 16:52:55 +0000 (09:52 -0700)
commit 1817176a86352f65210139d4c794ad2d19fc6b63 upstream.

This patch prevents user "foo" from using the SWAPEXT ioctl to swap
a write-only file owned by user "bar" into a file owned by "foo" and
subsequently reading it.  It does so by checking that the file
descriptors passed to the ioctl are also opened for reading.

Signed-off-by: Dan Rosenberg <dan.j.rosenberg@gmail.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
fs/xfs/xfs_dfrag.c

index 75b0cd4da0ea30140bbdd3068c02ba94c751bd13..ce2a6a21995c5237413e54713e88b70a473c2884 100644 (file)
@@ -74,7 +74,9 @@ xfs_swapext(
                goto out_free_sxp;
        }
 
-       if (!(file->f_mode & FMODE_WRITE) || (file->f_flags & O_APPEND)) {
+       if (!(file->f_mode & FMODE_WRITE) ||
+           !(file->f_mode & FMODE_READ) ||
+           (file->f_flags & O_APPEND)) {
                error = XFS_ERROR(EBADF);
                goto out_put_file;
        }
@@ -86,6 +88,7 @@ xfs_swapext(
        }
 
        if (!(target_file->f_mode & FMODE_WRITE) ||
+           !(target_file->f_mode & FMODE_READ) ||
            (target_file->f_flags & O_APPEND)) {
                error = XFS_ERROR(EBADF);
                goto out_put_target_file;