xfs: prevent swapext from operating on write-only files
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>
This commit is contained in:
committed by
Dave Chinner
parent
7e27d6e778
commit
1817176a86
@@ -69,7 +69,9 @@ xfs_swapext(
|
|||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
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);
|
error = XFS_ERROR(EBADF);
|
||||||
goto out_put_file;
|
goto out_put_file;
|
||||||
}
|
}
|
||||||
@@ -81,6 +83,7 @@ xfs_swapext(
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!(tmp_file->f_mode & FMODE_WRITE) ||
|
if (!(tmp_file->f_mode & FMODE_WRITE) ||
|
||||||
|
!(tmp_file->f_mode & FMODE_READ) ||
|
||||||
(tmp_file->f_flags & O_APPEND)) {
|
(tmp_file->f_flags & O_APPEND)) {
|
||||||
error = XFS_ERROR(EBADF);
|
error = XFS_ERROR(EBADF);
|
||||||
goto out_put_tmp_file;
|
goto out_put_tmp_file;
|
||||||
|
Reference in New Issue
Block a user