All of lore.kernel.org
 help / color / mirror / Atom feed
From: Kamezawa Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
To: Glauber Costa <glommer@parallels.com>
Cc: linux-kernel@vger.kernel.org, linux-mm@kvack.org,
	cgroups@vger.kernel.org, devel@openvz.org,
	Michal Hocko <mhocko@suse.cz>,
	Johannes Weiner <hannes@cmpxchg.org>,
	Andrew Morton <akpm@linux-foundation.org>,
	Christoph Lameter <cl@linux.com>,
	David Rientjes <rientjes@google.com>,
	Pekka Enberg <penberg@kernel.org>,
	Pekka Enberg <penberg@cs.helsinki.fi>,
	Suleiman Souhlal <suleiman@google.com>
Subject: Re: [PATCH v2 07/11] mm: Allocate kernel pages to the right memcg
Date: Sat, 11 Aug 2012 02:33:06 +0900	[thread overview]
Message-ID: <502545D2.80708@jp.fujitsu.com> (raw)
In-Reply-To: <1344517279-30646-8-git-send-email-glommer@parallels.com>

(2012/08/09 22:01), Glauber Costa wrote:
> When a process tries to allocate a page with the __GFP_KMEMCG flag, the
> page allocator will call the corresponding memcg functions to validate
> the allocation. Tasks in the root memcg can always proceed.
> 
> To avoid adding markers to the page - and a kmem flag that would
> necessarily follow, as much as doing page_cgroup lookups for no reason,
> whoever is marking its allocations with __GFP_KMEMCG flag is responsible
> for telling the page allocator that this is such an allocation at
> free_pages() time. This is done by the invocation of
> __free_accounted_pages() and free_accounted_pages().
> 
> Signed-off-by: Glauber Costa <glommer@parallels.com>
> CC: Christoph Lameter <cl@linux.com>
> CC: Pekka Enberg <penberg@cs.helsinki.fi>
> CC: Michal Hocko <mhocko@suse.cz>
> CC: Kamezawa Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
> CC: Johannes Weiner <hannes@cmpxchg.org>
> CC: Suleiman Souhlal <suleiman@google.com>

Ah, ok. free_accounted_page() seems good.

Acked-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>

I myself is okay with this. But...

Because you add a new hook to alloc_pages(), please get Ack from Mel
before requesting merge.

Thanks,
-Kame




