}
 EXPORT_SYMBOL(discard_new_inode);
 
-/**
- * lock_two_inodes - lock two inodes (may be regular files but also dirs)
- *
- * Lock any non-NULL argument. The caller must make sure that if he is passing
- * in two directories, one is not ancestor of the other.  Zero, one or two
- * objects may be locked by this function.
- *
- * @inode1: first inode to lock
- * @inode2: second inode to lock
- * @subclass1: inode lock subclass for the first lock obtained
- * @subclass2: inode lock subclass for the second lock obtained
- */
-void lock_two_inodes(struct inode *inode1, struct inode *inode2,
-                    unsigned subclass1, unsigned subclass2)
-{
-       if (!inode1 || !inode2) {
-               /*
-                * Make sure @subclass1 will be used for the acquired lock.
-                * This is not strictly necessary (no current caller cares) but
-                * let's keep things consistent.
-                */
-               if (!inode1)
-                       swap(inode1, inode2);
-               goto lock;
-       }
-
-       /*
-        * If one object is directory and the other is not, we must make sure
-        * to lock directory first as the other object may be its child.
-        */
-       if (S_ISDIR(inode2->i_mode) == S_ISDIR(inode1->i_mode)) {
-               if (inode1 > inode2)
-                       swap(inode1, inode2);
-       } else if (!S_ISDIR(inode1->i_mode))
-               swap(inode1, inode2);
-lock:
-       if (inode1)
-               inode_lock_nested(inode1, subclass1);
-       if (inode2 && inode2 != inode1)
-               inode_lock_nested(inode2, subclass2);
-}
-
 /**
  * lock_two_nondirectories - take two i_mutexes on non-directory objects
  *
                WARN_ON_ONCE(S_ISDIR(inode1->i_mode));
        if (inode2)
                WARN_ON_ONCE(S_ISDIR(inode2->i_mode));
-       lock_two_inodes(inode1, inode2, I_MUTEX_NORMAL, I_MUTEX_NONDIR2);
+       if (inode1 > inode2)
+               swap(inode1, inode2);
+       if (inode1)
+               inode_lock(inode1);
+       if (inode2 && inode2 != inode1)
+               inode_lock_nested(inode2, I_MUTEX_NONDIR2);
 }
 EXPORT_SYMBOL(lock_two_nondirectories);
 
 
 int dentry_needs_remove_privs(struct mnt_idmap *, struct dentry *dentry);
 bool in_group_or_capable(struct mnt_idmap *idmap,
                         const struct inode *inode, vfsgid_t vfsgid);
-void lock_two_inodes(struct inode *inode1, struct inode *inode2,
-                    unsigned subclass1, unsigned subclass2);
 
 /*
  * fs-writeback.c