All of lore.kernel.org
 help / color / mirror / Atom feed
From: Glauber Costa <glommer@parallels.com>
To: <linux-kernel@vger.kernel.org>
Cc: <cgroups@vger.kernel.org>, <kamezawa.hiroyu@jp.fujitsu.com>,
	<devel@openvz.org>, Tejun Heo <tj@kernel.org>,
	<linux-mm@kvack.org>, Suleiman Souhlal <suleiman@google.com>,
	Frederic Weisbecker <fweisbec@gmail.com>,
	Mel Gorman <mgorman@suse.de>,
	David Rientjes <rientjes@google.com>,
	Glauber Costa <glommer@parallels.com>,
	Michal Hocko <mhocko@suse.cz>,
	Johannes Weiner <hannes@cmpxchg.org>
Subject: [PATCH v3 08/13] res_counter: return amount of charges after res_counter_uncharge
Date: Tue, 18 Sep 2012 18:04:05 +0400	[thread overview]
Message-ID: <1347977050-29476-9-git-send-email-glommer@parallels.com> (raw)
In-Reply-To: <1347977050-29476-1-git-send-email-glommer@parallels.com>

It is useful to know how many charges are still left after a call to
res_counter_uncharge. While it is possible to issue a res_counter_read
after uncharge, this is racy. It would be better if uncharge itself
would tell us what the current status is.

Since the current return value is void, we don't need to worry about
anything breaking due to this change: nobody relied on that, and only
users appearing from now on will be checking this value.

Signed-off-by: Glauber Costa <glommer@parallels.com>
CC: Michal Hocko <mhocko@suse.cz>
CC: Johannes Weiner <hannes@cmpxchg.org>
CC: Suleiman Souhlal <suleiman@google.com>
CC: Kamezawa Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
---
 Documentation/cgroups/resource_counter.txt |  7 ++++---
 include/linux/res_counter.h                | 12 +++++++-----
 kernel/res_counter.c                       | 20 +++++++++++++-------
 3 files changed, 24 insertions(+), 15 deletions(-)

diff --git a/Documentation/cgroups/resource_counter.txt b/Documentation/cgroups/resource_counter.txt
index 0c4a344..c4d99ed 100644
--- a/Documentation/cgroups/resource_counter.txt
+++ b/Documentation/cgroups/resource_counter.txt
@@ -83,16 +83,17 @@ to work with it.
 	res_counter->lock internally (it must be called with res_counter->lock
 	held). The force parameter indicates whether we can bypass the limit.
 
- e. void res_counter_uncharge[_locked]
+ e. u64 res_counter_uncharge[_locked]
 			(struct res_counter *rc, unsigned long val)
 
 	When a resource is released (freed) it should be de-accounted
 	from the resource counter it was accounted to.  This is called
-	"uncharging".
+	"uncharging". The return value of this function indicate the amount
+	of charges still present in the counter.
 
 	The _locked routines imply that the res_counter->lock is taken.
 
- f. void res_counter_uncharge_until
+ f. u64 res_counter_uncharge_until
 		(struct res_counter *rc, struct res_counter *top,
 		 unsinged long val)
 
