diff options
author | Andrew Morton <akpm@osdl.org> | 2004-06-23 19:24:33 -0700 |
---|---|---|
committer | Linus Torvalds <torvalds@ppc970.osdl.org> | 2004-06-23 19:24:33 -0700 |
commit | 0d3e94651d87ec7518320f9986f1a637163501c9 (patch) | |
tree | ff6858187b827bf9ba7a376ae72ce6ffa43a7140 /mm | |
parent | edadc05ffef4683d892dff02ee482021a2905510 (diff) | |
download | history-0d3e94651d87ec7518320f9986f1a637163501c9.tar.gz |
[PATCH] hugetlb.c - fix try_to_free_low()
From: "Chen, Kenneth W" <kenneth.w.chen@intel.com>
Turn on CONFIG_HIGHMEM and CONFIG_HUGETLBFS. Try to config the hugetlb
pool:
[root@quokka]# echo 100 > /proc/sys/vm/nr_hugepages
[root@quokka]# grep HugePage /proc/meminfo
HugePages_Total: 100
HugePages_Free: 100
[root@quokka]# echo 20 > /proc/sys/vm/nr_hugepages
[root@quokka]# grep HugePage /proc/meminfo
HugePages_Total: 0
HugePages_Free: 0
[root@quokka]# echo 100 > /proc/sys/vm/nr_hugepages
[root@quokka]# grep HugePage /proc/meminfo
HugePages_Total: 100
HugePages_Free: 100
[root@quokka]# echo 0 > /proc/sys/vm/nr_hugepages
[root@quokka]# grep HugePage /proc/meminfo
HugePages_Total: 31
HugePages_Free: 31
The argument "count" passed to try_to_free_low() is the config parameter
for desired hugetlb page pool size. But the implementation took that input
argument as number of pages to free. It also decrement the config
parameter as well. All give random behavior depend on how many hugetlb
pages are in normal/highmem zone.
A two line fix in try_to_free_low() would be:
- if (!--count)
- return 0;
+ if (count >= nr_huge_pages)
+ return count;
But more appropriately, that function shouldn't return anything.
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'mm')
-rw-r--r-- | mm/hugetlb.c | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/mm/hugetlb.c b/mm/hugetlb.c index 440a672da1107e..3dd936d1e7dd5d 100644 --- a/mm/hugetlb.c +++ b/mm/hugetlb.c @@ -130,7 +130,7 @@ static void update_and_free_page(struct page *page) } #ifdef CONFIG_HIGHMEM -static int try_to_free_low(unsigned long count) +static void try_to_free_low(unsigned long count) { int i; for (i = 0; i < MAX_NUMNODES; ++i) { @@ -141,16 +141,14 @@ static int try_to_free_low(unsigned long count) list_del(&page->lru); update_and_free_page(page); --free_huge_pages; - if (!--count) - return 0; + if (count >= nr_huge_pages) + return; } } - return count; } #else -static inline int try_to_free_low(unsigned long count) +static inline void try_to_free_low(unsigned long count) { - return count; } #endif @@ -170,7 +168,8 @@ static unsigned long set_max_huge_pages(unsigned long count) return nr_huge_pages; spin_lock(&hugetlb_lock); - for (count = try_to_free_low(count); count < nr_huge_pages; --free_huge_pages) { + try_to_free_low(count); + for (; count < nr_huge_pages; --free_huge_pages) { struct page *page = dequeue_huge_page(); if (!page) break; |