summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Rientjes <rientjes@google.com>2022-12-28 07:05:48 +0100
committerVlastimil Babka <vbabka@suse.cz>2023-01-02 09:31:05 +0100
commitcc2e9d2b26c86c1dd8687f6916e5f621bcacd6f7 (patch)
tree51af4df8df89ddb5322e276d1ec57648268893ef
parentLinux 6.2-rc2 (diff)
downloadlinux-cc2e9d2b26c86c1dd8687f6916e5f621bcacd6f7.tar.xz
linux-cc2e9d2b26c86c1dd8687f6916e5f621bcacd6f7.zip
mm, slab: periodically resched in drain_freelist()
drain_freelist() can be called with a very large number of slabs to free, such as for kmem_cache_shrink(), or depending on various settings of the slab cache when doing periodic reaping. If there is a potentially long list of slabs to drain, periodically schedule to ensure we aren't saturating the cpu for too long. Signed-off-by: David Rientjes <rientjes@google.com> Reviewed-by: Hyeonggon Yoo <42.hyeyoo@gmail.com> Signed-off-by: Vlastimil Babka <vbabka@suse.cz>
Diffstat (limited to '')
-rw-r--r--mm/slab.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/mm/slab.c b/mm/slab.c
index 7a269db050ee..29300fc1289a 100644
--- a/mm/slab.c
+++ b/mm/slab.c
@@ -2211,6 +2211,8 @@ static int drain_freelist(struct kmem_cache *cache,
raw_spin_unlock_irq(&n->list_lock);
slab_destroy(cache, slab);
nr_freed++;
+
+ cond_resched();
}
out:
return nr_freed;