All of lore.kernel.org
 help / color / mirror / Atom feed
From: KAMEZAWA Hiroyuki <kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
To: Andrea Righi <arighi-vWjgImWzx8FBDgjK7y7TUQ@public.gmane.org>
Cc: Daisuke Nishimura
	<nishimura-YQH0OdQVrdy45+QrQBaojngSJqDPrsil@public.gmane.org>,
	linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	Trond Myklebust
	<trond.myklebust-41N18TsMXrtuMpJDpNschA@public.gmane.org>,
	linux-mm-Bw31MaZKKs3YtjvyW6yDsg@public.gmane.org,
	Greg-FOgKQjlUJ6BQetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org,
	Suleiman Souhlal
	<suleiman-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>,
	Andrew Morton
	<akpm-de/tnXTf+JLsfHDXvbKv3WD2FQJk+8+b@public.gmane.org>,
	Peter-FOgKQjlUJ6BQetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org,
	containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org,
	Vivek Goyal <vgoyal-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>,
	Balbir Singh
	<balbir-23VcF4HTsmIX0ybBhKVfKdBPR1lH4CV8@public.gmane.org>
Subject: Re: [PATCH -mmotm 1/5] memcg: disable irq at page cgroup lock
Date: Mon, 15 Mar 2010 09:06:38 +0900	[thread overview]
Message-ID: <20100315090638.ee416d93.kamezawa.hiroyu__22737.6810777516$1268611873$gmane$org@jp.fujitsu.com> (raw)
In-Reply-To: <1268609202-15581-2-git-send-email-arighi-vWjgImWzx8FBDgjK7y7TUQ@public.gmane.org>

On Mon, 15 Mar 2010 00:26:38 +0100
Andrea Righi <arighi-vWjgImWzx8FBDgjK7y7TUQ@public.gmane.org> wrote:

> From: KAMEZAWA Hiroyuki <kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
> 
> Now, file-mapped is maintaiend. But more generic update function
> will be needed for dirty page accounting.
> 
> For accountig page status, we have to guarantee lock_page_cgroup()
> will be never called under tree_lock held.
> To guarantee that, we use trylock at updating status.
> By this, we do fuzzy accounting, but in almost all case, it's correct.
> 
> Signed-off-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>

Bad patch title...."use trylock for safe accounting in some contexts" ?

Thanks,
-Kame