diff --git a/include/linux/res_counter.h b/include/linux/res_counter.h
index 7d7fbe2..4b173b6 100644
--- a/include/linux/res_counter.h
+++ b/include/linux/res_counter.h
@@ -130,14 +130,16 @@ int res_counter_charge_nofail(struct res_counter *counter,
  *
  * these calls check for usage underflow and show a warning on the console
  * _locked call expects the counter->lock to be taken
+ *
+ * returns the total charges still present in @counter.
  */
 
-void res_counter_uncharge_locked(struct res_counter *counter, unsigned long val);
-void res_counter_uncharge(struct res_counter *counter, unsigned long val);
+u64 res_counter_uncharge_locked(struct res_counter *counter, unsigned long val);
+u64 res_counter_uncharge(struct res_counter *counter, unsigned long val);
 
-void res_counter_uncharge_until(struct res_counter *counter,
-				struct res_counter *top,
-				unsigned long val);
+u64 res_counter_uncharge_until(struct res_counter *counter,
+			       struct res_counter *top,
+			       unsigned long val);
 /**
  * res_counter_margin - calculate chargeable space of a counter
  * @cnt: the counter
diff --git a/kernel/res_counter.c b/kernel/res_counter.c
index ad581aa..7b3d6dc 100644
--- a/kernel/res_counter.c
+++ b/kernel/res_counter.c
@@ -86,33 +86,39 @@ int res_counter_charge_nofail(struct res_counter *counter, unsigned long val,
 	return __res_counter_charge(counter, val, limit_fail_at, true);
 }
 
-void res_counter_uncharge_locked(struct res_counter *counter, unsigned long val)
+u64 res_counter_uncharge_locked(struct res_counter *counter, unsigned long val)
 {
 	if (WARN_ON(counter->usage < val))
 		val = counter->usage;
 
 	counter->usage -= val;
+	return counter->usage;
 }
 
-void res_counter_uncharge_until(struct res_counter *counter,
-				struct res_counter *top,
-				unsigned long val)
+u64 res_counter_uncharge_until(struct res_counter *counter,
+			       struct res_counter *top,
+			       unsigned long val)
 {
 	unsigned long flags;
 	struct res_counter *c;
+	u64 ret = 0;
 
 	local_irq_save(flags);
 	for (c = counter; c != top; c = c->parent) {
+		u64 r;
 		spin_lock(&c->lock);
-		res_counter_uncharge_locked(c, val);
+		r = res_counter_uncharge_locked(c, val);
+		if (c == counter)
+			ret = r;
 		spin_unlock(&c->lock);
 	}
 	local_irq_restore(flags);
+	return ret;
 }
 
-void res_counter_uncharge(struct res_counter *counter, unsigned long val)
+u64 res_counter_uncharge(struct res_counter *counter, unsigned long val)
 {
-	res_counter_uncharge_until(counter, NULL, val);
+	return res_counter_uncharge_until(counter, NULL, val);
 }
 
 static inline unsigned long long *
-- 
1.7.11.4


WARNING: multiple messages have this Message-ID (diff)
From: Glauber Costa <glommer@parallels.com>
To: linux-kernel@vger.kernel.org
Cc: cgroups@vger.kernel.org, kamezawa.hiroyu@jp.fujitsu.com,
	devel@openvz.org, Tejun Heo <tj@kernel.org>,
	linux-mm@kvack.org, Suleiman Souhlal <suleiman@google.com>,
	Frederic Weisbecker <fweisbec@gmail.com>,
	Mel Gorman <mgorman@suse.de>,
	David Rientjes <rientjes@google.com>,
	Glauber Costa <glommer@parallels.com>,
	Michal Hocko <mhocko@suse.cz>,
	Johannes Weiner <hannes@cmpxchg.org>
Subject: [PATCH v3 08/13] res_counter: return amount of charges after res_counter_uncharge
Date: Tue, 18 Sep 2012 18:04:05 +0400	[thread overview]
Message-ID: <1347977050-29476-9-git-send-email-glommer@parallels.com> (raw)
In-Reply-To: <1347977050-29476-1-git-send-email-glommer@parallels.com>

It is useful to know how many charges are still left after a call to
res_counter_uncharge. While it is possible to issue a res_counter_read
after uncharge, this is racy. It would be better if uncharge itself
would tell us what the current status is.

Since the current return value is void, we don't need to worry about
anything breaking due to this change: nobody relied on that, and only
users appearing from now on will be checking this value.

Signed-off-by: Glauber Costa <glommer@parallels.com>
CC: Michal Hocko <mhocko@suse.cz>
CC: Johannes Weiner <hannes@cmpxchg.org>
CC: Suleiman Souhlal <suleiman@google.com>
CC: Kamezawa Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>
---
 Documentation/cgroups/resource_counter.txt |  7 ++++---
 include/linux/res_counter.h                | 12 +++++++-----
 kernel/res_counter.c                       | 20 +++++++++++++-------
 3 files changed, 24 insertions(+), 15 deletions(-)

diff --git a/Documentation/cgroups/resource_counter.txt b/Documentation/cgroups/resource_counter.txt
index 0c4a344..c4d99ed 100644
--- a/Documentation/cgroups/resource_counter.txt
+++ b/Documentation/cgroups/resource_counter.txt
@@ -83,16 +83,17 @@ to work with it.
 	res_counter->lock internally (it must be called with res_counter->lock
 	held). The force parameter indicates whether we can bypass the limit.
 
- e. void res_counter_uncharge[_locked]
+ e. u64 res_counter_uncharge[_locked]
 			(struct res_counter *rc, unsigned long val)
 
 	When a resource is released (freed) it should be de-accounted
 	from the resource counter it was accounted to.  This is called
-	"uncharging".
+	"uncharging". The return value of this function indicate the amount
+	of charges still present in the counter.
 
 	The _locked routines imply that the res_counter->lock is taken.
 
- f. void res_counter_uncharge_until
+ f. u64 res_counter_uncharge_until
 		(struct res_counter *rc, struct res_counter *top,
 		 unsinged long val)
 
diff --git a/include/linux/res_counter.h b/include/linux/res_counter.h
index 7d7fbe2..4b173b6 100644
--- a/include/linux/res_counter.h
+++ b/include/linux/res_counter.h
@@ -130,14 +130,16 @@ int res_counter_charge_nofail(struct res_counter *counter,
  *
  * these calls check for usage underflow and show a warning on the console
  * _locked call expects the counter->lock to be taken
+ *
+ * returns the total charges still present in @counter.
  */
 
-void res_counter_uncharge_locked(struct res_counter *counter, unsigned long val);
-void res_counter_uncharge(struct res_counter *counter, unsigned long val);
+u64 res_counter_uncharge_locked(struct res_counter *counter, unsigned long val);
+u64 res_counter_uncharge(struct res_counter *counter, unsigned long val);
 
-void res_counter_uncharge_until(struct res_counter *counter,
-				struct res_counter *top,
-				unsigned long val);
+u64 res_counter_uncharge_until(struct res_counter *counter,
+			       struct res_counter *top,
+			       unsigned long val);
 /**
  * res_counter_margin - calculate chargeable space of a counter
  * @cnt: the counter
diff --git a/kernel/res_counter.c b/kernel/res_counter.c
index ad581aa..7b3d6dc 100644
--- a/kernel/res_counter.c
+++ b/kernel/res_counter.c
@@ -86,33 +86,39 @@ int res_counter_charge_nofail(struct res_counter *counter, unsigned long val,
 	return __res_counter_charge(counter, val, limit_fail_at, true);
 }
 
-void res_counter_uncharge_locked(struct res_counter *counter, unsigned long val)
+u64 res_counter_uncharge_locked(struct res_counter *counter, unsigned long val)
 {
 	if (WARN_ON(counter->usage < val))
 		val = counter->usage;
 
 	counter->usage -= val;
+	return counter->usage;
 }
 
-void res_counter_uncharge_until(struct res_counter *counter,
-				struct res_counter *top,
-				unsigned long val)
+u64 res_counter_uncharge_until(struct res_counter *counter,
+			       struct res_counter *top,
+			       unsigned long val)
 {
 	unsigned long flags;
 	struct res_counter *c;
+	u64 ret = 0;
 
 	local_irq_save(flags);
 	for (c = counter; c != top; c = c->parent) {
+		u64 r;
 		spin_lock(&c->lock);
-		res_counter_uncharge_locked(c, val);
+		r = res_counter_uncharge_locked(c, val);
+		if (c == counter)
+			ret = r;
 		spin_unlock(&c->lock);
 	}
 	local_irq_restore(flags);
+	return ret;
 }
 
-void res_counter_uncharge(struct res_counter *counter, unsigned long val)
+u64 res_counter_uncharge(struct res_counter *counter, unsigned long val)
 {
-	res_counter_uncharge_until(counter, NULL, val);
+	return res_counter_uncharge_until(counter, NULL, val);
 }
 
 static inline unsigned long long *
-- 
1.7.11.4

--
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: Glauber Costa <glommer-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
To: linux-kernel-u79uwXL29TY76Z2rM5mHXA@public.gmane.org
Cc: cgroups-u79uwXL29TY76Z2rM5mHXA@public.gmane.org,
	kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org,
	devel-GEFAQzZX7r8dnm+yROfE0A@public.gmane.org,
	Tejun Heo <tj-DgEjT+Ai2ygdnm+yROfE0A@public.gmane.org>,
	linux-mm-Bw31MaZKKs3YtjvyW6yDsg@public.gmane.org,
	Suleiman Souhlal
	<suleiman-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>,
	Frederic Weisbecker
	<fweisbec-Re5JQEeQqe8AvxtiuMwx3w@public.gmane.org>,
	Mel Gorman <mgorman-l3A5Bk7waGM@public.gmane.org>,
	David Rientjes <rientjes-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>,
	Glauber Costa <glommer-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>,
	Michal Hocko <mhocko-AlSwsSmVLrQ@public.gmane.org>,
	Johannes Weiner <hannes-druUgvl0LCNAfugRpC6u6w@public.gmane.org>
Subject: [PATCH v3 08/13] res_counter: return amount of charges after res_counter_uncharge
Date: Tue, 18 Sep 2012 18:04:05 +0400	[thread overview]
Message-ID: <1347977050-29476-9-git-send-email-glommer@parallels.com> (raw)
In-Reply-To: <1347977050-29476-1-git-send-email-glommer-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>

It is useful to know how many charges are still left after a call to
res_counter_uncharge. While it is possible to issue a res_counter_read
after uncharge, this is racy. It would be better if uncharge itself
would tell us what the current status is.

Since the current return value is void, we don't need to worry about
anything breaking due to this change: nobody relied on that, and only
users appearing from now on will be checking this value.

Signed-off-by: Glauber Costa <glommer-bzQdu9zFT3WakBO8gow8eQ@public.gmane.org>
CC: Michal Hocko <mhocko-AlSwsSmVLrQ@public.gmane.org>
CC: Johannes Weiner <hannes-druUgvl0LCNAfugRpC6u6w@public.gmane.org>
CC: Suleiman Souhlal <suleiman-hpIqsD4AKlfQT0dZR+AlfA@public.gmane.org>
CC: Kamezawa Hiroyuki <kamezawa.hiroyu-+CUm20s59erQFUHtdCDX3A@public.gmane.org>
---
 Documentation/cgroups/resource_counter.txt |  7 ++++---
 include/linux/res_counter.h                | 12 +++++++-----
 kernel/res_counter.c                       | 20 +++++++++++++-------
 3 files changed, 24 insertions(+), 15 deletions(-)

diff --git a/Documentation/cgroups/resource_counter.txt b/Documentation/cgroups/resource_counter.txt
index 0c4a344..c4d99ed 100644
--- a/Documentation/cgroups/resource_counter.txt
+++ b/Documentation/cgroups/resource_counter.txt
@@ -83,16 +83,17 @@ to work with it.
 	res_counter->lock internally (it must be called with res_counter->lock
 	held). The force parameter indicates whether we can bypass the limit.
 
- e. void res_counter_uncharge[_locked]
+ e. u64 res_counter_uncharge[_locked]
 			(struct res_counter *rc, unsigned long val)
 
 	When a resource is released (freed) it should be de-accounted
 	from the resource counter it was accounted to.  This is called
-	"uncharging".
+	"uncharging". The return value of this function indicate the amount
+	of charges still present in the counter.
 
 	The _locked routines imply that the res_counter->lock is taken.
 
- f. void res_counter_uncharge_until
+ f. u64 res_counter_uncharge_until
 		(struct res_counter *rc, struct res_counter *top,
 		 unsinged long val)
 
diff --git a/include/linux/res_counter.h b/include/linux/res_counter.h
index 7d7fbe2..4b173b6 100644
--- a/include/linux/res_counter.h
+++ b/include/linux/res_counter.h
@@ -130,14 +130,16 @@ int res_counter_charge_nofail(struct res_counter *counter,
  *
  * these calls check for usage underflow and show a warning on the console
  * _locked call expects the counter->lock to be taken
+ *
+ * returns the total charges still present in @counter.
  */
 
-void res_counter_uncharge_locked(struct res_counter *counter, unsigned long val);
-void res_counter_uncharge(struct res_counter *counter, unsigned long val);
+u64 res_counter_uncharge_locked(struct res_counter *counter, unsigned long val);
+u64 res_counter_uncharge(struct res_counter *counter, unsigned long val);
 
-void res_counter_uncharge_until(struct res_counter *counter,
-				struct res_counter *top,
-				unsigned long val);
+u64 res_counter_uncharge_until(struct res_counter *counter,
+			       struct res_counter *top,
+			       unsigned long val);
 /**
  * res_counter_margin - calculate chargeable space of a counter
  * @cnt: the counter
diff --git a/kernel/res_counter.c b/kernel/res_counter.c
index ad581aa..7b3d6dc 100644
--- a/kernel/res_counter.c
+++ b/kernel/res_counter.c
@@ -86,33 +86,39 @@ int res_counter_charge_nofail(struct res_counter *counter, unsigned long val,
 	return __res_counter_charge(counter, val, limit_fail_at, true);
 }
 
-void res_counter_uncharge_locked(struct res_counter *counter, unsigned long val)
+u64 res_counter_uncharge_locked(struct res_counter *counter, unsigned long val)
 {
 	if (WARN_ON(counter->usage < val))
 		val = counter->usage;
 
 	counter->usage -= val;
+	return counter->usage;
 }
 
-void res_counter_uncharge_until(struct res_counter *counter,
-				struct res_counter *top,
-				unsigned long val)
+u64 res_counter_uncharge_until(struct res_counter *counter,
+			       struct res_counter *top,
+			       unsigned long val)
 {
 	unsigned long flags;
 	struct res_counter *c;
+	u64 ret = 0;
 
 	local_irq_save(flags);
 	for (c = counter; c != top; c = c->parent) {
+		u64 r;
 		spin_lock(&c->lock);
-		res_counter_uncharge_locked(c, val);
+		r = res_counter_uncharge_locked(c, val);
+		if (c == counter)
+			ret = r;
 		spin_unlock(&c->lock);
 	}
 	local_irq_restore(flags);
+	return ret;
 }
 
-void res_counter_uncharge(struct res_counter *counter, unsigned long val)
+u64 res_counter_uncharge(struct res_counter *counter, unsigned long val)
 {
-	res_counter_uncharge_until(counter, NULL, val);
+	return res_counter_uncharge_until(counter, NULL, val);
 }
 
 static inline unsigned long long *
-- 
1.7.11.4

  parent reply	other threads:[~2012-09-18 14:08 UTC|newest]

Thread overview: 323+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2012-09-18 14:03 [PATCH v3 00/13] kmem controller for memcg Glauber Costa
2012-09-18 14:03 ` Glauber Costa
2012-09-18 14:03 ` Glauber Costa
2012-09-18 14:03 ` [PATCH v3 01/13] memcg: Make it possible to use the stock for more than one page Glauber Costa
2012-09-18 14:03   ` Glauber Costa
2012-09-18 14:03   ` Glauber Costa
2012-10-01 18:48   ` Johannes Weiner
2012-10-01 18:48     ` Johannes Weiner
2012-09-18 14:03 ` [PATCH v3 02/13] memcg: Reclaim when more than one page needed Glauber Costa
2012-09-18 14:03   ` Glauber Costa
2012-09-18 14:03   ` Glauber Costa
2012-10-01 19:00   ` Johannes Weiner
2012-10-01 19:00     ` Johannes Weiner
2012-09-18 14:04 ` [PATCH v3 03/13] memcg: change defines to an enum Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-10-01 19:06   ` Johannes Weiner
2012-10-01 19:06     ` Johannes Weiner
2012-10-01 19:06     ` Johannes Weiner
2012-10-02  9:10     ` Glauber Costa
2012-10-02  9:10       ` Glauber Costa
2012-09-18 14:04 ` [PATCH v3 04/13] kmem accounting basic infrastructure Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-21 16:34   ` Tejun Heo
2012-09-21 16:34     ` Tejun Heo
2012-09-24  8:09     ` Glauber Costa
2012-09-24  8:09       ` Glauber Costa
2012-09-24  8:09       ` Glauber Costa
2012-09-26 14:03   ` Michal Hocko
2012-09-26 14:03     ` Michal Hocko
2012-09-26 14:03     ` Michal Hocko
2012-09-26 14:33     ` Glauber Costa
2012-09-26 14:33       ` Glauber Costa
2012-09-26 16:01       ` Michal Hocko
2012-09-26 16:01         ` Michal Hocko
2012-09-26 16:01         ` Michal Hocko
2012-09-26 17:34         ` Glauber Costa
2012-09-26 17:34           ` Glauber Costa
2012-09-26 16:36     ` Tejun Heo
2012-09-26 16:36       ` Tejun Heo
2012-09-26 16:36       ` Tejun Heo
2012-09-26 17:36       ` Glauber Costa
2012-09-26 17:36         ` Glauber Costa
2012-09-26 17:44         ` Tejun Heo
2012-09-26 17:44           ` Tejun Heo
2012-09-26 17:44           ` Tejun Heo
2012-09-26 17:53           ` Glauber Costa
2012-09-26 17:53             ` Glauber Costa
2012-09-26 18:01             ` Tejun Heo
2012-09-26 18:01               ` Tejun Heo
2012-09-26 18:56               ` Glauber Costa
2012-09-26 18:56                 ` Glauber Costa
2012-09-26 18:56                 ` Glauber Costa
2012-09-26 19:34                 ` Tejun Heo
2012-09-26 19:34                   ` Tejun Heo
2012-09-26 19:34                   ` Tejun Heo
2012-09-26 19:46                   ` Glauber Costa
2012-09-26 19:46                     ` Glauber Costa
2012-09-26 19:56                     ` Tejun Heo
2012-09-26 19:56                       ` Tejun Heo
2012-09-26 19:56                       ` Tejun Heo
2012-09-26 20:02                       ` Glauber Costa
2012-09-26 20:02                         ` Glauber Costa
2012-09-26 20:16                         ` Tejun Heo
2012-09-26 20:16                           ` Tejun Heo
2012-09-26 20:16                           ` Tejun Heo
2012-09-26 21:24                           ` Glauber Costa
2012-09-26 21:24                             ` Glauber Costa
2012-09-26 22:10                             ` Tejun Heo
2012-09-26 22:10                               ` Tejun Heo
2012-09-26 22:10                               ` Tejun Heo
2012-09-26 22:29                               ` Glauber Costa
2012-09-26 22:29                                 ` Glauber Costa
2012-09-26 22:42                                 ` Tejun Heo
2012-09-26 22:42                                   ` Tejun Heo
2012-09-26 22:42                                   ` Tejun Heo
2012-09-26 22:54                                   ` Glauber Costa
2012-09-26 22:54                                     ` Glauber Costa
2012-09-26 23:08                                     ` Tejun Heo
2012-09-26 23:08                                       ` Tejun Heo
2012-09-26 23:08                                       ` Tejun Heo
2012-09-26 23:20                                       ` Glauber Costa
2012-09-26 23:20                                         ` Glauber Costa
2012-09-26 23:33                                         ` Tejun Heo
2012-09-26 23:33                                           ` Tejun Heo
2012-09-27 12:15                                           ` Michal Hocko
2012-09-27 12:15                                             ` Michal Hocko
2012-09-27 12:15                                             ` Michal Hocko
2012-09-27 12:20                                             ` Glauber Costa
2012-09-27 12:20                                               ` Glauber Costa
2012-09-27 12:40                                               ` Michal Hocko
2012-09-27 12:40                                                 ` Michal Hocko
2012-09-27 12:40                                                 ` Michal Hocko
2012-09-27 12:40                                                 ` Glauber Costa
2012-09-27 12:40                                                   ` Glauber Costa
2012-09-27 12:40                                                   ` Glauber Costa
2012-09-27 12:54                                                   ` Michal Hocko
2012-09-27 12:54                                                     ` Michal Hocko
2012-09-27 14:28                                       ` Mel Gorman
2012-09-27 14:28                                         ` Mel Gorman
2012-09-27 14:28                                         ` Mel Gorman
2012-09-27 14:49                                         ` Tejun Heo
2012-09-27 14:49                                           ` Tejun Heo
2012-09-27 14:57                                           ` Glauber Costa
2012-09-27 14:57                                             ` Glauber Costa
2012-09-27 17:46                                             ` Tejun Heo
2012-09-27 17:46                                               ` Tejun Heo
2012-09-27 17:46                                               ` Tejun Heo
2012-09-27 17:56                                               ` Michal Hocko
2012-09-27 17:56                                                 ` Michal Hocko
2012-09-27 18:45                                               ` Glauber Costa
2012-09-27 18:45                                                 ` Glauber Costa
2012-09-30  7:57                                                 ` Tejun Heo
2012-09-30  7:57                                                   ` Tejun Heo
2012-09-30  7:57                                                   ` Tejun Heo
2012-09-30  8:02                                                   ` Tejun Heo
2012-09-30  8:02                                                     ` Tejun Heo
2012-09-30  8:56                                                     ` James Bottomley
2012-09-30  8:56                                                       ` James Bottomley
2012-09-30  8:56                                                       ` James Bottomley
2012-09-30 10:37                                                       ` Tejun Heo
2012-09-30 10:37                                                         ` Tejun Heo
2012-09-30 10:37                                                         ` Tejun Heo
2012-09-30 11:25                                                         ` James Bottomley
2012-09-30 11:25                                                           ` James Bottomley
2012-10-01  0:57                                                           ` Tejun Heo
2012-10-01  0:57                                                             ` Tejun Heo
2012-10-01  0:57                                                             ` Tejun Heo
2012-10-01  8:43                                                             ` Glauber Costa
2012-10-01  8:43                                                               ` Glauber Costa
2012-10-01  8:46                                                         ` Glauber Costa
2012-10-01  8:46                                                           ` Glauber Costa
2012-10-03 22:59                                                           ` Tejun Heo
2012-10-03 22:59                                                             ` Tejun Heo
2012-10-01  8:36                                                   ` Glauber Costa
2012-10-01  8:36                                                     ` Glauber Costa
2012-09-27 12:08                             ` Michal Hocko
2012-09-27 12:08                               ` Michal Hocko
2012-09-27 12:08                               ` Michal Hocko
2012-09-27 12:11                               ` Glauber Costa
2012-09-27 12:11                                 ` Glauber Costa
2012-09-27 14:33                               ` Tejun Heo
2012-09-27 14:33                                 ` Tejun Heo
2012-09-27 14:43                                 ` Mel Gorman
2012-09-27 14:43                                   ` Mel Gorman
2012-09-27 14:43                                   ` Mel Gorman
2012-09-27 14:58                                   ` Tejun Heo
2012-09-27 14:58                                     ` Tejun Heo
2012-09-27 18:30                                     ` Glauber Costa
2012-09-27 18:30                                       ` Glauber Costa
2012-09-30  8:23                                       ` Tejun Heo
2012-09-30  8:23                                         ` Tejun Heo
2012-10-01  8:45                                         ` Glauber Costa
2012-10-01  8:45                                           ` Glauber Costa
2012-10-03 22:54                                           ` Tejun Heo
2012-10-03 22:54                                             ` Tejun Heo
2012-10-04 11:55                                             ` Glauber Costa
2012-10-04 11:55                                               ` Glauber Costa
2012-10-06  2:19                                               ` Tejun Heo
2012-10-06  2:19                                                 ` Tejun Heo
2012-10-06  2:19                                                 ` Tejun Heo
2012-09-27 15:09                                 ` Michal Hocko
2012-09-27 15:09                                   ` Michal Hocko
2012-09-30  8:47                                   ` Tejun Heo
2012-09-30  8:47                                     ` Tejun Heo
2012-10-01  9:27                                     ` Michal Hocko
2012-10-01  9:27                                       ` Michal Hocko
2012-10-03 22:43                                       ` Tejun Heo
2012-10-03 22:43                                         ` Tejun Heo
2012-10-03 22:43                                         ` Tejun Heo
2012-10-05 13:47                                         ` Michal Hocko
2012-10-05 13:47                                           ` Michal Hocko
2012-10-05 13:47                                           ` Michal Hocko
2012-09-26 22:11                         ` Johannes Weiner
2012-09-26 22:11                           ` Johannes Weiner
2012-09-26 22:11                           ` Johannes Weiner
2012-09-26 22:45                           ` Glauber Costa
2012-09-26 22:45                             ` Glauber Costa
2012-09-18 14:04 ` [PATCH v3 05/13] Add a __GFP_KMEMCG flag Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-18 14:15   ` Rik van Riel
2012-09-18 14:15     ` Rik van Riel
2012-09-18 15:06   ` Christoph Lameter
2012-09-18 15:06     ` Christoph Lameter
2012-09-18 15:06     ` Christoph Lameter
2012-09-19  7:39     ` Glauber Costa
2012-09-19  7:39       ` Glauber Costa
2012-09-19  7:39       ` Glauber Costa
2012-09-19 14:07       ` Christoph Lameter
2012-09-19 14:07         ` Christoph Lameter
2012-09-19 14:07         ` Christoph Lameter
2012-09-27 13:34   ` Mel Gorman
2012-09-27 13:34     ` Mel Gorman
2012-09-27 13:41     ` Glauber Costa
2012-09-27 13:41       ` Glauber Costa
2012-10-01 19:09   ` Johannes Weiner
2012-10-01 19:09     ` Johannes Weiner
2012-09-18 14:04 ` [PATCH v3 06/13] memcg: kmem controller infrastructure Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-20 16:05   ` JoonSoo Kim
2012-09-20 16:05     ` JoonSoo Kim
2012-09-20 16:05     ` JoonSoo Kim
2012-09-21  8:41     ` Glauber Costa
2012-09-21  8:41       ` Glauber Costa
2012-09-21  8:41       ` Glauber Costa
2012-09-21  9:14       ` JoonSoo Kim
2012-09-21  9:14         ` JoonSoo Kim
2012-09-26 15:51   ` Michal Hocko
2012-09-26 15:51     ` Michal Hocko
2012-09-26 15:51     ` Michal Hocko
2012-09-27 11:31     ` Glauber Costa
2012-09-27 11:31       ` Glauber Costa
2012-09-27 13:44       ` Michal Hocko
2012-09-27 13:44         ` Michal Hocko
2012-09-27 13:44         ` Michal Hocko
2012-09-28 11:34         ` Glauber Costa
2012-09-28 11:34           ` Glauber Costa
2012-09-28 11:34           ` Glauber Costa
2012-09-30  8:25           ` Tejun Heo
2012-09-30  8:25             ` Tejun Heo
2012-10-01  8:28             ` Glauber Costa
2012-10-01  8:28               ` Glauber Costa
2012-10-03 22:11               ` Tejun Heo
2012-10-03 22:11                 ` Tejun Heo
2012-10-03 22:11                 ` Tejun Heo
2012-10-01  9:44             ` Michal Hocko
2012-10-01  9:44               ` Michal Hocko
2012-10-01  9:44               ` Michal Hocko
2012-10-01  9:48           ` Michal Hocko
2012-10-01  9:48             ` Michal Hocko
2012-10-01  9:48             ` Michal Hocko
2012-10-01 10:09             ` Glauber Costa
2012-10-01 10:09               ` Glauber Costa
2012-10-01 11:51               ` Michal Hocko
2012-10-01 11:51                 ` Michal Hocko
2012-10-01 11:51                 ` Glauber Costa
2012-10-01 11:51                   ` Glauber Costa
2012-10-01 11:51                   ` Glauber Costa
2012-10-01 11:58                   ` Michal Hocko
2012-10-01 11:58                     ` Michal Hocko
2012-10-01 12:04                     ` Glauber Costa
2012-10-01 12:04                       ` Glauber Costa
2012-10-01 12:04                       ` Glauber Costa
2012-09-18 14:04 ` [PATCH v3 07/13] mm: Allocate kernel pages to the right memcg Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-27 13:50   ` Mel Gorman
2012-09-27 13:50     ` Mel Gorman
2012-09-28  9:43     ` Glauber Costa
2012-09-28  9:43       ` Glauber Costa
2012-09-28  9:43       ` Glauber Costa
2012-09-28 13:28       ` Mel Gorman
2012-09-28 13:28         ` Mel Gorman
2012-09-27 13:52   ` Michal Hocko
2012-09-27 13:52     ` Michal Hocko
2012-09-27 13:52     ` Michal Hocko
2012-09-18 14:04 ` Glauber Costa [this message]
2012-09-18 14:04   ` [PATCH v3 08/13] res_counter: return amount of charges after res_counter_uncharge Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-10-01 10:00   ` Michal Hocko
2012-10-01 10:00     ` Michal Hocko
2012-10-01 10:01     ` Glauber Costa
2012-10-01 10:01       ` Glauber Costa
2012-09-18 14:04 ` [PATCH v3 09/13] memcg: kmem accounting lifecycle management Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-10-01 12:15   ` Michal Hocko
2012-10-01 12:15     ` Michal Hocko
2012-10-01 12:15     ` Michal Hocko
2012-10-01 12:29     ` Glauber Costa
2012-10-01 12:29       ` Glauber Costa
2012-10-01 12:29       ` Glauber Costa
2012-10-01 12:36       ` Michal Hocko
2012-10-01 12:36         ` Michal Hocko
2012-10-01 12:36         ` Michal Hocko
2012-10-01 12:43         ` Glauber Costa
2012-10-01 12:43           ` Glauber Costa
2012-10-01 12:43           ` Glauber Costa
2012-09-18 14:04 ` [PATCH v3 10/13] memcg: use static branches when code not in use Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-10-01 12:25   ` Michal Hocko
2012-10-01 12:25     ` Michal Hocko
2012-10-01 12:27     ` Glauber Costa
2012-10-01 12:27       ` Glauber Costa
2012-10-01 12:27       ` Glauber Costa
2012-09-18 14:04 ` [PATCH v3 11/13] memcg: allow a memcg with kmem charges to be destructed Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-10-01 12:30   ` Michal Hocko
2012-10-01 12:30     ` Michal Hocko
2012-10-01 12:30     ` Michal Hocko
2012-09-18 14:04 ` [PATCH v3 12/13] execute the whole memcg freeing in rcu callback Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-21 17:23   ` Tejun Heo
2012-09-21 17:23     ` Tejun Heo
2012-09-21 17:23     ` Tejun Heo
2012-09-24  8:48     ` Glauber Costa
2012-09-24  8:48       ` Glauber Costa
2012-09-24  8:48       ` Glauber Costa
2012-10-01 13:27   ` Michal Hocko
2012-10-01 13:27     ` Michal Hocko
2012-10-01 13:27     ` Michal Hocko
2012-10-04 10:53     ` Glauber Costa
2012-10-04 10:53       ` Glauber Costa
2012-10-04 10:53       ` Glauber Costa
2012-10-04 14:20       ` Glauber Costa
2012-10-04 14:20         ` Glauber Costa
2012-10-05 15:31       ` Johannes Weiner
2012-10-05 15:31         ` Johannes Weiner
2012-10-05 15:31         ` Johannes Weiner
2012-10-08  9:45         ` Glauber Costa
2012-10-08  9:45           ` Glauber Costa
2012-09-18 14:04 ` [PATCH v3 13/13] protect architectures where THREAD_SIZE >= PAGE_SIZE against fork bombs Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-09-18 14:04   ` Glauber Costa
2012-10-01 13:17   ` Michal Hocko
2012-10-01 13:17     ` Michal Hocko
2012-10-01 13:17     ` Michal Hocko

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=1347977050-29476-9-git-send-email-glommer@parallels.com \
    --to=glommer@parallels.com \
    --cc=cgroups@vger.kernel.org \
    --cc=devel@openvz.org \
    --cc=fweisbec@gmail.com \
    --cc=hannes@cmpxchg.org \
    --cc=kamezawa.hiroyu@jp.fujitsu.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-mm@kvack.org \
    --cc=mgorman@suse.de \
    --cc=mhocko@suse.cz \
    --cc=rientjes@google.com \
    --cc=suleiman@google.com \
    --cc=tj@kernel.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.