diff options
author | Kirill A. Shutemov <kirill.shutemov@linux.intel.com> | 2016-02-02 19:57:12 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2016-02-03 11:28:43 -0500 |
commit | cb8d68ec16a511f8be7e1028fd8f869ef7c6a1a8 (patch) | |
tree | bca734285ef34b21cbdc7d3c3873981c41c76d4e /mm | |
parent | a3d0a918502cc73af4f60da2cc4c5cac5573f183 (diff) |
thp: change deferred_split_count() to return number of THP in queue
I've got meaning of shrinker::count_objects() wrong: it should return
number of potentially freeable objects, which is not necessary correlate
with freeable memory.
Returning 256 per THP in queue is not reasonable:
shrinker::scan_objects() never called with nr_to_scan > 128 in my setup.
Let's return 1 per THP and correct scan_object accordingly.
Signed-off-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
Reviewed-by: Andrea Arcangeli <aarcange@redhat.com>
Cc: Hugh Dickins <hughd@google.com>
Cc: Dave Hansen <dave.hansen@intel.com>
Cc: Mel Gorman <mgorman@suse.de>
Cc: Rik van Riel <riel@redhat.com>
Cc: Vlastimil Babka <vbabka@suse.cz>
Cc: "Aneesh Kumar K.V" <aneesh.kumar@linux.vnet.ibm.com>
Cc: Johannes Weiner <hannes@cmpxchg.org>
Cc: Michal Hocko <mhocko@suse.cz>
Cc: Jerome Marchand <jmarchan@redhat.com>
Cc: Sasha Levin <sasha.levin@oracle.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'mm')
-rw-r--r-- | mm/huge_memory.c | 15 |
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 | ||
3476 | static unsigned long deferred_split_scan(struct shrinker *shrink, | 3471 | static 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 | ||
3517 | static struct shrinker deferred_split_shrinker = { | 3518 | static struct shrinker deferred_split_shrinker = { |