* @update: Function to call when updating a node.
  *
  * The XArray can notify a caller after it has updated an xa_node.
- * This is advanced functionality and is only needed by the page cache.
+ * This is advanced functionality and is only needed by the page
+ * cache and swap cache.
  */
 static inline void xas_set_update(struct xa_state *xas, xa_update_node_t update)
 {
 
        unsigned long i, nr = folio_nr_pages(folio);
        void *old;
 
+       xas_set_update(&xas, workingset_update_node);
+
        VM_BUG_ON_FOLIO(!folio_test_locked(folio), folio);
        VM_BUG_ON_FOLIO(folio_test_swapcache(folio), folio);
        VM_BUG_ON_FOLIO(!folio_test_swapbacked(folio), folio);
        pgoff_t idx = swp_offset(entry);
        XA_STATE(xas, &address_space->i_pages, idx);
 
+       xas_set_update(&xas, workingset_update_node);
+
        VM_BUG_ON_FOLIO(!folio_test_locked(folio), folio);
        VM_BUG_ON_FOLIO(!folio_test_swapcache(folio), folio);
        VM_BUG_ON_FOLIO(folio_test_writeback(folio), folio);
                struct address_space *address_space = swap_address_space(entry);
                XA_STATE(xas, &address_space->i_pages, curr);
 
+               xas_set_update(&xas, workingset_update_node);
+
                xa_lock_irq(&address_space->i_pages);
                xas_for_each(&xas, old, end) {
                        if (!xa_is_value(old))
 
                goto out;
        }
 
-       if (!spin_trylock(&mapping->host->i_lock)) {
-               xa_unlock(&mapping->i_pages);
-               spin_unlock_irq(lru_lock);
-               ret = LRU_RETRY;
-               goto out;
+       /* For page cache we need to hold i_lock */
+       if (mapping->host != NULL) {
+               if (!spin_trylock(&mapping->host->i_lock)) {
+                       xa_unlock(&mapping->i_pages);
+                       spin_unlock_irq(lru_lock);
+                       ret = LRU_RETRY;
+                       goto out;
+               }
        }
 
        list_lru_isolate(lru, item);
 
 out_invalid:
        xa_unlock_irq(&mapping->i_pages);
-       if (mapping_shrinkable(mapping))
-               inode_add_lru(mapping->host);
-       spin_unlock(&mapping->host->i_lock);
+       if (mapping->host != NULL) {
+               if (mapping_shrinkable(mapping))
+                       inode_add_lru(mapping->host);
+               spin_unlock(&mapping->host->i_lock);
+       }
        ret = LRU_REMOVED_RETRY;
 out:
        cond_resched();