aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2013-09-30 08:35:10 -0700
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2013-10-22 08:41:44 +0100
commit0ffc34c0d09a7d36ff84d1ac506a352a06ef5e4e (patch)
tree6bb5e763a314d5b7b8e0bf59b6210a6c49d3b773 /fs
parentfa759b5d100c8b0d2ec2b83fcac990f2c3ac13b7 (diff)
downloadkernel_samsung_smdk4412-0ffc34c0d09a7d36ff84d1ac506a352a06ef5e4e.tar.gz
kernel_samsung_smdk4412-0ffc34c0d09a7d36ff84d1ac506a352a06ef5e4e.tar.bz2
kernel_samsung_smdk4412-0ffc34c0d09a7d36ff84d1ac506a352a06ef5e4e.zip
vfs: allow O_PATH file descriptors for fstatfs()
commit 9d05746e7b16d8565dddbe3200faa1e669d23bbf upstream. Olga reported that file descriptors opened with O_PATH do not work with fstatfs(), found during further development of ksh93's thread support. There is no reason to not allow O_PATH file descriptors here (fstatfs is very much a path operation), so use "fdget_raw()". See commit 55815f70147d ("vfs: make O_PATH file descriptors usable for 'fstat()'") for a very similar issue reported for fstat() by the same team. Reported-and-tested-by: ольга крыжановская <olga.kryzhanovska@gmail.com> Acked-by: Al Viro <viro@zeniv.linux.org.uk> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'fs')
-rw-r--r--fs/statfs.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/statfs.c b/fs/statfs.c
index 9cf04a11896..a133c3ef2be 100644
--- a/fs/statfs.c
+++ b/fs/statfs.c
@@ -86,7 +86,7 @@ int user_statfs(const char __user *pathname, struct kstatfs *st)
int fd_statfs(int fd, struct kstatfs *st)
{
- struct file *file = fget(fd);
+ struct file *file = fget_raw(fd);
int error = -EBADF;
if (file) {
error = vfs_statfs(&file->f_path, st);