From mboxrd@z Thu Jan 1 00:00:00 1970 Date: Wed, 14 Nov 2007 17:48:28 +0900 From: KAMEZAWA Hiroyuki Subject: [RFC][ for -mm] memory controller enhancements for NUMA [5/10] calc active/inactive impabance Message-Id: <20071114174828.e342ec2a.kamezawa.hiroyu@jp.fujitsu.com> In-Reply-To: <20071114173950.92857eaa.kamezawa.hiroyu@jp.fujitsu.com> References: <20071114173950.92857eaa.kamezawa.hiroyu@jp.fujitsu.com> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: owner-linux-mm@kvack.org Return-Path: To: KAMEZAWA Hiroyuki Cc: "linux-mm@kvack.org" , "containers@lists.osdl.org" , "balbir@linux.vnet.ibm.com" , "yamamoto@valinux.co.jp" , hugh@veritas.com List-ID: Define function for determining active/inactive balance in memory cgroup. This imbalance value is calculated against the whole zone.. maybe should be per-zone...? Signed-off-by: KAMEZAWA Hiroyuki include/linux/memcontrol.h | 8 ++++++++ mm/memcontrol.c | 16 ++++++++++++++++ 2 files changed, 24 insertions(+) Index: linux-2.6.24-rc2-mm1/mm/memcontrol.c =================================================================== --- linux-2.6.24-rc2-mm1.orig/mm/memcontrol.c +++ linux-2.6.24-rc2-mm1/mm/memcontrol.c @@ -412,6 +412,22 @@ int mem_cgroup_calc_mapped_ratio(struct rss = mem_cgroup_read_stat(&mem->stat, MEM_CGROUP_STAT_RSS); return (rss * 100) / total; } +/* + * Uses mem_cgroup's imbalance instead of zone's lru imbalance. + * This will be used for detemining whether page out routine try to free + * mapped pages or not. + */ +int mem_cgroup_reclaim_imbalance(struct mem_cgroup *mem) +{ + s64 total, active, inactive; + + /* usage is recoreded in bytes */ + total = mem->res.usage >> PAGE_SHIFT; + inactive = mem_cgroup_get_all_zonestat(mem, MEM_CGROUP_ZSTAT_INACTIVE); + active = total - inactive; + + return active / (inactive + 1); +} unsigned long mem_cgroup_isolate_pages(unsigned long nr_to_scan, struct list_head *dst, Index: linux-2.6.24-rc2-mm1/include/linux/memcontrol.h =================================================================== --- linux-2.6.24-rc2-mm1.orig/include/linux/memcontrol.h +++ linux-2.6.24-rc2-mm1/include/linux/memcontrol.h @@ -65,6 +65,8 @@ extern void mem_cgroup_page_migration(st * For memory reclaim. */ extern int mem_cgroup_calc_mapped_ratio(struct mem_cgroup *mem); +extern int mem_cgroup_reclaim_imbalance(struct mem_cgroup *mem); + #else /* CONFIG_CGROUP_MEM_CONT */ @@ -142,6 +144,12 @@ static inline int mem_cgroup_calc_mapped { return 0; } + +static inline int mem_cgroup_reclaim_imbalance(struct mem_cgroup *mem) +{ + return 0; +} + #endif /* CONFIG_CGROUP_MEM_CONT */ #endif /* _LINUX_MEMCONTROL_H */ -- 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: email@kvack.org