From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail143.messagelabs.com (mail143.messagelabs.com [216.82.254.35]) by kanga.kvack.org (Postfix) with ESMTP id 1D9936B0093 for ; Tue, 3 Mar 2009 06:23:14 -0500 (EST) Received: from d28relay04.in.ibm.com (d28relay04.in.ibm.com [9.184.220.61]) by e28smtp09.in.ibm.com (8.13.1/8.13.1) with ESMTP id n23B03KN010438 for ; Tue, 3 Mar 2009 16:30:03 +0530 Received: from d28av04.in.ibm.com (d28av04.in.ibm.com [9.184.220.66]) by d28relay04.in.ibm.com (8.13.8/8.13.8/NCO v9.2) with ESMTP id n23BNF3u3903600 for ; Tue, 3 Mar 2009 16:53:15 +0530 Received: from d28av04.in.ibm.com (loopback [127.0.0.1]) by d28av04.in.ibm.com (8.13.1/8.13.3) with ESMTP id n23BN7SN024183 for ; Tue, 3 Mar 2009 22:23:08 +1100 Date: Tue, 3 Mar 2009 16:53:06 +0530 From: Balbir Singh Subject: Re: [PATCH 0/4] Memory controller soft limit patches (v3) Message-ID: <20090303112305.GR11421@balbir.in.ibm.com> Reply-To: balbir@linux.vnet.ibm.com References: <20090301062959.31557.31079.sendpatchset@localhost.localdomain> <20090302092404.1439d2a6.kamezawa.hiroyu@jp.fujitsu.com> <20090302044043.GC11421@balbir.in.ibm.com> <20090302143250.f47758f9.kamezawa.hiroyu@jp.fujitsu.com> <20090302060519.GG11421@balbir.in.ibm.com> <20090302151830.3770e528.kamezawa.hiroyu@jp.fujitsu.com> <20090302175235.GN11421@balbir.in.ibm.com> <20090303090303.ca430b43.kamezawa.hiroyu@jp.fujitsu.com> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline In-Reply-To: <20090303090303.ca430b43.kamezawa.hiroyu@jp.fujitsu.com> Sender: owner-linux-mm@kvack.org To: KAMEZAWA Hiroyuki Cc: linux-mm@kvack.org, Sudhir Kumar , YAMAMOTO Takashi , Bharata B Rao , Paul Menage , lizf@cn.fujitsu.com, linux-kernel@vger.kernel.org, KOSAKI Motohiro , David Rientjes , Pavel Emelianov , Dhaval Giani , Rik van Riel , Andrew Morton List-ID: * KAMEZAWA Hiroyuki [2009-03-03 09:03:03]: > On Mon, 2 Mar 2009 23:22:35 +0530 > Balbir Singh wrote: > > > * KAMEZAWA Hiroyuki [2009-03-02 15:18:30]: > > > > > On Mon, 2 Mar 2009 11:35:19 +0530 > > > Balbir Singh wrote: > > > > > > > > Then, not-sorted RB-tree can be there. > > > > > > > > > > BTW, > > > > > time_after(jiffies, 0) > > > > > is buggy (see definition). If you want make this true always, > > > > > time_after(jiffies, jiffies +1) > > > > > > > > > > > > > HZ/4 is 250/4 jiffies in the worst case (62). We have > > > > time_after(jiffies, next_update_interval) and next_update_interval is > > > > set to last_tree_update + 62. Not sure if I got what you are pointing > > > > to. > > > > > > > + unsigned long next_update = 0; > > > + unsigned long flags; > > > + > > > + if (!css_tryget(&mem->css)) > > > + return; > > > + prev_usage_in_excess = mem->usage_in_excess; > > > + new_usage_in_excess = res_counter_soft_limit_excess(&mem->res); > > > + > > > + if (time_check) > > > + next_update = mem->last_tree_update + > > > + MEM_CGROUP_TREE_UPDATE_INTERVAL; > > > + if (new_usage_in_excess && time_after(jiffies, next_update)) { > > > + if (prev_usage_in_excess) > > > + mem_cgroup_remove_exceeded(mem); > > > + mem_cgroup_insert_exceeded(mem); > > > + updated_tree = true; > > > + } else if (prev_usage_in_excess && !new_usage_in_excess) { > > > + mem_cgroup_remove_exceeded(mem); > > > + updated_tree = true; > > > + } > > > > > > My point is what happens if time_check==false. > > > time_afrter(jiffies, 0) is buggy. > > > > > > > I see your point now, but the idea behind doing so is that > > time_after(jiffies, 0) will always return false, which forces the > > prev_usage_in_excess and !new_usage_in_excess check to execute. We set > > the value to false only from __mem_cgroup_free(). > > > > Are you suggesting that calling time_after(jiffies, 0) is buggy? > > The comment > > > > Do this with "<0" and ">=0" to only test the sign of the result. A > > > > I think refers to the comparison check and not to the parameters. I > > hope I am reading this right. > > 106 #define time_after(a,b) \ > 107 (typecheck(unsigned long, a) && \ > 108 typecheck(unsigned long, b) && \ > 109 ((long)(b) - (long)(a) < 0)) > > Reading above. > > if b==0. > if (long)a <0 -> false > if (long)a >0 -> true > > jiffies is unsigned value. please think of bit-pattern of signed/unsigned value. Fair enough, the cast to long will be an issue. I'll fix it. -- Balbir -- 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