[PATCH 1/2] res_counter : check limit change

!MAILaRCHIVE_VOTE_RePLACE
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]
To: LKML <linux-kernel@...>
Cc: linux-mm@kvack.org <linux-mm@...>, Andrew Morton <akpm@...>, balbir@linux.vnet.ibm.com <balbir@...>, xemul@openvz.org <xemul@...>, menage@google.com <menage@...>, nishimura@mxp.nes.nec.co.jp <nishimura@...>, yamamoto@valinux.co.jp <yamamoto@...>
Date: Friday, July 4, 2008 - 5:12 am

Add an interface to set limit. This is necessary to memory resource controller
because it shrinks usage at set limit.

(*) Other controller may not need this interface to shrink usage because
    shrinking is not necessary or impossible in it.

Changelog:
  - fixed white space bug.

Acked-by: Balbir Singh <balbir@linux.vnet.ibm.com>
Signed-off-by: KAMEZAWA Hiroyuki <kamezawa.hiroyu@jp.fujitsu.com>


 include/linux/res_counter.h |   15 +++++++++++++++
 1 file changed, 15 insertions(+)

Index: test-2.6.26-rc8-mm1/include/linux/res_counter.h
===================================================================
--- test-2.6.26-rc8-mm1.orig/include/linux/res_counter.h
+++ test-2.6.26-rc8-mm1/include/linux/res_counter.h
@@ -176,4 +176,19 @@ static inline bool res_counter_can_add(s
 	return ret;
 }
 
+static inline int res_counter_set_limit(struct res_counter *cnt,
+	unsigned long long limit)
+{
+	unsigned long flags;
+	int ret = -EBUSY;
+
+	spin_lock_irqsave(&cnt->lock, flags);
+	if (cnt->usage < limit) {
+		cnt->limit = limit;
+		ret = 0;
+	}
+	spin_unlock_irqrestore(&cnt->lock, flags);
+	return ret;
+}
+
 #endif

--
Previous message: [thread] [date] [author]
Next message: [thread] [date] [author]

Messages in current thread:
[PATCH 1/2] res_counter : check limit change, KAMEZAWA Hiroyuki, (Fri Jul 4, 5:12 am)
Re: [PATCH 1/2] res_counter : check limit change, Pavel Emelyanov, (Fri Jul 4, 6:34 am)
[PATCH 2/2] memcg: check limit change, KAMEZAWA Hiroyuki, (Fri Jul 4, 5:16 am)
Re: [PATCH 2/2] memcg: check limit change, Pavel Emelyanov, (Fri Jul 4, 6:35 am)