{
        struct dentry *dentry = file->f_path.dentry;
        struct autofs_sb_info *sbi = autofs_sbi(dentry->d_sb);
+       struct autofs_info *ino = autofs_dentry_ino(dentry);
 
        pr_debug("file=%p dentry=%p %pd\n", file, dentry, dentry);
 
         * it.
         */
        spin_lock(&sbi->lookup_lock);
-       if (!path_is_mountpoint(&file->f_path) && simple_empty(dentry)) {
+       if (!path_is_mountpoint(&file->f_path) && autofs_empty(ino)) {
                spin_unlock(&sbi->lookup_lock);
                return -ENOENT;
        }
                 * the mount never trigger mounts themselves (they have an
                 * autofs trigger mount mounted on them). But v4 pseudo direct
                 * mounts do need the leaves to trigger mounts. In this case
-                * we have no choice but to use the list_empty() check and
+                * we have no choice but to use the autofs_empty() check and
                 * require user space behave.
                 */
                if (sbi->version > 4) {
                                goto done;
                        }
                } else {
-                       if (!simple_empty(dentry)) {
+                       if (!autofs_empty(ino)) {
                                spin_unlock(&sbi->fs_lock);
                                goto done;
                        }
 
        if (rcu_walk) {
                /* We don't need fs_lock in rcu_walk mode,
-                * just testing 'AUTOFS_INFO_NO_RCU' is enough.
-                * simple_empty() takes a spinlock, so leave it
-                * to last.
+                * just testing 'AUTOFS_INF_WANT_EXPIRE' is enough.
+                *
                 * We only return -EISDIR when certain this isn't
                 * a mount-trap.
                 */
                inode = d_inode_rcu(dentry);
                if (inode && S_ISLNK(inode->i_mode))
                        return -EISDIR;
-               if (list_empty(&dentry->d_subdirs))
-                       return 0;
-               if (!simple_empty(dentry))
+               if (!autofs_empty(ino))
                        return -EISDIR;
                return 0;
        }
                 * we can avoid needless calls ->d_automount() and avoid
                 * an incorrect ELOOP error return.
                 */
-               if ((!path_is_mountpoint(path) && !simple_empty(dentry)) ||
+               if ((!path_is_mountpoint(path) && !autofs_empty(ino)) ||
                    (d_really_is_positive(dentry) && d_is_symlink(dentry)))
                        status = -EISDIR;
        }