Commit 73108957 authored by Johannes Weiner's avatar Johannes Weiner Committed by Andrew Morton

mm: zswap: tighten up entry invalidation

Removing a zswap entry from the tree is tied to an explicit operation
that's supposed to drop the base reference: swap invalidation, exclusive
load, duplicate store.  Don't silently remove the entry on final put, but
instead warn if an entry is in tree without reference.

While in that diff context, convert a BUG_ON to a WARN_ON_ONCE.  No need
to crash on a refcount underflow.

Link: https://lkml.kernel.org/r/20230727162343.1415598-3-hannes@cmpxchg.orgSigned-off-by: default avatarJohannes Weiner <hannes@cmpxchg.org>
Reviewed-by: default avatarYosry Ahmed <yosryahmed@google.com>
Cc: Barry Song <song.bao.hua@hisilicon.com>
Cc: Domenico Cerasuolo <cerasuolodomenico@gmail.com>
Cc: Nhat Pham <nphamcs@gmail.com>
Cc: Seth Jennings <sjenning@redhat.com>
Cc: Vitaly Wool <vitaly.wool@konsulko.com>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
parent 56c67049
...@@ -417,9 +417,9 @@ static void zswap_entry_put(struct zswap_tree *tree, ...@@ -417,9 +417,9 @@ static void zswap_entry_put(struct zswap_tree *tree,
{ {
int refcount = --entry->refcount; int refcount = --entry->refcount;
BUG_ON(refcount < 0); WARN_ON_ONCE(refcount < 0);
if (refcount == 0) { if (refcount == 0) {
zswap_rb_erase(&tree->rbroot, entry); WARN_ON_ONCE(!RB_EMPTY_NODE(&entry->rbnode));
zswap_free_entry(entry); zswap_free_entry(entry);
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment