aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mm/huge_memory.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/mm/huge_memory.c b/mm/huge_memory.c
index 253a25e007d7..7aae72114583 100644
--- a/mm/huge_memory.c
+++ b/mm/huge_memory.c
@@ -3465,12 +3465,7 @@ static unsigned long deferred_split_count(struct shrinker *shrink,
3465 struct shrink_control *sc) 3465 struct shrink_control *sc)
3466{ 3466{
3467 struct pglist_data *pgdata = NODE_DATA(sc->nid); 3467 struct pglist_data *pgdata = NODE_DATA(sc->nid);
3468 /* 3468 return ACCESS_ONCE(pgdata->split_queue_len);
3469 * Split a page from split_queue will free up at least one page,
3470 * at most HPAGE_PMD_NR - 1. We don't track exact number.
3471 * Let's use HPAGE_PMD_NR / 2 as ballpark.
3472 */
3473 return ACCESS_ONCE(pgdata->split_queue_len) * HPAGE_PMD_NR / 2;
3474} 3469}
3475 3470
3476static unsigned long deferred_split_scan(struct shrinker *shrink, 3471static unsigned long deferred_split_scan(struct shrinker *shrink,
@@ -3511,7 +3506,13 @@ static unsigned long deferred_split_scan(struct shrinker *shrink,
3511 list_splice_tail(&list, &pgdata->split_queue); 3506 list_splice_tail(&list, &pgdata->split_queue);
3512 spin_unlock_irqrestore(&pgdata->split_queue_lock, flags); 3507 spin_unlock_irqrestore(&pgdata->split_queue_lock, flags);
3513 3508
3514 return split * HPAGE_PMD_NR / 2; 3509 /*
3510 * Stop shrinker if we didn't split any page, but the queue is empty.
3511 * This can happen if pages were freed under us.
3512 */
3513 if (!split && list_empty(&pgdata->split_queue))
3514 return SHRINK_STOP;
3515 return split;
3515} 3516}
3516 3517
3517static struct shrinker deferred_split_shrinker = { 3518static struct shrinker deferred_split_shrinker = {