> ---
>   include/linux/gfp.h |  3 +++
>   mm/page_alloc.c     | 38 ++++++++++++++++++++++++++++++++++++++
>   2 files changed, 41 insertions(+)
> 
> diff --git a/include/linux/gfp.h b/include/linux/gfp.h
> index d8eae4d..029570f 100644
> --- a/include/linux/gfp.h
> +++ b/include/linux/gfp.h
> @@ -370,6 +370,9 @@ extern void free_pages(unsigned long addr, unsigned int order);
>   extern void free_hot_cold_page(struct page *page, int cold);
>   extern void free_hot_cold_page_list(struct list_head *list, int cold);
>   
> +extern void __free_accounted_pages(struct page *page, unsigned int order);
> +extern void free_accounted_pages(unsigned long addr, unsigned int order);
> +
>   #define __free_page(page) __free_pages((page), 0)
>   #define free_page(addr) free_pages((addr), 0)
>   
> diff --git a/mm/page_alloc.c b/mm/page_alloc.c
> index b956cec..da341dc 100644
> --- a/mm/page_alloc.c
> +++ b/mm/page_alloc.c
> @@ -2532,6 +2532,7 @@ __alloc_pages_nodemask(gfp_t gfp_mask, unsigned int order,
>   	struct page *page = NULL;
>   	int migratetype = allocflags_to_migratetype(gfp_mask);
>   	unsigned int cpuset_mems_cookie;
> +	void *handle = NULL;
>   
>   	gfp_mask &= gfp_allowed_mask;
>   
> @@ -2543,6 +2544,13 @@ __alloc_pages_nodemask(gfp_t gfp_mask, unsigned int order,
>   		return NULL;
>   
>   	/*
> +	 * Will only have any effect when __GFP_KMEMCG is set.
> +	 * This is verified in the (always inline) callee
> +	 */
> +	if (!memcg_kmem_new_page(gfp_mask, &handle, order))
> +		return NULL;
> +
> +	/*
>   	 * Check the zones suitable for the gfp_mask contain at least one
>   	 * valid zone. It's possible to have an empty zonelist as a result
>   	 * of GFP_THISNODE and a memoryless node
> @@ -2583,6 +2591,8 @@ out:
>   	if (unlikely(!put_mems_allowed(cpuset_mems_cookie) && !page))
>   		goto retry_cpuset;
>   
> +	memcg_kmem_commit_page(page, handle, order);
> +
>   	return page;
>   }
>   EXPORT_SYMBOL(__alloc_pages_nodemask);
> @@ -2635,6 +2645,34 @@ void free_pages(unsigned long addr, unsigned int order)
>   
>   EXPORT_SYMBOL(free_pages);
>   
> +/*
> + * __free_accounted_pages and free_accounted_pages will free pages allocated
> + * with __GFP_KMEMCG.
> + *
> + * Those pages are accounted to a particular memcg, embedded in the
> + * corresponding page_cgroup. To avoid adding a hit in the allocator to search
> + * for that information only to find out that it is NULL for users who have no
> + * interest in that whatsoever, we provide these functions.
> + *
> + * The caller knows better which flags it relies on.
> + */
> +void __free_accounted_pages(struct page *page, unsigned int order)
> +{
> +	memcg_kmem_free_page(page, order);
> +	__free_pages(page, order);
> +}
> +EXPORT_SYMBOL(__free_accounted_pages);
> +
> +void free_accounted_pages(unsigned long addr, unsigned int order)
> +{
> +	if (addr != 0) {
> +		VM_BUG_ON(!virt_addr_valid((void *)addr));
> +		memcg_kmem_free_page(virt_to_page((void *)addr), order);
> +		__free_pages(virt_to_page((void *)addr), order);
> +	}
> +}
> +EXPORT_SYMBOL(free_accounted_pages);
> +
>   static void *make_alloc_exact(unsigned long addr, unsigned order, size_t size)
>   {
>   	if (addr) {
> 



WARNING: multiple messages have this Message-ID (diff)
From: Kamezawa Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
To: Glauber Costa <glommer@parallels.com>
Cc: linux-kernel@vger.kernel.org, linux-mm@kvack.org,
	cgroups@vger.kernel.org, devel@openvz.org,
	Michal Hocko <mhocko@suse.cz>,
	Johannes Weiner <hannes@cmpxchg.org>,
	Andrew Morton <akpm@linux-foundation.org>,
	Christoph Lameter <cl@linux.com>,
	David Rientjes <rientjes@google.com>,
	Pekka Enberg <penberg@kernel.org>,
	Pekka Enberg <penberg@cs.helsinki.fi>,
	Suleiman Souhlal <suleiman@google.com>
Subject: Re: [PATCH v2 07/11] mm: Allocate kernel pages to the right memcg
Date: Sat, 11 Aug 2012 02:33:06 +0900	[thread overview]
Message-ID: <502545D2.80708@jp.fujitsu.com> (raw)
In-Reply-To: <1344517279-30646-8-git-send-email-glommer@parallels.com>

(2012/08/09 22:01), Glauber Costa wrote:
> When a process tries to allocate a page with the __GFP_KMEMCG flag, the
> page allocator will call the corresponding memcg functions to validate
> the allocation. Tasks in the root memcg can always proceed.
> 
> To avoid adding markers to the page - and a kmem flag that would
> necessarily follow, as much as doing page_cgroup lookups for no reason,
> whoever is marking its allocations with __GFP_KMEMCG flag is responsible
> for telling the page allocator that this is such an allocation at
> free_pages() time. This is done by the invocation of
> __free_accounted_pages() and free_accounted_pages().
> 
> Signed-off-by: Glauber Costa <glommer@parallels.com>
> CC: Christoph Lameter <cl@linux.com>
> CC: Pekka Enberg <penberg@cs.helsinki.fi>
> CC: Michal Hocko <mhocko@suse.cz>
> CC: Kamezawa Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
> CC: Johannes Weiner <hannes@cmpxchg.org>
> CC: Suleiman Souhlal <suleiman@google.com>

Ah, ok. free_accounted_page() seems good.

Acked-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>

I myself is okay with this. But...

Because you add a new hook to alloc_pages(), please get Ack from Mel
before requesting merge.

Thanks,
-Kame




> ---
>   include/linux/gfp.h |  3 +++
>   mm/page_alloc.c     | 38 ++++++++++++++++++++++++++++++++++++++
>   2 files changed, 41 insertions(+)
> 
> diff --git a/include/linux/gfp.h b/include/linux/gfp.h
> index d8eae4d..029570f 100644
> --- a/include/linux/gfp.h
> +++ b/include/linux/gfp.h
> @@ -370,6 +370,9 @@ extern void free_pages(unsigned long addr, unsigned int order);
>   extern void free_hot_cold_page(struct page *page, int cold);
>   extern void free_hot_cold_page_list(struct list_head *list, int cold);
>   
> +extern void __free_accounted_pages(struct page *page, unsigned int order);
> +extern void free_accounted_pages(unsigned long addr, unsigned int order);
> +
>   #define __free_page(page) __free_pages((page), 0)
>   #define free_page(addr) free_pages((addr), 0)
>   
> diff --git a/mm/page_alloc.c b/mm/page_alloc.c
> index b956cec..da341dc 100644
> --- a/mm/page_alloc.c
> +++ b/mm/page_alloc.c
> @@ -2532,6 +2532,7 @@ __alloc_pages_nodemask(gfp_t gfp_mask, unsigned int order,
>   	struct page *page = NULL;
>   	int migratetype = allocflags_to_migratetype(gfp_mask);
>   	unsigned int cpuset_mems_cookie;
> +	void *handle = NULL;
>   
>   	gfp_mask &= gfp_allowed_mask;
>   
> @@ -2543,6 +2544,13 @@ __alloc_pages_nodemask(gfp_t gfp_mask, unsigned int order,
>   		return NULL;
>   
>   	/*
> +	 * Will only have any effect when __GFP_KMEMCG is set.
> +	 * This is verified in the (always inline) callee
> +	 */
> +	if (!memcg_kmem_new_page(gfp_mask, &handle, order))
> +		return NULL;
> +
> +	/*
>   	 * Check the zones suitable for the gfp_mask contain at least one
>   	 * valid zone. It's possible to have an empty zonelist as a result
>   	 * of GFP_THISNODE and a memoryless node
> @@ -2583,6 +2591,8 @@ out:
>   	if (unlikely(!put_mems_allowed(cpuset_mems_cookie) && !page))
>   		goto retry_cpuset;
>   
> +	memcg_kmem_commit_page(page, handle, order);
> +
>   	return page;
>   }
>   EXPORT_SYMBOL(__alloc_pages_nodemask);
> @@ -2635,6 +2645,34 @@ void free_pages(unsigned long addr, unsigned int order)
>   
>   EXPORT_SYMBOL(free_pages);
>   
> +/*
> + * __free_accounted_pages and free_accounted_pages will free pages allocated
> + * with __GFP_KMEMCG.
> + *
> + * Those pages are accounted to a particular memcg, embedded in the
> + * corresponding page_cgroup. To avoid adding a hit in the allocator to search
> + * for that information only to find out that it is NULL for users who have no
> + * interest in that whatsoever, we provide these functions.
> + *
> + * The caller knows better which flags it relies on.
> + */
> +void __free_accounted_pages(struct page *page, unsigned int order)
> +{
> +	memcg_kmem_free_page(page, order);
> +	__free_pages(page, order);
> +}
> +EXPORT_SYMBOL(__free_accounted_pages);
> +
> +void free_accounted_pages(unsigned long addr, unsigned int order)
> +{
> +	if (addr != 0) {
> +		VM_BUG_ON(!virt_addr_valid((void *)addr));
> +		memcg_kmem_free_page(virt_to_page((void *)addr), order);
> +		__free_pages(virt_to_page((void *)addr), order);
> +	}
> +}
> +EXPORT_SYMBOL(free_accounted_pages);
> +
>   static void *make_alloc_exact(unsigned long addr, unsigned order, size_t size)
>   {
>   	if (addr) {
> 


--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org.  For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>

WARNING: multiple messages have this Message-ID (diff)
From: Kamezawa Hiroyuki <kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
To: Glauber Costa <glommer-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
Cc: linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	linux-mm-Bw31MaZKKs3YtjvyW6yDsg@public.gmane.org,
	cgroups-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	devel-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org,
	Michal Hocko <mhocko-AlSwsSmVLrQ@public.gmane.org>,
	Johannes Weiner <hannes-druUgvl0LCNAfugRpC6u6w@public.gmane.org>,
	Andrew Morton
	<akpm-de/tnXTf+JLsfHDXvbKv3WD2FQJk+8+b@public.gmane.org>,
	Christoph Lameter <cl-vYTEC60ixJUAvxtiuMwx3w@public.gmane.org>,
	David Rientjes <rientjes-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>,
	Pekka Enberg <penberg-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>,
	Pekka Enberg <penberg-bbCR+/B0CizivPeTLB3BmA@public.gmane.org>,
	Suleiman Souhlal
	<suleiman-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>
Subject: Re: [PATCH v2 07/11] mm: Allocate kernel pages to the right memcg
Date: Sat, 11 Aug 2012 02:33:06 +0900	[thread overview]
Message-ID: <502545D2.80708@jp.fujitsu.com> (raw)
In-Reply-To: <1344517279-30646-8-git-send-email-glommer-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>

(2012/08/09 22:01), Glauber Costa wrote:
> When a process tries to allocate a page with the __GFP_KMEMCG flag, the
> page allocator will call the corresponding memcg functions to validate
> the allocation. Tasks in the root memcg can always proceed.
> 
> To avoid adding markers to the page - and a kmem flag that would
> necessarily follow, as much as doing page_cgroup lookups for no reason,
> whoever is marking its allocations with __GFP_KMEMCG flag is responsible
> for telling the page allocator that this is such an allocation at
> free_pages() time. This is done by the invocation of
> __free_accounted_pages() and free_accounted_pages().
> 
> Signed-off-by: Glauber Costa <glommer-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
> CC: Christoph Lameter <cl-vYTEC60ixJUAvxtiuMwx3w@public.gmane.org>
> CC: Pekka Enberg <penberg-bbCR+/B0CizivPeTLB3BmA@public.gmane.org>
> CC: Michal Hocko <mhocko-AlSwsSmVLrQ@public.gmane.org>
> CC: Kamezawa Hiroyuki <kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
> CC: Johannes Weiner <hannes-druUgvl0LCNAfugRpC6u6w@public.gmane.org>
> CC: Suleiman Souhlal <suleiman-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>

Ah, ok. free_accounted_page() seems good.

Acked-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>

I myself is okay with this. But...

Because you add a new hook to alloc_pages(), please get Ack from Mel
before requesting merge.

Thanks,
-Kame




> ---
>   include/linux/gfp.h |  3 +++
>   mm/page_alloc.c     | 38 ++++++++++++++++++++++++++++++++++++++
>   2 files changed, 41 insertions(+)
> 
> diff --git a/include/linux/gfp.h b/include/linux/gfp.h
> index d8eae4d..029570f 100644
> --- a/include/linux/gfp.h
> +++ b/include/linux/gfp.h
> @@ -370,6 +370,9 @@ extern void free_pages(unsigned long addr, unsigned int order);
>   extern void free_hot_cold_page(struct page *page, int cold);
>   extern void free_hot_cold_page_list(struct list_head *list, int cold);
>   
> +extern void __free_accounted_pages(struct page *page, unsigned int order);
> +extern void free_accounted_pages(unsigned long addr, unsigned int order);
> +
>   #define __free_page(page) __free_pages((page), 0)
>   #define free_page(addr) free_pages((addr), 0)
>   
> diff --git a/mm/page_alloc.c b/mm/page_alloc.c
> index b956cec..da341dc 100644
> --- a/mm/page_alloc.c
> +++ b/mm/page_alloc.c
> @@ -2532,6 +2532,7 @@ __alloc_pages_nodemask(gfp_t gfp_mask, unsigned int order,
>   	struct page *page = NULL;
>   	int migratetype = allocflags_to_migratetype(gfp_mask);
>   	unsigned int cpuset_mems_cookie;
> +	void *handle = NULL;
>   
>   	gfp_mask &= gfp_allowed_mask;
>   
> @@ -2543,6 +2544,13 @@ __alloc_pages_nodemask(gfp_t gfp_mask, unsigned int order,
>   		return NULL;
>   
>   	/*
> +	 * Will only have any effect when __GFP_KMEMCG is set.
> +	 * This is verified in the (always inline) callee
> +	 */
> +	if (!memcg_kmem_new_page(gfp_mask, &handle, order))
> +		return NULL;
> +
> +	/*
>   	 * Check the zones suitable for the gfp_mask contain at least one
>   	 * valid zone. It's possible to have an empty zonelist as a result
>   	 * of GFP_THISNODE and a memoryless node
> @@ -2583,6 +2591,8 @@ out:
>   	if (unlikely(!put_mems_allowed(cpuset_mems_cookie) && !page))
>   		goto retry_cpuset;
>   
> +	memcg_kmem_commit_page(page, handle, order);
> +
>   	return page;
>   }
>   EXPORT_SYMBOL(__alloc_pages_nodemask);
> @@ -2635,6 +2645,34 @@ void free_pages(unsigned long addr, unsigned int order)
>   
>   EXPORT_SYMBOL(free_pages);
>   
> +/*
> + * __free_accounted_pages and free_accounted_pages will free pages allocated
> + * with __GFP_KMEMCG.
> + *
> + * Those pages are accounted to a particular memcg, embedded in the
> + * corresponding page_cgroup. To avoid adding a hit in the allocator to search
> + * for that information only to find out that it is NULL for users who have no
> + * interest in that whatsoever, we provide these functions.
> + *
> + * The caller knows better which flags it relies on.
> + */
> +void __free_accounted_pages(struct page *page, unsigned int order)
> +{
> +	memcg_kmem_free_page(page, order);
> +	__free_pages(page, order);
> +}
> +EXPORT_SYMBOL(__free_accounted_pages);
> +
> +void free_accounted_pages(unsigned long addr, unsigned int order)
> +{
> +	if (addr != 0) {
> +		VM_BUG_ON(!virt_addr_valid((void *)addr));
> +		memcg_kmem_free_page(virt_to_page((void *)addr), order);
> +		__free_pages(virt_to_page((void *)addr), order);
> +	}
> +}
> +EXPORT_SYMBOL(free_accounted_pages);
> +
>   static void *make_alloc_exact(unsigned long addr, unsigned order, size_t size)
>   {
>   	if (addr) {
> 


  parent reply	other threads:[~2012-08-10 17:33 UTC|newest]

Thread overview: 352+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-08-09 13:01 [PATCH v2 00/11] Request for Inclusion: kmem controller for memcg Glauber Costa
2012-08-09 13:01 ` Glauber Costa
2012-08-09 13:01 ` Glauber Costa
2012-08-09 13:01 ` [PATCH v2 01/11] memcg: Make it possible to use the stock for more than one page Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-10 15:12   ` Michal Hocko
2012-08-10 15:12     ` Michal Hocko
2012-08-09 13:01 ` [PATCH v2 02/11] memcg: Reclaim when more than one page needed Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-10 15:42   ` Michal Hocko
2012-08-10 15:42     ` Michal Hocko
2012-08-10 15:42     ` Michal Hocko
2012-08-10 16:49     ` Kamezawa Hiroyuki
2012-08-10 16:49       ` Kamezawa Hiroyuki
2012-08-10 16:49       ` Kamezawa Hiroyuki
2012-08-10 17:28       ` Michal Hocko
2012-08-10 17:28         ` Michal Hocko
2012-08-10 17:28         ` Michal Hocko
2012-08-10 17:56         ` Kamezawa Hiroyuki
2012-08-10 17:56           ` Kamezawa Hiroyuki
2012-08-10 17:30   ` Michal Hocko
2012-08-10 17:30     ` Michal Hocko
2012-08-10 17:30     ` Michal Hocko
2012-08-10 18:52     ` Michal Hocko
2012-08-10 18:52       ` Michal Hocko
2012-08-10 18:52       ` Michal Hocko
2012-08-10 18:54   ` Michal Hocko
2012-08-10 18:54     ` Michal Hocko
2012-08-10 18:54     ` Michal Hocko
2012-08-13  8:05     ` Glauber Costa
2012-08-13  8:05       ` Glauber Costa
2012-08-13  8:05       ` Glauber Costa
2012-08-13 13:10       ` Michal Hocko
2012-08-13 13:10         ` Michal Hocko
2012-08-13 13:10         ` Michal Hocko
2012-08-09 13:01 ` [PATCH v2 03/11] memcg: change defines to an enum Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-10 15:43   ` Michal Hocko
2012-08-10 15:43     ` Michal Hocko
2012-08-10 15:43     ` Michal Hocko
2012-08-09 13:01 ` [PATCH v2 04/11] kmem accounting basic infrastructure Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-10 17:02   ` Kamezawa Hiroyuki
2012-08-10 17:02     ` Kamezawa Hiroyuki
2012-08-10 17:02     ` Kamezawa Hiroyuki
2012-08-13  8:36     ` Glauber Costa
2012-08-13  8:36       ` Glauber Costa
2012-08-13  8:36       ` Glauber Costa
2012-08-17  2:38       ` Kamezawa Hiroyuki
2012-08-17  2:38         ` Kamezawa Hiroyuki
2012-08-14 16:21   ` Michal Hocko
2012-08-14 16:21     ` Michal Hocko
2012-08-15  9:33     ` Glauber Costa
2012-08-15  9:33       ` Glauber Costa
2012-08-15 11:12       ` James Bottomley
2012-08-15 11:12         ` James Bottomley
2012-08-15 11:12         ` James Bottomley
2012-08-15 12:55         ` Michal Hocko
2012-08-15 12:55           ` Michal Hocko
2012-08-15 12:55           ` Michal Hocko
2012-08-15 13:29           ` James Bottomley
2012-08-15 13:29             ` James Bottomley
2012-08-15 12:39       ` Michal Hocko
2012-08-15 12:39         ` Michal Hocko
2012-08-15 12:39         ` Michal Hocko
2012-08-15 12:53         ` Glauber Costa
2012-08-15 12:53           ` Glauber Costa
2012-08-15 12:53           ` Glauber Costa
2012-08-15 13:02           ` Michal Hocko
2012-08-15 13:02             ` Michal Hocko
2012-08-15 13:02             ` Michal Hocko
2012-08-15 13:04             ` Glauber Costa
2012-08-15 13:04               ` Glauber Costa
2012-08-15 13:04               ` Glauber Costa
2012-08-15 13:26               ` Michal Hocko
2012-08-15 13:26                 ` Michal Hocko
2012-08-15 13:26                 ` Michal Hocko
2012-08-15 13:31                 ` Glauber Costa
2012-08-15 13:31                   ` Glauber Costa
2012-08-15 13:31                   ` Glauber Costa
2012-08-15 14:10                   ` Michal Hocko
2012-08-15 14:10                     ` Michal Hocko
2012-08-15 14:10                     ` Michal Hocko
2012-08-15 14:11                     ` Glauber Costa
2012-08-15 14:11                       ` Glauber Costa
2012-08-15 14:11                       ` Glauber Costa
2012-08-15 14:47         ` Christoph Lameter
2012-08-15 14:47           ` Christoph Lameter
2012-08-15 15:11           ` Glauber Costa
2012-08-15 15:11             ` Glauber Costa
2012-08-15 15:11             ` Glauber Costa
2012-08-15 15:34             ` Christoph Lameter
2012-08-15 15:34               ` Christoph Lameter
2012-08-15 15:35               ` Glauber Costa
2012-08-15 15:35                 ` Glauber Costa
2012-08-15 15:35                 ` Glauber Costa
2012-08-15 17:26                 ` Christoph Lameter
2012-08-15 17:26                   ` Christoph Lameter
2012-08-15 17:26                   ` Christoph Lameter
2012-08-15 18:11               ` Ying Han
2012-08-15 18:11                 ` Ying Han
2012-08-15 18:11                 ` Ying Han
2012-08-15 18:25                 ` Christoph Lameter
2012-08-15 18:25                   ` Christoph Lameter
2012-08-15 18:25                   ` Christoph Lameter
2012-08-15 19:22                   ` Glauber Costa
2012-08-15 19:22                     ` Glauber Costa
2012-08-15 19:22                     ` Glauber Costa
2012-08-15 18:07             ` Ying Han
2012-08-15 18:07               ` Ying Han
2012-08-15 15:19           ` Greg Thelen
2012-08-15 15:19             ` Greg Thelen
2012-08-15 15:36             ` Christoph Lameter
2012-08-15 15:36               ` Christoph Lameter
2012-08-15 18:01         ` Ying Han
2012-08-15 18:01           ` Ying Han
2012-08-15 18:00           ` Glauber Costa
2012-08-15 18:00             ` Glauber Costa
2012-08-15 18:00             ` Glauber Costa
2012-08-15 19:50     ` Ying Han
2012-08-15 19:50       ` Ying Han
2012-08-16 15:25       ` Michal Hocko
2012-08-16 15:25         ` Michal Hocko
2012-08-16 15:25         ` Michal Hocko
2012-08-17  5:58         ` Ying Han
2012-08-17  5:58           ` Ying Han
2012-08-09 13:01 ` [PATCH v2 05/11] Add a __GFP_KMEMCG flag Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-10 17:07   ` Kamezawa Hiroyuki
2012-08-10 17:07     ` Kamezawa Hiroyuki
2012-08-10 17:07     ` Kamezawa Hiroyuki
2012-08-09 13:01 ` [PATCH v2 06/11] memcg: kmem controller infrastructure Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-10 17:27   ` Kamezawa Hiroyuki
2012-08-10 17:27     ` Kamezawa Hiroyuki
2012-08-10 17:27     ` Kamezawa Hiroyuki
2012-08-13  8:28     ` Glauber Costa
2012-08-13  8:28       ` Glauber Costa
2012-08-14 18:58       ` Greg Thelen
2012-08-14 18:58         ` Greg Thelen
2012-08-15  9:18         ` Glauber Costa
2012-08-15  9:18           ` Glauber Costa
2012-08-15  9:18           ` Glauber Costa
2012-08-15 16:38           ` Greg Thelen
2012-08-15 16:38             ` Greg Thelen
2012-08-15 17:00             ` Glauber Costa
2012-08-15 17:00               ` Glauber Costa
2012-08-15 17:00               ` Glauber Costa
2012-08-15 17:12               ` Greg Thelen
2012-08-15 17:12                 ` Greg Thelen
2012-08-15 17:12                 ` Greg Thelen
2012-08-15 19:31                 ` Glauber Costa
2012-08-15 19:31                   ` Glauber Costa
2012-08-15 19:31                   ` Glauber Costa
2012-08-16  3:37                   ` Greg Thelen
2012-08-16  3:37                     ` Greg Thelen
2012-08-16  3:37                     ` Greg Thelen
2012-08-16  7:47                     ` Glauber Costa
2012-08-16  7:47                       ` Glauber Costa
2012-08-16  7:47                       ` Glauber Costa
2012-08-20 13:36               ` Kamezawa Hiroyuki
2012-08-20 13:36                 ` Kamezawa Hiroyuki
2012-08-20 15:29                 ` Glauber Costa
2012-08-20 15:29                   ` Glauber Costa
2012-08-20 15:29                   ` Glauber Costa
2012-08-17  2:36       ` Kamezawa Hiroyuki
2012-08-17  2:36         ` Kamezawa Hiroyuki
2012-08-17  2:36         ` Kamezawa Hiroyuki
2012-08-17  7:04         ` Glauber Costa
2012-08-17  7:04           ` Glauber Costa
2012-08-17  7:04           ` Glauber Costa
2012-08-14 11:00     ` Glauber Costa
2012-08-14 11:00       ` Glauber Costa
2012-08-11  5:11   ` Greg Thelen
2012-08-11  5:11     ` Greg Thelen
2012-08-13  8:07     ` Glauber Costa
2012-08-13  8:07       ` Glauber Costa
2012-08-13  9:59     ` Glauber Costa
2012-08-13  9:59       ` Glauber Costa
2012-08-13 21:21       ` Greg Thelen
2012-08-13 21:21         ` Greg Thelen
2012-08-14 17:25   ` Michal Hocko
2012-08-14 17:25     ` Michal Hocko
2012-08-14 17:25     ` Michal Hocko
2012-08-15  9:42     ` Glauber Costa
2012-08-15  9:42       ` Glauber Costa
2012-08-15 10:44       ` Glauber Costa
2012-08-15 10:44         ` Glauber Costa
2012-08-15 13:09       ` Michal Hocko
2012-08-15 13:09         ` Michal Hocko
2012-08-15 13:09         ` Michal Hocko
2012-08-15 14:01         ` Glauber Costa
2012-08-15 14:01           ` Glauber Costa
2012-08-15 14:23           ` Michal Hocko
2012-08-15 14:23             ` Michal Hocko
2012-08-15 14:23             ` Michal Hocko
2012-08-15 14:27             ` Glauber Costa
2012-08-15 14:27               ` Glauber Costa
2012-08-16  9:53               ` Michal Hocko
2012-08-16  9:53                 ` Michal Hocko
2012-08-16  9:57                 ` Glauber Costa
2012-08-16  9:57                   ` Glauber Costa
2012-08-16  9:57                   ` Glauber Costa
2012-08-16 15:05                   ` Michal Hocko
2012-08-16 15:05                     ` Michal Hocko
2012-08-16 15:22                     ` Glauber Costa
2012-08-16 15:22                       ` Glauber Costa
2012-08-21 21:50   ` Greg Thelen
2012-08-21 21:50     ` Greg Thelen
2012-08-22  8:35     ` Glauber Costa
2012-08-22  8:35       ` Glauber Costa
2012-08-23  0:07       ` Greg Thelen
2012-08-23  0:07         ` Greg Thelen
2012-08-23  0:07         ` Greg Thelen
2012-08-23  7:51         ` Glauber Costa
2012-08-23  7:51           ` Glauber Costa
2012-08-23  7:51           ` Glauber Costa
2012-08-09 13:01 ` [PATCH v2 07/11] mm: Allocate kernel pages to the right memcg Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-09 16:33   ` Greg Thelen
2012-08-09 16:33     ` Greg Thelen
2012-08-09 16:33     ` Greg Thelen
2012-08-09 16:42     ` Glauber Costa
2012-08-09 16:42       ` Glauber Costa
2012-08-09 16:42       ` Glauber Costa
2012-08-10 17:33   ` Kamezawa Hiroyuki [this message]
2012-08-10 17:33     ` Kamezawa Hiroyuki
2012-08-10 17:33     ` Kamezawa Hiroyuki
2012-08-13  8:03     ` Glauber Costa
2012-08-13  8:03       ` Glauber Costa
2012-08-13  8:03       ` Glauber Costa
2012-08-13  8:57       ` Mel Gorman
2012-08-13  8:57         ` Mel Gorman
2012-08-10 17:36   ` Greg Thelen
2012-08-10 17:36     ` Greg Thelen
2012-08-10 17:36     ` Greg Thelen
2012-08-13  8:02     ` Glauber Costa
2012-08-13  8:02       ` Glauber Costa
2012-08-14 15:16   ` Mel Gorman
2012-08-14 15:16     ` Mel Gorman
2012-08-14 15:16     ` Mel Gorman
2012-08-15  9:08     ` Glauber Costa
2012-08-15  9:08       ` Glauber Costa
2012-08-15 13:22       ` Mel Gorman
2012-08-15 13:22         ` Mel Gorman
2012-08-15 13:22         ` Mel Gorman
2012-08-15 13:39         ` Glauber Costa
2012-08-15 13:39           ` Glauber Costa
2012-08-15 13:51         ` Glauber Costa
2012-08-15 13:51           ` Glauber Costa
2012-08-15 13:51           ` Glauber Costa
2012-08-15  9:24   ` Michal Hocko
2012-08-15  9:24     ` Michal Hocko
2012-08-15  9:24     ` Michal Hocko
2012-08-09 13:01 ` [PATCH v2 08/11] memcg: disable kmem code when not in use Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-17  7:02   ` Michal Hocko
2012-08-17  7:02     ` Michal Hocko
2012-08-17  7:01     ` Glauber Costa
2012-08-17  7:01       ` Glauber Costa
2012-08-17  8:04       ` Michal Hocko
2012-08-17  8:04         ` Michal Hocko
2012-08-09 13:01 ` [PATCH v2 09/11] memcg: propagate kmem limiting information to children Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-10 17:51   ` Kamezawa Hiroyuki
2012-08-10 17:51     ` Kamezawa Hiroyuki
2012-08-10 17:51     ` Kamezawa Hiroyuki
2012-08-13  8:01     ` Glauber Costa
2012-08-13  8:01       ` Glauber Costa
2012-08-13  8:01       ` Glauber Costa
2012-08-17  9:00   ` Michal Hocko
2012-08-17  9:00     ` Michal Hocko
2012-08-17  9:15     ` Glauber Costa
2012-08-17  9:15       ` Glauber Costa
2012-08-17  9:35       ` Michal Hocko
2012-08-17  9:35         ` Michal Hocko
2012-08-17 10:07         ` Glauber Costa
2012-08-17 10:07           ` Glauber Costa
2012-08-17 10:07           ` Glauber Costa
2012-08-17 10:35           ` Michal Hocko
2012-08-17 10:35             ` Michal Hocko
2012-08-17 10:35             ` Michal Hocko
2012-08-17 10:36             ` Glauber Costa
2012-08-17 10:36               ` Glauber Costa
2012-08-21  7:54               ` Michal Hocko
2012-08-21  7:54                 ` Michal Hocko
2012-08-21  7:54                 ` Michal Hocko
2012-08-21  8:35                 ` Michal Hocko
2012-08-21  8:35                   ` Michal Hocko
2012-08-21  9:17                   ` Glauber Costa
2012-08-21  9:17                     ` Glauber Costa
2012-08-21  9:22                 ` Glauber Costa
2012-08-21  9:22                   ` Glauber Costa
2012-08-21  9:22                   ` Glauber Costa
2012-08-21 10:00                   ` Michal Hocko
2012-08-21 10:00                     ` Michal Hocko
2012-08-21 10:01                     ` Glauber Costa
2012-08-21 10:01                       ` Glauber Costa
2012-08-22  1:09                     ` Greg Thelen
2012-08-22  1:09                       ` Greg Thelen
2012-08-22  8:22                       ` Glauber Costa
2012-08-22  8:22                         ` Glauber Costa
2012-08-22 23:23                         ` Greg Thelen
2012-08-22 23:23                           ` Greg Thelen
2012-08-23  7:55                           ` Glauber Costa
2012-08-23  7:55                             ` Glauber Costa
2012-08-23  7:55                             ` Glauber Costa
2012-08-24  5:06                             ` Greg Thelen
2012-08-24  5:06                               ` Greg Thelen
2012-08-24  5:06                               ` Greg Thelen
2012-08-24  5:23                               ` Glauber Costa
2012-08-24  5:23                                 ` Glauber Costa
2012-08-24  5:23                                 ` Glauber Costa
2012-08-17 10:39             ` Glauber Costa
2012-08-17 10:39               ` Glauber Costa
2012-08-17 10:39               ` Glauber Costa
2012-08-09 13:01 ` [PATCH v2 10/11] memcg: allow a memcg with kmem charges to be destructed Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-21  8:22   ` Michal Hocko
2012-08-21  8:22     ` Michal Hocko
2012-08-21  8:22     ` Michal Hocko
2012-08-22  8:36     ` Glauber Costa
2012-08-22  8:36       ` Glauber Costa
2012-08-09 13:01 ` [PATCH v2 11/11] protect architectures where THREAD_SIZE >= PAGE_SIZE against fork bombs Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-09 13:01   ` Glauber Costa
2012-08-10 17:54   ` Kamezawa Hiroyuki
2012-08-10 17:54     ` Kamezawa Hiroyuki
2012-08-10 17:54     ` Kamezawa Hiroyuki
2012-08-21  9:35   ` Michal Hocko
2012-08-21  9:35     ` Michal Hocko
2012-08-21  9:40     ` Glauber Costa
2012-08-21  9:40       ` Glauber Costa
2012-08-21  9:40       ` Glauber Costa
2012-08-21 10:57       ` Michal Hocko
2012-08-21 10:57         ` Michal Hocko
2012-08-21 10:57         ` Michal Hocko
2012-08-17 21:37 ` [PATCH v2 00/11] Request for Inclusion: kmem controller for memcg Ying Han
2012-08-17 21:37   ` Ying Han
2012-08-20  7:51   ` Glauber Costa
2012-08-20  7:51     ` Glauber Costa
2012-08-20  7:51     ` Glauber Costa

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=502545D2.80708@jp.fujitsu.com \
    --to=kamezawa.hiroyu@jp.fujitsu.com \
    --cc=akpm@linux-foundation.org \
    --cc=cgroups@vger.kernel.org \
    --cc=cl@linux.com \
    --cc=devel@openvz.org \
    --cc=glommer@parallels.com \
    --cc=hannes@cmpxchg.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-mm@kvack.org \
    --cc=mhocko@suse.cz \
    --cc=penberg@cs.helsinki.fi \
    --cc=penberg@kernel.org \
    --cc=rientjes@google.com \
    --cc=suleiman@google.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.