{
        struct cached_fid *cfid;
 
-       spin_lock(&cfids->cfid_list_lock);
        list_for_each_entry(cfid, &cfids->entries, entry) {
                if (!strcmp(cfid->path, path)) {
                        /*
                         * being deleted due to a lease break.
                         */
                        if (!cfid->time || !cfid->has_lease) {
-                               spin_unlock(&cfids->cfid_list_lock);
                                return NULL;
                        }
                        kref_get(&cfid->refcount);
-                       spin_unlock(&cfids->cfid_list_lock);
                        return cfid;
                }
        }
        if (lookup_only) {
-               spin_unlock(&cfids->cfid_list_lock);
                return NULL;
        }
        if (cfids->num_entries >= max_cached_dirs) {
-               spin_unlock(&cfids->cfid_list_lock);
                return NULL;
        }
        cfid = init_cached_dir(path);
        if (cfid == NULL) {
-               spin_unlock(&cfids->cfid_list_lock);
                return NULL;
        }
        cfid->cfids = cfids;
         */
        cfid->has_lease = true;
 
-       spin_unlock(&cfids->cfid_list_lock);
        return cfid;
 }
 
        if (!utf16_path)
                return -ENOMEM;
 
+       spin_lock(&cfids->cfid_list_lock);
        cfid = find_or_create_cached_dir(cfids, path, lookup_only, tcon->max_cached_dirs);
        if (cfid == NULL) {
+               spin_unlock(&cfids->cfid_list_lock);
                kfree(utf16_path);
                return -ENOENT;
        }
         * Otherwise, it is either a new entry or laundromat worker removed it
         * from @cfids->entries.  Caller will put last reference if the latter.
         */
-       spin_lock(&cfids->cfid_list_lock);
        if (cfid->has_lease && cfid->time) {
                spin_unlock(&cfids->cfid_list_lock);
                *ret_cfid = cfid;