Unionfs: minor code rearrangement in rename
authorErez Zadok <ezk@cs.sunysb.edu>
Wed, 26 Dec 2007 05:10:37 +0000 (00:10 -0500)
committerErez Zadok <ezk@cs.sunysb.edu>
Fri, 12 Aug 2011 02:37:19 +0000 (22:37 -0400)
To avoid too much code nesting.

Signed-off-by: Erez Zadok <ezk@cs.sunysb.edu>
fs/unionfs/rename.c

index 824c2855c068d7beea9952008938c3410532da9b..1019d474d0e21acb671c8e46767b745e216a42a7 100644 (file)
@@ -479,54 +479,51 @@ int unionfs_rename(struct inode *old_dir, struct dentry *old_dentry,
                                goto out;
                }
        }
+
        err = do_unionfs_rename(old_dir, old_dentry, new_dir, new_dentry);
-out:
-       if (err) {
-               /* clear the new_dentry stuff created */
-               d_drop(new_dentry);
-       } else {
-               /*
-                * force re-lookup since the dir on ro branch is not renamed,
-                * and lower dentries still indicate the un-renamed ones.
-                */
-               if (S_ISDIR(old_dentry->d_inode->i_mode))
-                       atomic_dec(&UNIONFS_D(old_dentry)->generation);
-               else
-                       unionfs_postcopyup_release(old_dentry);
-               if (new_dentry->d_inode &&
-                   !S_ISDIR(new_dentry->d_inode->i_mode)) {
-                       unionfs_postcopyup_release(new_dentry);
-                       unionfs_postcopyup_setmnt(new_dentry);
-                       if (!unionfs_lower_inode(new_dentry->d_inode)) {
-                               /*
-                                * If we get here, it means that no copyup
-                                * was needed, and that a file by the old
-                                * name already existing on the destination
-                                * branch; that file got renamed earlier in
-                                * this function, so all we need to do here
-                                * is set the lower inode.
-                                */
-                               struct inode *inode;
-                               inode = unionfs_lower_inode(
-                                       old_dentry->d_inode);
-                               igrab(inode);
-                               unionfs_set_lower_inode_idx(
-                                       new_dentry->d_inode,
-                                       dbstart(new_dentry), inode);
-                       }
+       if (err)
+               goto out;
 
+       /*
+        * force re-lookup since the dir on ro branch is not renamed, and
+        * lower dentries still indicate the un-renamed ones.
+        */
+       if (S_ISDIR(old_dentry->d_inode->i_mode))
+               atomic_dec(&UNIONFS_D(old_dentry)->generation);
+       else
+               unionfs_postcopyup_release(old_dentry);
+       if (new_dentry->d_inode && !S_ISDIR(new_dentry->d_inode->i_mode)) {
+               unionfs_postcopyup_release(new_dentry);
+               unionfs_postcopyup_setmnt(new_dentry);
+               if (!unionfs_lower_inode(new_dentry->d_inode)) {
+                       /*
+                        * If we get here, it means that no copyup was
+                        * needed, and that a file by the old name already
+                        * existing on the destination branch; that file got
+                        * renamed earlier in this function, so all we need
+                        * to do here is set the lower inode.
+                        */
+                       struct inode *inode;
+                       inode = unionfs_lower_inode(old_dentry->d_inode);
+                       igrab(inode);
+                       unionfs_set_lower_inode_idx(new_dentry->d_inode,
+                                                   dbstart(new_dentry),
+                                                   inode);
                }
-               /* if all of this renaming succeeded, update our times */
-               unionfs_copy_attr_times(old_dir);
-               unionfs_copy_attr_times(new_dir);
-               unionfs_copy_attr_times(old_dentry->d_inode);
-               unionfs_copy_attr_times(new_dentry->d_inode);
-               unionfs_check_inode(old_dir);
-               unionfs_check_inode(new_dir);
-               unionfs_check_dentry(old_dentry);
-               unionfs_check_dentry(new_dentry);
        }
+       /* if all of this renaming succeeded, update our times */
+       unionfs_copy_attr_times(old_dir);
+       unionfs_copy_attr_times(new_dir);
+       unionfs_copy_attr_times(old_dentry->d_inode);
+       unionfs_copy_attr_times(new_dentry->d_inode);
+       unionfs_check_inode(old_dir);
+       unionfs_check_inode(new_dir);
+       unionfs_check_dentry(old_dentry);
+       unionfs_check_dentry(new_dentry);
 
+out:
+       if (err)                /* clear the new_dentry stuff created */
+               d_drop(new_dentry);
        unionfs_unlock_dentry(new_dentry);
        unionfs_unlock_dentry(old_dentry);
        unionfs_read_unlock(old_dentry->d_sb);