static bool swap_count_continued(struct swap_info_struct *, pgoff_t,
                                 unsigned char);
 static void free_swap_count_continuations(struct swap_info_struct *);
-static void swap_entry_range_free(struct swap_info_struct *si,
-                                 struct swap_cluster_info *ci,
-                                 swp_entry_t entry, unsigned int nr_pages);
+static void swap_entries_free(struct swap_info_struct *si,
+                             struct swap_cluster_info *ci,
+                             swp_entry_t entry, unsigned int nr_pages);
 static void swap_range_alloc(struct swap_info_struct *si,
                             unsigned int nr_entries);
 static bool folio_swapcache_freeable(struct folio *folio);
        ci = lock_cluster(si, offset);
        usage = swap_entry_put_locked(si, offset, 1);
        if (!usage)
-               swap_entry_range_free(si, ci, swp_entry(si->type, offset), 1);
+               swap_entries_free(si, ci, swp_entry(si->type, offset), 1);
        unlock_cluster(ci);
 
        return usage;
        for (i = 0; i < nr; i++)
                WRITE_ONCE(si->swap_map[offset + i], SWAP_HAS_CACHE);
        if (!has_cache)
-               swap_entry_range_free(si, ci, entry, nr);
+               swap_entries_free(si, ci, entry, nr);
        unlock_cluster(ci);
 
        return has_cache;
 }
 
 /*
- * Drop the last HAS_CACHE flag of swap entries, caller have to
- * ensure all entries belong to the same cgroup.
+ * Check if it's the last ref of swap entry in the freeing path.
+ * Qualified vlaue includes 1, SWAP_HAS_CACHE or SWAP_MAP_SHMEM.
  */
-static void swap_entry_range_free(struct swap_info_struct *si,
-                                 struct swap_cluster_info *ci,
-                                 swp_entry_t entry, unsigned int nr_pages)
+static inline bool __maybe_unused swap_is_last_ref(unsigned char count)
+{
+       return (count == SWAP_HAS_CACHE) || (count == 1) ||
+              (count == SWAP_MAP_SHMEM);
+}
+
+/*
+ * Drop the last ref of swap entries, caller have to ensure all entries
+ * belong to the same cgroup and cluster.
+ */
+static void swap_entries_free(struct swap_info_struct *si,
+                             struct swap_cluster_info *ci,
+                             swp_entry_t entry, unsigned int nr_pages)
 {
        unsigned long offset = swp_offset(entry);
        unsigned char *map = si->swap_map + offset;
 
        ci->count -= nr_pages;
        do {
-               VM_BUG_ON(*map != SWAP_HAS_CACHE);
+               VM_BUG_ON(!swap_is_last_ref(*map));
                *map = 0;
        } while (++map < map_end);
 
        ci = lock_cluster(si, offset);
        do {
                if (!swap_entry_put_locked(si, offset, usage))
-                       swap_entry_range_free(si, ci, swp_entry(si->type, offset), 1);
+                       swap_entries_free(si, ci, swp_entry(si->type, offset), 1);
        } while (++offset < end);
        unlock_cluster(ci);
 }
 
        ci = lock_cluster(si, offset);
        if (swap_only_has_cache(si, offset, size))
-               swap_entry_range_free(si, ci, entry, size);
+               swap_entries_free(si, ci, entry, size);
        else {
                for (int i = 0; i < size; i++, entry.val++) {
                        if (!swap_entry_put_locked(si, offset + i, SWAP_HAS_CACHE))
-                               swap_entry_range_free(si, ci, entry, 1);
+                               swap_entries_free(si, ci, entry, 1);
                }
        }
        unlock_cluster(ci);