aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiklos Szeredi <mszeredi@suse.cz>2008-10-16 16:08:56 +0200
committerMiklos Szeredi <miklos@szeredi.hu>2008-10-16 16:08:56 +0200
commit769415c61191bc860f60c6edc3cb7cba24fb3218 (patch)
treec9ca5eb8afd1e4848967c3ec5a0a97dcda395e3f
parent04ab591808565f968d4406f6435090ad671ebdab (diff)
downloadkernel_samsung_smdk4412-769415c61191bc860f60c6edc3cb7cba24fb3218.zip
kernel_samsung_smdk4412-769415c61191bc860f60c6edc3cb7cba24fb3218.tar.gz
kernel_samsung_smdk4412-769415c61191bc860f60c6edc3cb7cba24fb3218.tar.bz2
fuse: fix SEEK_END incorrectness
Update file size before using it in lseek(..., SEEK_END). Reported-by: Amnon Shiloh <u3557@miso.sublimeip.com> Signed-off-by: Miklos Szeredi <mszeredi@suse.cz>
-rw-r--r--fs/fuse/file.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/fs/fuse/file.c b/fs/fuse/file.c
index 2bada6b..98079aa 100644
--- a/fs/fuse/file.c
+++ b/fs/fuse/file.c
@@ -1448,6 +1448,9 @@ static loff_t fuse_file_llseek(struct file *file, loff_t offset, int origin)
mutex_lock(&inode->i_mutex);
switch (origin) {
case SEEK_END:
+ retval = fuse_update_attributes(inode, NULL, file, NULL);
+ if (retval)
+ return retval;
offset += i_size_read(inode);
break;
case SEEK_CUR: