Unionfs: use i_size wrappers
authorErez Zadok <ezk@cs.sunysb.edu>
Tue, 27 Nov 2007 00:54:02 +0000 (19:54 -0500)
committerErez Zadok <ezk@cs.sunysb.edu>
Tue, 27 Nov 2007 00:54:02 +0000 (19:54 -0500)
Signed-off-by: Erez Zadok <ezk@cs.sunysb.edu>
fs/unionfs/commonfops.c
fs/unionfs/inode.c
fs/unionfs/rdstate.c
fs/unionfs/rename.c
fs/unionfs/super.c

index e35a49647a0c60c06004e72c5ab957e11b96593e..3a60fa63082d451734621bc4bf6ea42265850941 100644 (file)
@@ -72,7 +72,8 @@ retry:
        dput(tmp_dentry);
 
        err = copyup_named_file(dentry->d_parent->d_inode, file, name, bstart,
-                               bindex, file->f_dentry->d_inode->i_size);
+                               bindex,
+                               i_size_read(file->f_dentry->d_inode));
        if (err) {
                if (unlikely(err == -EEXIST))
                        goto retry;
@@ -198,7 +199,6 @@ static int open_highest_file(struct file *file, bool willwrite)
        struct dentry *dentry = file->f_dentry;
        struct inode *parent_inode = dentry->d_parent->d_inode;
        struct super_block *sb = dentry->d_sb;
-       size_t inode_size = dentry->d_inode->i_size;
 
        bstart = dbstart(dentry);
        bend = dbend(dentry);
@@ -207,7 +207,7 @@ static int open_highest_file(struct file *file, bool willwrite)
        if (willwrite && IS_WRITE_FLAG(file->f_flags) && is_robranch(dentry)) {
                for (bindex = bstart - 1; bindex >= 0; bindex--) {
                        err = copyup_file(parent_inode, file, bstart, bindex,
-                                         inode_size);
+                                         i_size_read(dentry->d_inode));
                        if (!err)
                                break;
                }
@@ -242,7 +242,6 @@ static int do_delayed_copyup(struct file *file)
        int bindex, bstart, bend, err = 0;
        struct dentry *dentry = file->f_dentry;
        struct inode *parent_inode = dentry->d_parent->d_inode;
-       loff_t inode_size = dentry->d_inode->i_size;
 
        bstart = fbstart(file);
        bend = fbend(file);
@@ -254,7 +253,8 @@ static int do_delayed_copyup(struct file *file)
        for (bindex = bstart - 1; bindex >= 0; bindex--) {
                if (!d_deleted(dentry))
                        err = copyup_file(parent_inode, file, bstart,
-                                         bindex, inode_size);
+                                         bindex,
+                                         i_size_read(dentry->d_inode));
                else
                        err = copyup_deleted_file(file, dentry, bstart,
                                                  bindex);
index 59854eab3aeb8b8f0d62317292a86aeb28627e3a..35a71c3d135b66985d31ccd4e82db72789a14d6b 100644 (file)
@@ -303,7 +303,7 @@ docopyup:
                                            old_dentry, old_bstart,
                                            bindex, old_dentry->d_name.name,
                                            old_dentry->d_name.len, NULL,
-                                           old_dentry->d_inode->i_size);
+                                           i_size_read(old_dentry->d_inode));
                        if (!err) {
                                lower_new_dentry =
                                        create_parents(dir, new_dentry,
@@ -1023,7 +1023,7 @@ static int unionfs_setattr(struct dentry *dentry, struct iattr *ia)
                                continue;
                        /* Only if its the leftmost file, copyup the file */
                        for (i = bstart - 1; i >= 0; i--) {
-                               loff_t size = dentry->d_inode->i_size;
+                               loff_t size = i_size_read(dentry->d_inode);
                                if (ia->ia_valid & ATTR_SIZE)
                                        size = ia->ia_size;
                                err = copyup_dentry(dentry->d_parent->d_inode,
index 26ec5a0fe7a21cfbd4e8d0453cca1e395549b767..3241380557db1af3955db57ec24f90e2d4953bc2 100644 (file)
@@ -76,10 +76,10 @@ static int guesstimate_hash_size(struct inode *inode)
                if (!lower_inode)
                        continue;
 
-               if (lower_inode->i_size == DENTPAGE)
+               if (i_size_read(lower_inode) == DENTPAGE)
                        hashsize += DENTPERONEPAGE;
                else
-                       hashsize += (lower_inode->i_size / DENTPAGE) *
+                       hashsize += (i_size_read(lower_inode) / DENTPAGE) *
                                DENTPERPAGE;
        }
 
index 00230558daff84f3376d4f2deb670c18c24de2c5..7a37d78fc1da70089c5b76dd1e34ca1353755c71 100644 (file)
@@ -254,8 +254,8 @@ static int do_unionfs_rename(struct inode *old_dir,
                        err = copyup_dentry(old_dentry->d_parent->d_inode,
                                            old_dentry, old_bstart, bindex,
                                            old_dentry->d_name.name,
-                                           old_dentry->d_name.len,
-                                           NULL, old_dentry->d_inode->i_size);
+                                           old_dentry->d_name.len, NULL,
+                                           i_size_read(old_dentry->d_inode));
                        /* if copyup failed, try next branch to the left */
                        if (err)
                                continue;
index e4838927e635bcbcc687002e6a07bf391ce6e1bd..b325b9aaa381d588cddea90a244a452f97646d31 100644 (file)
@@ -69,7 +69,7 @@ static void unionfs_read_inode(struct inode *inode)
  */
 static void unionfs_delete_inode(struct inode *inode)
 {
-       inode->i_size = 0;      /* every f/s seems to do that */
+       i_size_write(inode, 0); /* every f/s seems to do that */
 
        if (inode->i_data.nrpages)
                truncate_inode_pages(&inode->i_data, 0);