orangefs: sanitize ->llseek()
authorAl Viro <viro@zeniv.linux.org.uk>
Wed, 17 Feb 2016 01:25:19 +0000 (20:25 -0500)
committerMike Marshall <hubcap@omnibond.com>
Sat, 26 Mar 2016 02:30:54 +0000 (22:30 -0400)
a) open files can't have NULL inodes
b) it's SEEK_END, not ORANGEFS_SEEK_END; no need to get cute.
c) make_bad_inode() on lseek()?

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Mike Marshall <hubcap@omnibond.com>
fs/orangefs/file.c
fs/orangefs/orangefs-kernel.h

index 63e6a10ab13d2f3adb49c44d3cd9053878ddb28b..cb6a164b2718097596461281b8c852a3719befe5 100644 (file)
@@ -652,14 +652,9 @@ static int orangefs_fsync(struct file *file,
 static loff_t orangefs_file_llseek(struct file *file, loff_t offset, int origin)
 {
        int ret = -EINVAL;
-       struct inode *inode = file->f_path.dentry->d_inode;
+       struct inode *inode = file_inode(file);
 
-       if (!inode) {
-               gossip_err("orangefs_file_llseek: invalid inode (NULL)\n");
-               return ret;
-       }
-
-       if (origin == ORANGEFS_SEEK_END) {
+       if (origin == SEEK_END) {
                /*
                 * revalidate the inode's file size.
                 * NOTE: We are only interested in file size here,
@@ -674,7 +669,6 @@ static loff_t orangefs_file_llseek(struct file *file, loff_t offset, int origin)
                                     __FILE__,
                                     __func__,
                                     __LINE__);
-                       orangefs_make_bad_inode(inode);
                        return ret;
                }
        }
@@ -684,7 +678,7 @@ static loff_t orangefs_file_llseek(struct file *file, loff_t offset, int origin)
                     " | inode size is %lu\n",
                     (long)offset,
                     origin,
-                    (unsigned long)file->f_path.dentry->d_inode->i_size);
+                    (unsigned long)i_size_read(inode));
 
        return generic_file_llseek(file, offset, origin);
 }
index 5832168106dea2db9b663227377f8bbe6038ad34..db258d2ccc6a86528bfa63ebe698442d9de0c3cc 100644 (file)
@@ -70,7 +70,6 @@
 #define ORANGEFS_DEVREQ_MAGIC             0x20030529
 #define ORANGEFS_LINK_MAX                 0x000000FF
 #define ORANGEFS_PURGE_RETRY_COUNT     0x00000005
-#define ORANGEFS_SEEK_END              0x00000002
 #define ORANGEFS_MAX_NUM_OPTIONS          0x00000004
 #define ORANGEFS_MAX_MOUNT_OPT_LEN        0x00000080
 #define ORANGEFS_MAX_FSKEY_LEN            64