Thread (31 messages) 31 messages, 4 authors, 2012-03-14

Re: [PATCH -V3 3/8] hugetlb: add charge/uncharge calls for HugeTLB alloc/free

From: Aneesh Kumar K.V <hidden>
Date: 2012-03-14 10:42:13
Also in: linux-mm, lkml

On Tue, 13 Mar 2012 17:31:52 +0400, Glauber Costa [off-list ref] wrote:
On 03/13/2012 11:07 AM, Aneesh Kumar K.V wrote:
quoted
diff --git a/mm/memcontrol.c b/mm/memcontrol.c
index 8cac77b..f4aa11c 100644
--- a/mm/memcontrol.c
+++ b/mm/memcontrol.c
@@ -2901,6 +2901,11 @@ __mem_cgroup_uncharge_common(struct page *page, enum charge_type ctype)

  	if (PageSwapCache(page))
  		return NULL;
+	/*
+	 * HugeTLB page uncharge happen in the HugeTLB compound page destructor
+	 */
+	if (PageHuge(page))
+		return NULL;
Maybe it is better to call uncharge_common from the compound destructor,
so we can have all the uncharge code in a single place.
PageHuge is not represented by a page flags as SwapCache. Hence I was
not able to call uncharge_common from compound destructor. For
SwapCache, we clear the flag and call uncharge_common again. Also I will
have to update those functions to take the resource counter index as
argument so that we end up updated the right resource counter in the
counter array. That would result in more code changes and I was not sure
about that.

-aneesh
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help