> ---
>  include/linux/memcontrol.h  |    7 +++-
>  include/linux/page_cgroup.h |   15 +++++++
>  mm/memcontrol.c             |   94 +++++++++++++++++++++++++++++++++----------
>  mm/rmap.c                   |    4 +-
>  4 files changed, 95 insertions(+), 25 deletions(-)
> 
> diff --git a/include/linux/memcontrol.h b/include/linux/memcontrol.h
> index 44301c6..88d3f9e 100644
> --- a/include/linux/memcontrol.h
> +++ b/include/linux/memcontrol.h
> @@ -124,7 +124,12 @@ static inline bool mem_cgroup_disabled(void)
>  	return false;
>  }
>  
> -void mem_cgroup_update_file_mapped(struct page *page, int val);
> +enum mem_cgroup_page_stat_item {
> +	MEMCG_NR_FILE_MAPPED,
> +	MEMCG_NR_FILE_NSTAT,
> +};
> +
> +void mem_cgroup_update_stat(struct page *page, int idx, bool charge);
>  unsigned long mem_cgroup_soft_limit_reclaim(struct zone *zone, int order,
>  						gfp_t gfp_mask, int nid,
>  						int zid);
> diff --git a/include/linux/page_cgroup.h b/include/linux/page_cgroup.h
> index 30b0813..bf9a913 100644
> --- a/include/linux/page_cgroup.h
> +++ b/include/linux/page_cgroup.h
> @@ -39,6 +39,8 @@ enum {
>  	PCG_CACHE, /* charged as cache */
>  	PCG_USED, /* this object is in use. */
>  	PCG_ACCT_LRU, /* page has been accounted for */
> +	/* for cache-status accounting */
> +	PCG_FILE_MAPPED,
>  };
>  
>  #define TESTPCGFLAG(uname, lname)			\
> @@ -57,6 +59,10 @@ static inline void ClearPageCgroup##uname(struct page_cgroup *pc)	\
>  static inline int TestClearPageCgroup##uname(struct page_cgroup *pc)	\
>  	{ return test_and_clear_bit(PCG_##lname, &pc->flags);  }
>  
> +/* Page/File stat flag mask */
> +#define PCG_PageStatMask	((1 << PCG_FILE_MAPPED))
> +
> +
>  TESTPCGFLAG(Locked, LOCK)
>  
>  /* Cache flag is set only once (at allocation) */
> @@ -73,6 +79,10 @@ CLEARPCGFLAG(AcctLRU, ACCT_LRU)
>  TESTPCGFLAG(AcctLRU, ACCT_LRU)
>  TESTCLEARPCGFLAG(AcctLRU, ACCT_LRU)
>  
> +TESTPCGFLAG(FileMapped, FILE_MAPPED)
> +SETPCGFLAG(FileMapped, FILE_MAPPED)
> +CLEARPCGFLAG(FileMapped, FILE_MAPPED)
> +
>  static inline int page_cgroup_nid(struct page_cgroup *pc)
>  {
>  	return page_to_nid(pc->page);
> @@ -93,6 +103,11 @@ static inline void unlock_page_cgroup(struct page_cgroup *pc)
>  	bit_spin_unlock(PCG_LOCK, &pc->flags);
>  }
>  
> +static inline int trylock_page_cgroup(struct page_cgroup *pc)
> +{
> +	return bit_spin_trylock(PCG_LOCK, &pc->flags);
> +}
> +
>  #else /* CONFIG_CGROUP_MEM_RES_CTLR */
>  struct page_cgroup;
>  
> diff --git a/mm/memcontrol.c b/mm/memcontrol.c
> index 7fab84e..b7c23ea 100644
> --- a/mm/memcontrol.c
> +++ b/mm/memcontrol.c
> @@ -1348,30 +1348,83 @@ bool mem_cgroup_handle_oom(struct mem_cgroup *mem, gfp_t mask)
>   * Currently used to update mapped file statistics, but the routine can be
>   * generalized to update other statistics as well.
>   */
> -void mem_cgroup_update_file_mapped(struct page *page, int val)
> +void __mem_cgroup_update_stat(struct page_cgroup *pc, int idx, bool charge)
>  {
>  	struct mem_cgroup *mem;
> -	struct page_cgroup *pc;
> +	int val;
>  
> -	pc = lookup_page_cgroup(page);
> -	if (unlikely(!pc))
> -		return;
> -
> -	lock_page_cgroup(pc);
>  	mem = pc->mem_cgroup;
> -	if (!mem)
> -		goto done;
> +	if (!mem || !PageCgroupUsed(pc))
> +		return;
>  
> -	if (!PageCgroupUsed(pc))
> -		goto done;
> +	if (charge)
> +		val = 1;
> +	else
> +		val = -1;
>  
> +	switch (idx) {
> +	case MEMCG_NR_FILE_MAPPED:
> +		if (charge) {
> +			if (!PageCgroupFileMapped(pc))
> +				SetPageCgroupFileMapped(pc);
> +			else
> +				val = 0;
> +		} else {
> +			if (PageCgroupFileMapped(pc))
> +				ClearPageCgroupFileMapped(pc);
> +			else
> +				val = 0;
> +		}
> +		idx = MEM_CGROUP_STAT_FILE_MAPPED;
> +		break;
> +	default:
> +		BUG();
> +		break;
> +	}
>  	/*
>  	 * Preemption is already disabled. We can use __this_cpu_xxx
>  	 */
> -	__this_cpu_add(mem->stat->count[MEM_CGROUP_STAT_FILE_MAPPED], val);
> +	__this_cpu_add(mem->stat->count[idx], val);
> +}
>  
> -done:
> -	unlock_page_cgroup(pc);
> +void mem_cgroup_update_stat(struct page *page, int idx, bool charge)
> +{
> +	struct page_cgroup *pc;
> +
> +	pc = lookup_page_cgroup(page);
> +	if (!pc || mem_cgroup_is_root(pc->mem_cgroup))
> +		return;
> +
> +	if (trylock_page_cgroup(pc)) {
> +		__mem_cgroup_update_stat(pc, idx, charge);
> +		unlock_page_cgroup(pc);
> +	}
> +	return;
> +}
> +
> +static void mem_cgroup_migrate_stat(struct page_cgroup *pc,
> +	struct mem_cgroup *from, struct mem_cgroup *to)
> +{
> +	if (PageCgroupFileMapped(pc)) {
> +		__this_cpu_dec(from->stat->count[MEM_CGROUP_STAT_FILE_MAPPED]);
> +		if (!mem_cgroup_is_root(to)) {
> +			__this_cpu_inc(to->stat->count[MEM_CGROUP_STAT_FILE_MAPPED]);
> +		} else {
> +			ClearPageCgroupFileMapped(pc);
> +		}
> +	}
> +}
> +
> +static void
> +__mem_cgroup_stat_fixup(struct page_cgroup *pc, struct mem_cgroup *mem)
> +{
> +	if (mem_cgroup_is_root(mem))
> +		return;
> +	/* We'are in uncharge() and lock_page_cgroup */
> +	if (PageCgroupFileMapped(pc)) {
> +		__this_cpu_dec(mem->stat->count[MEM_CGROUP_STAT_FILE_MAPPED]);
> +		ClearPageCgroupFileMapped(pc);
> +	}
>  }
>  
>  /*
> @@ -1810,13 +1863,7 @@ static void __mem_cgroup_move_account(struct page_cgroup *pc,
>  	VM_BUG_ON(pc->mem_cgroup != from);
>  
>  	page = pc->page;
> -	if (page_mapped(page) && !PageAnon(page)) {
> -		/* Update mapped_file data for mem_cgroup */
> -		preempt_disable();
> -		__this_cpu_dec(from->stat->count[MEM_CGROUP_STAT_FILE_MAPPED]);
> -		__this_cpu_inc(to->stat->count[MEM_CGROUP_STAT_FILE_MAPPED]);
> -		preempt_enable();
> -	}
> +	mem_cgroup_migrate_stat(pc, from, to);
>  	mem_cgroup_charge_statistics(from, pc, false);
>  	if (uncharge)
>  		/* This is not "cancel", but cancel_charge does all we need. */
> @@ -2208,6 +2255,9 @@ __mem_cgroup_uncharge_common(struct page *page, enum charge_type ctype)
>  		__do_uncharge(mem, ctype);
>  	if (ctype == MEM_CGROUP_CHARGE_TYPE_SWAPOUT)
>  		mem_cgroup_swap_statistics(mem, true);
> +	if (unlikely(PCG_PageStatMask & pc->flags))
> +		__mem_cgroup_stat_fixup(pc, mem);
> +
>  	mem_cgroup_charge_statistics(mem, pc, false);
>  
>  	ClearPageCgroupUsed(pc);
> diff --git a/mm/rmap.c b/mm/rmap.c
> index fcd593c..b5b2daf 100644
> --- a/mm/rmap.c
> +++ b/mm/rmap.c
> @@ -829,7 +829,7 @@ void page_add_file_rmap(struct page *page)
>  {
>  	if (atomic_inc_and_test(&page->_mapcount)) {
>  		__inc_zone_page_state(page, NR_FILE_MAPPED);
> -		mem_cgroup_update_file_mapped(page, 1);
> +		mem_cgroup_update_stat(page, MEMCG_NR_FILE_MAPPED, true);
>  	}
>  }
>  
> @@ -861,7 +861,7 @@ void page_remove_rmap(struct page *page)
>  		__dec_zone_page_state(page, NR_ANON_PAGES);
>  	} else {
>  		__dec_zone_page_state(page, NR_FILE_MAPPED);
> -		mem_cgroup_update_file_mapped(page, -1);
> +		mem_cgroup_update_stat(page, MEMCG_NR_FILE_MAPPED, false);
>  	}
>  	/*
>  	 * It would be tidy to reset the PageAnon mapping here,
> -- 
> 1.6.3.3
> 
> 

  parent reply	other threads:[~2010-03-15  0:06 UTC|newest]

Thread overview: 206+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2010-03-14 23:26 [PATCH -mmotm 0/5] memcg: per cgroup dirty limit (v7) Andrea Righi
2010-03-14 23:26 ` Andrea Righi
2010-03-14 23:26 ` [PATCH -mmotm 1/5] memcg: disable irq at page cgroup lock Andrea Righi
2010-03-14 23:26   ` Andrea Righi
2010-03-15  0:06   ` KAMEZAWA Hiroyuki
2010-03-15  0:06     ` KAMEZAWA Hiroyuki
2010-03-15 10:00     ` Andrea Righi
2010-03-15 10:00       ` Andrea Righi
     [not found]     ` <20100315090638.ee416d93.kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
2010-03-15 10:00       ` Andrea Righi
     [not found]   ` <1268609202-15581-2-git-send-email-arighi-vWjgImWzx8FBDgjK7y7TUQ@public.gmane.org>
2010-03-15  0:06     ` KAMEZAWA Hiroyuki [this message]
2010-03-17  7:04     ` Balbir Singh
2010-03-17 11:58     ` Balbir Singh
2010-03-17  7:04   ` Balbir Singh
2010-03-17  7:04     ` Balbir Singh
2010-03-17 11:58   ` Balbir Singh
2010-03-17 11:58     ` Balbir Singh
     [not found]     ` <20100317115855.GS18054-SINUvgVNF2CyUtPGxGje5AC/G2K4zDHf@public.gmane.org>
2010-03-17 23:54       ` KAMEZAWA Hiroyuki
2010-03-17 23:54     ` KAMEZAWA Hiroyuki
2010-03-17 23:54       ` KAMEZAWA Hiroyuki
     [not found]       ` <20100318085411.834e1e46.kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
2010-03-18  0:45         ` KAMEZAWA Hiroyuki
2010-03-18  4:19         ` Balbir Singh
2010-03-18  0:45       ` KAMEZAWA Hiroyuki
2010-03-18  0:45         ` KAMEZAWA Hiroyuki
     [not found]         ` <20100318094519.cd1eed72.kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
2010-03-18  2:16           ` Daisuke Nishimura
2010-03-18  2:16         ` Daisuke Nishimura
2010-03-18  2:16           ` Daisuke Nishimura
2010-03-18  2:58           ` KAMEZAWA Hiroyuki
2010-03-18  2:58             ` KAMEZAWA Hiroyuki
     [not found]           ` <20100318111653.92f899e6.nishimura-YQH0OdQVrdy45+QrQBaojngSJqDPrsil@public.gmane.org>
2010-03-18  2:58             ` KAMEZAWA Hiroyuki
2010-03-18  5:12             ` Balbir Singh
2010-03-18  5:12           ` Balbir Singh
2010-03-18  5:12             ` Balbir Singh
2010-03-18  4:19       ` Balbir Singh
2010-03-18  4:19         ` Balbir Singh
2010-03-18  4:21         ` KAMEZAWA Hiroyuki
2010-03-18  4:21           ` KAMEZAWA Hiroyuki
2010-03-18  6:25           ` Balbir Singh
2010-03-18  6:25             ` Balbir Singh
     [not found]           ` <20100318132114.d5680e1e.kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
2010-03-18  6:25             ` Balbir Singh
2010-03-18  4:35         ` KAMEZAWA Hiroyuki
2010-03-18  4:35           ` KAMEZAWA Hiroyuki
2010-03-18 16:28           ` Balbir Singh
2010-03-18 16:28             ` Balbir Singh
     [not found]             ` <20100318162855.GG18054-SINUvgVNF2CyUtPGxGje5AC/G2K4zDHf@public.gmane.org>
2010-03-19  1:23               ` KAMEZAWA Hiroyuki
2010-03-19  1:23             ` KAMEZAWA Hiroyuki
2010-03-19  1:23               ` KAMEZAWA Hiroyuki
2010-03-19  2:40               ` Balbir Singh
2010-03-19  2:40                 ` Balbir Singh
     [not found]                 ` <20100319024039.GH18054-SINUvgVNF2CyUtPGxGje5AC/G2K4zDHf@public.gmane.org>
2010-03-19  3:00                   ` KAMEZAWA Hiroyuki
2010-03-19  3:00                 ` KAMEZAWA Hiroyuki
2010-03-19  3:00                   ` KAMEZAWA Hiroyuki
     [not found]                   ` <xr93hbnepmj6.fsf@ninji.mtv.corp.google.com>
2010-04-14  6:55                     ` Greg Thelen
2010-04-14  6:55                       ` Greg Thelen
2010-04-14  9:29                       ` KAMEZAWA Hiroyuki
2010-04-14  9:29                         ` KAMEZAWA Hiroyuki
2010-04-14 14:04                         ` Vivek Goyal
2010-04-14 14:04                           ` Vivek Goyal
     [not found]                           ` <20100414140430.GB13535-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-04-14 19:31                             ` Greg Thelen
2010-04-15  0:14                             ` KAMEZAWA Hiroyuki
2010-04-14 19:31                           ` Greg Thelen
2010-04-14 19:31                             ` Greg Thelen
2010-04-15  0:14                           ` KAMEZAWA Hiroyuki
2010-04-15  0:14                             ` KAMEZAWA Hiroyuki
     [not found]                         ` <20100414182904.2f72a63d.kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
2010-04-14 14:04                           ` Vivek Goyal
2010-04-14 16:22                           ` Greg Thelen
2010-04-14 16:22                         ` Greg Thelen
2010-04-14 16:22                           ` Greg Thelen
2010-04-15  0:22                           ` KAMEZAWA Hiroyuki
2010-04-15  0:22                             ` KAMEZAWA Hiroyuki
     [not found]                           ` <p2k49b004811004140922v8b6c4c57j2dd435261ff2dd43-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2010-04-15  0:22                             ` KAMEZAWA Hiroyuki
2010-04-14 14:05                       ` Vivek Goyal
2010-04-14 14:05                         ` Vivek Goyal
2010-04-14 20:14                         ` Greg Thelen
2010-04-14 20:14                           ` Greg Thelen
     [not found]                           ` <xr9339yxyepc.fsf-Pk7ff2FLCuk9fRMx9H/SexPsWskHk0ljAL8bYrjMMd8@public.gmane.org>
2010-04-15  2:40                             ` Daisuke Nishimura
2010-04-15  2:40                           ` Daisuke Nishimura
2010-04-15  2:40                             ` Daisuke Nishimura
2010-04-15  4:48                             ` Greg Thelen
2010-04-15  4:48                               ` Greg Thelen
2010-04-15  6:21                               ` Daisuke Nishimura
2010-04-15  6:21                                 ` Daisuke Nishimura
2010-04-15  6:38                                 ` Greg Thelen
2010-04-15  6:38                                   ` Greg Thelen
     [not found]                                 ` <20100415152104.62593f37.nishimura-YQH0OdQVrdy45+QrQBaojngSJqDPrsil@public.gmane.org>
2010-04-15  6:38                                   ` Greg Thelen
2010-04-15  6:54                                   ` KAMEZAWA Hiroyuki
2010-04-15  6:54                                 ` KAMEZAWA Hiroyuki
2010-04-15  6:54                                   ` KAMEZAWA Hiroyuki
2010-04-23 20:17                                   ` Greg Thelen
2010-04-23 20:17                                     ` Greg Thelen
2010-04-23 20:54                                     ` Peter Zijlstra
2010-04-23 20:54                                       ` Peter Zijlstra
2010-04-24 15:53                                       ` Greg Thelen
2010-04-24 15:53                                         ` Greg Thelen
2010-04-24 15:53                                       ` Greg Thelen
     [not found]                                     ` <xr93k4rxx6sd.fsf-Pk7ff2FLCuk9fRMx9H/SexPsWskHk0ljAL8bYrjMMd8@public.gmane.org>
2010-04-23 20:54                                       ` Peter Zijlstra
2010-04-23 20:57                                       ` Peter Zijlstra
2010-04-23 21:19                                       ` Peter Zijlstra
2010-04-24  2:19                                       ` KAMEZAWA Hiroyuki
2010-04-23 20:57                                     ` Peter Zijlstra
2010-04-23 20:57                                       ` Peter Zijlstra
2010-04-24  2:22                                       ` KAMEZAWA Hiroyuki
2010-04-24  2:22                                         ` KAMEZAWA Hiroyuki
2010-04-24  2:22                                       ` KAMEZAWA Hiroyuki
2010-04-23 21:19                                     ` Peter Zijlstra
2010-04-23 21:19                                       ` Peter Zijlstra
2010-04-24  2:19                                     ` KAMEZAWA Hiroyuki
2010-04-24  2:19                                       ` KAMEZAWA Hiroyuki
2010-04-23 20:17                                   ` Greg Thelen
     [not found]                               ` <g2u49b004811004142148i3db9fefaje1f20760426e0c7e-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2010-04-15  6:21                                 ` Daisuke Nishimura
     [not found]                             ` <20100415114022.ef01b704.nishimura-YQH0OdQVrdy45+QrQBaojngSJqDPrsil@public.gmane.org>
2010-04-15  4:48                               ` Greg Thelen
     [not found]                         ` <20100414140523.GC13535-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-04-14 20:14                           ` Greg Thelen
2010-04-14 14:44                       ` Balbir Singh
2010-04-14 14:44                         ` Balbir Singh
     [not found]                       ` <xr931veiplpr.fsf-Pk7ff2FLCuk9fRMx9H/SexPsWskHk0ljAL8bYrjMMd8@public.gmane.org>
2010-04-14  9:29                         ` KAMEZAWA Hiroyuki
2010-04-14 14:05                         ` Vivek Goyal
2010-04-14 14:44                         ` Balbir Singh
     [not found]                   ` <xr93hbnepmj6.fsf-Pk7ff2FLCuk9fRMx9H/SexPsWskHk0ljAL8bYrjMMd8@public.gmane.org>
2010-04-14  6:55                     ` Greg Thelen
     [not found]               ` <20100319102332.f1d81c8d.kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
2010-03-19  2:40                 ` Balbir Singh
     [not found]           ` <20100318133527.420b2f25.kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
2010-03-18 16:28             ` Balbir Singh
     [not found]         ` <20100318041944.GA18054-SINUvgVNF2CyUtPGxGje5AC/G2K4zDHf@public.gmane.org>
2010-03-18  4:21           ` KAMEZAWA Hiroyuki
2010-03-18  4:35           ` KAMEZAWA Hiroyuki
2010-03-14 23:26 ` [PATCH -mmotm 2/5] memcg: dirty memory documentation Andrea Righi
2010-03-14 23:26   ` Andrea Righi
     [not found]   ` <1268609202-15581-3-git-send-email-arighi-vWjgImWzx8FBDgjK7y7TUQ@public.gmane.org>
2010-03-16  7:41     ` Daisuke Nishimura
2010-03-16  7:41   ` Daisuke Nishimura
2010-03-16  7:41     ` Daisuke Nishimura
     [not found]     ` <20100316164121.024e35d8.nishimura-YQH0OdQVrdy45+QrQBaojngSJqDPrsil@public.gmane.org>
2010-03-17 17:48       ` Greg Thelen
2010-03-17 22:43       ` Andrea Righi
2010-03-17 17:48     ` Greg Thelen
2010-03-17 17:48       ` Greg Thelen
     [not found]       ` <49b004811003171048h5f27405oe6ea39a103bc4ee3-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2010-03-17 19:02         ` Balbir Singh
2010-03-17 19:02       ` Balbir Singh
2010-03-17 19:02         ` Balbir Singh
2010-03-17 22:43     ` Andrea Righi
2010-03-17 22:43       ` Andrea Righi
2010-03-14 23:26 ` [PATCH -mmotm 3/5] page_cgroup: introduce file cache flags Andrea Righi
2010-03-14 23:26   ` Andrea Righi
2010-03-14 23:26 ` [PATCH -mmotm 4/5] memcg: dirty pages accounting and limiting infrastructure Andrea Righi
2010-03-14 23:26   ` Andrea Righi
2010-03-15  2:26   ` KAMEZAWA Hiroyuki
2010-03-15  2:26     ` KAMEZAWA Hiroyuki
     [not found]   ` <1268609202-15581-5-git-send-email-arighi-vWjgImWzx8FBDgjK7y7TUQ@public.gmane.org>
2010-03-15  2:26     ` KAMEZAWA Hiroyuki
2010-03-16  2:32     ` Daisuke Nishimura
2010-03-18  6:48     ` Greg Thelen
2010-03-16  2:32   ` Daisuke Nishimura
2010-03-16  2:32     ` Daisuke Nishimura
2010-03-16 14:11     ` Vivek Goyal
2010-03-16 14:11       ` Vivek Goyal
2010-03-16 15:09       ` Daisuke Nishimura
2010-03-16 15:09         ` Daisuke Nishimura
     [not found]       ` <20100316141150.GC9144-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-03-16 15:09         ` Daisuke Nishimura
2010-03-17 22:37         ` Andrea Righi
2010-03-17 22:37       ` Andrea Righi
2010-03-17 22:37         ` Andrea Righi
     [not found]     ` <20100316113238.f7d74848.nishimura-YQH0OdQVrdy45+QrQBaojngSJqDPrsil@public.gmane.org>
2010-03-16 14:11       ` Vivek Goyal
2010-03-17 22:52       ` Andrea Righi
2010-03-17 22:52     ` Andrea Righi
2010-03-17 22:52       ` Andrea Righi
2010-03-18  6:48   ` Greg Thelen
2010-03-18  6:48     ` Greg Thelen
2010-03-14 23:26 ` [PATCH -mmotm 5/5] memcg: dirty pages instrumentation Andrea Righi
2010-03-14 23:26   ` Andrea Righi
     [not found]   ` <1268609202-15581-6-git-send-email-arighi-vWjgImWzx8FBDgjK7y7TUQ@public.gmane.org>
2010-03-15  2:31     ` KAMEZAWA Hiroyuki
2010-03-15  2:31   ` KAMEZAWA Hiroyuki
2010-03-15  2:31     ` KAMEZAWA Hiroyuki
2010-03-15  2:36 ` [PATCH -mmotm 0/5] memcg: per cgroup dirty limit (v7) KAMEZAWA Hiroyuki
2010-03-15  2:36   ` KAMEZAWA Hiroyuki
2010-03-15 10:02   ` Andrea Righi
2010-03-15 10:02     ` Andrea Righi
     [not found]   ` <20100315113612.8411d92d.kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
2010-03-15 10:02     ` Andrea Righi
     [not found] ` <1268609202-15581-1-git-send-email-arighi-vWjgImWzx8FBDgjK7y7TUQ@public.gmane.org>
2010-03-14 23:26   ` [PATCH -mmotm 1/5] memcg: disable irq at page cgroup lock Andrea Righi
2010-03-14 23:26   ` [PATCH -mmotm 2/5] memcg: dirty memory documentation Andrea Righi
2010-03-14 23:26   ` [PATCH -mmotm 3/5] page_cgroup: introduce file cache flags Andrea Righi
2010-03-14 23:26   ` [PATCH -mmotm 4/5] memcg: dirty pages accounting and limiting infrastructure Andrea Righi
2010-03-14 23:26   ` [PATCH -mmotm 5/5] memcg: dirty pages instrumentation Andrea Righi
2010-03-15  2:36   ` [PATCH -mmotm 0/5] memcg: per cgroup dirty limit (v7) KAMEZAWA Hiroyuki
2010-03-15 17:12   ` Vivek Goyal
2010-03-17  6:44   ` Balbir Singh
2010-03-15 17:12 ` Vivek Goyal
2010-03-15 17:12   ` Vivek Goyal
     [not found]   ` <20100315171209.GI21127-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-03-15 17:19     ` Vivek Goyal
2010-03-15 17:19   ` Vivek Goyal
2010-03-15 17:19     ` Vivek Goyal
2010-03-17 11:54     ` Balbir Singh
2010-03-17 11:54       ` Balbir Singh
2010-03-17 13:34       ` Vivek Goyal
2010-03-17 13:34         ` Vivek Goyal
2010-03-17 18:53         ` Balbir Singh
2010-03-17 18:53           ` Balbir Singh
2010-03-17 19:15           ` Vivek Goyal
2010-03-17 19:15             ` Vivek Goyal
     [not found]           ` <20100317185327.GV18054-SINUvgVNF2CyUtPGxGje5AC/G2K4zDHf@public.gmane.org>
2010-03-17 19:15             ` Vivek Goyal
2010-03-17 19:17         ` Balbir Singh
2010-03-17 19:17           ` Balbir Singh
     [not found]           ` <20100317191743.GY18054-SINUvgVNF2CyUtPGxGje5AC/G2K4zDHf@public.gmane.org>
2010-03-17 19:48             ` Vivek Goyal
2010-03-17 19:48           ` Vivek Goyal
2010-03-17 19:48             ` Vivek Goyal
     [not found]         ` <20100317133407.GA9198-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-03-17 18:53           ` Balbir Singh
2010-03-17 19:17           ` Balbir Singh
     [not found]       ` <20100317115427.GR18054-SINUvgVNF2CyUtPGxGje5AC/G2K4zDHf@public.gmane.org>
2010-03-17 13:34         ` Vivek Goyal
     [not found]     ` <20100315171921.GJ21127-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
2010-03-17 11:54       ` Balbir Singh
2010-03-17  6:44 ` Balbir Singh
2010-03-17  6:44   ` Balbir Singh
  -- strict thread matches above, loose matches on Subject: below --
2010-03-09 23:00 [PATCH -mmotm 0/5] memcg: per cgroup dirty limit (v6) Andrea Righi
     [not found] ` <1268175636-4673-1-git-send-email-arighi-vWjgImWzx8FBDgjK7y7TUQ@public.gmane.org>
2010-03-09 23:00   ` [PATCH -mmotm 1/5] memcg: disable irq at page cgroup lock Andrea Righi
2010-03-09 23:00 ` Andrea Righi
2010-03-09 23:00   ` Andrea Righi

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='20100315090638.ee416d93.kamezawa.hiroyu__22737.6810777516$1268611873$gmane$org@jp.fujitsu.com' \
    --to=kamezawa.hiroyu-+cum20s59erqfuhtdcdx3a@public.gmane.org \
    --cc=Greg-FOgKQjlUJ6BQetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org \
    --cc=Peter-FOgKQjlUJ6BQetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org \
    --cc=akpm-de/tnXTf+JLsfHDXvbKv3WD2FQJk+8+b@public.gmane.org \
    --cc=arighi-vWjgImWzx8FBDgjK7y7TUQ@public.gmane.org \
    --cc=balbir-23VcF4HTsmIX0ybBhKVfKdBPR1lH4CV8@public.gmane.org \
    --cc=containers-cunTk1MwBs9QetFLy7KEm3xJsTq8ys+cHZ5vskTnxNA@public.gmane.org \
    --cc=linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org \
    --cc=linux-mm-Bw31MaZKKs3YtjvyW6yDsg@public.gmane.org \
    --cc=nishimura-YQH0OdQVrdy45+QrQBaojngSJqDPrsil@public.gmane.org \
    --cc=suleiman-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org \
    --cc=trond.myklebust-41N18TsMXrtuMpJDpNschA@public.gmane.org \
    --cc=vgoyal-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org \
    /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.