diff --git a/module/zfs/arc.c b/module/zfs/arc.c index 79b04f455..efac973ba 100644 --- a/module/zfs/arc.c +++ b/module/zfs/arc.c @@ -4423,12 +4423,12 @@ __arc_shrinker_func(struct shrinker *shrink, struct shrink_control *sc) /* * Evict the requested number of pages by shrinking arc_c the - * requested amount. If there is nothing left to evict just - * reap whatever we can from the various arc slabs. + * requested amount. */ if (pages > 0) { arc_shrink(ptob(sc->nr_to_scan)); - arc_kmem_reap_now(); + if (current_is_kswapd()) + arc_kmem_reap_now(); #ifdef HAVE_SPLIT_SHRINKER_CALLBACK pages = MAX(pages - btop(arc_evictable_memory()), 0); #else @@ -4439,10 +4439,8 @@ __arc_shrinker_func(struct shrinker *shrink, struct shrink_control *sc) */ cv_broadcast(&arc_reclaim_waiters_cv); - } else { - arc_kmem_reap_now(); + } else pages = SHRINK_STOP; - } /* * When direct reclaim is observed it usually indicates a rapid @@ -4455,6 +4453,7 @@ __arc_shrinker_func(struct shrinker *shrink, struct shrink_control *sc) ARCSTAT_BUMP(arcstat_memory_indirect_count); } else { arc_no_grow = B_TRUE; + arc_kmem_reap_now(); ARCSTAT_BUMP(arcstat_memory_direct_count); }