Unionfs: use i_size wrappers
authorErez Zadok <ezk@cs.sunysb.edu>
Sun, 18 Nov 2007 04:42:10 +0000 (23:42 -0500)
committerRachita Kothiyal <rachita@dewey.fsl.cs.sunysb.edu>
Thu, 1 May 2008 23:03:17 +0000 (19:03 -0400)
Signed-off-by: Erez Zadok <ezk@cs.sunysb.edu>
fs/unionfs/commonfops.c
fs/unionfs/dirfops.c
fs/unionfs/dirhelper.c
fs/unionfs/export.c
fs/unionfs/inode.c
fs/unionfs/rdstate.c
fs/unionfs/rename.c
fs/unionfs/super.c

index fcf0aa7811b20a9c4883ad5229996034e977e389..8d2cfdc12078faade2a6b56cdf667edf403159a1 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_path.dentry->d_inode->i_size);
+                               bindex,
+                               i_size_read(file->f_path.dentry->d_inode));
        if (err) {
                if (unlikely(err == -EEXIST))
                        goto retry;
@@ -266,7 +267,6 @@ static int open_highest_file(struct file *file, bool willwrite)
        struct dentry *dentry = file->f_path.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);
@@ -275,7 +275,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;
                }
@@ -310,7 +310,6 @@ static int do_delayed_copyup(struct file *file)
        int bindex, bstart, bend, err = 0;
        struct dentry *dentry = file->f_path.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);
@@ -322,7 +321,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 5a15acb92bb98800dca7225d92e7b5dbf7ea1b6e..15215608d0e6253dcce21fe9f01a1b86179e36ef 100644 (file)
@@ -50,7 +50,7 @@ static int unionfs_readdir(struct file *file, void *dirent, filldir_t filldir)
        }
 
        /* check if cached dir does not exist */
-       if (!odf_cache->d_inode || !odf_cache->d_inode->i_size) {
+       if (!odf_cache->d_inode || !i_size_read(odf_cache->d_inode)) {
 
                /*
                 * odf cache dir calls partial lookup which expects a locked
@@ -91,7 +91,7 @@ static int unionfs_readdir(struct file *file, void *dirent, filldir_t filldir)
 
        odf_file->f_pos = file->f_pos;
 
-       size = odf_cache->d_inode->i_size;
+       size = i_size_read(odf_cache->d_inode);
        while (odf_file->f_pos < size && !overflow) {
 
                pos = odf_file->f_pos;
index b7a6d7a5782c32f4fd9a3f2006bafa196e2d0b0f..5036cec07f311eff7872253bda6431f5d5cd8cba 100644 (file)
@@ -331,7 +331,7 @@ retry:
         * compare mtimes, do not proceed if equal, do not check if retrying
         * after -ENOSPC
         */
-       if (i_odf && i_odf->i_size && !cleaned) {
+       if (i_odf && i_size_read(i_odf) && !cleaned) {
                if(timespec_compare(&i_odf->i_mtime,mtime) >= 0)
                        goto out;
        }
index 4e6173e1fb85fd0ae31f84b62fcf117c8297ef2f..44493e93e69143bf3dbc996786a6f2da6105f353 100644 (file)
@@ -215,7 +215,7 @@ static int unionfs_get_name(struct dentry *dentry, char *name,
        }
 
        /* reconstruct the cached dir if necessary */
-       if (!odf_cache->d_inode || !odf_cache->d_inode->i_size) {
+       if (!odf_cache->d_inode || !i_size_read(odf_cache->d_inode)) {
                unionfs_lock_dentry(dentry);
                err = odf_cache_dir(dentry, odf_cache,
                                    &dentry->d_inode->i_mtime);
@@ -238,7 +238,7 @@ static int unionfs_get_name(struct dentry *dentry, char *name,
 
        /* search for the inode in the dir */
        file->f_pos = 0;
-       while (file->f_pos < file->f_path.dentry->d_inode->i_size) {
+       while (file->f_pos < i_size_read(file->f_path.dentry->d_inode)) {
                err = odf_read_dirent(file, &tmp_name, &namelen, &ino,
                                      &d_type);
                if (err)
index 3ad08d84e6e948add7f9a4e5ecabd553ddd9aeb8..e522b565f5866ca021a2fc8d6c7d8523d1ada379 100644 (file)
@@ -271,7 +271,7 @@ docopyup:
                                    old_dentry, old_bstart, bindex,
                                    old_dentry->d_name.name,
                                    old_dentry->d_name.len,
-                                   NULL, old_dentry->d_inode->i_size);
+                                   NULL, i_size_read(old_dentry->d_inode));
                if (!err) {
                        lower_new_dentry =
                                create_parents(dir, new_dentry,
@@ -861,7 +861,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 95c48182ec72a8b2feaa354bba7e10ac189f85ea..8f824418ca602dc7327069a10054e1eeccb102db 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 43a7b01ce31f24195f17e6a3076627528f8e7a6b..330812df3f7ae3af54556796f404d7cc4a49f66d 100644 (file)
@@ -221,8 +221,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 (!err)
                                err = __unionfs_rename(old_dir, old_dentry,
                                                       new_dir, new_dentry,
index 73d25076020f94ef1fe36a37fb960937e706ef80..cdb54393859374e50c02a9aba0224fe285ab3c6a 100644 (file)
@@ -67,7 +67,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);