Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932647Ab0BPHU4 (ORCPT ); Tue, 16 Feb 2010 02:20:56 -0500 Received: from cantor.suse.de ([195.135.220.2]:33378 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932624Ab0BPHUz (ORCPT ); Tue, 16 Feb 2010 02:20:55 -0500 Date: Tue, 16 Feb 2010 18:20:47 +1100 From: Nick Piggin To: David Rientjes Cc: Andrew Morton , Rik van Riel , KAMEZAWA Hiroyuki , Andrea Arcangeli , Balbir Singh , Lubos Lunak , KOSAKI Motohiro , linux-kernel@vger.kernel.org, linux-mm@kvack.org Subject: Re: [patch -mm 4/9 v2] oom: remove compulsory panic_on_oom mode Message-ID: <20100216072047.GH5723@laptop> References: <20100216062035.GA5723@laptop> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.20 (2009-06-14) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2493 Lines: 56 On Mon, Feb 15, 2010 at 10:59:26PM -0800, David Rientjes wrote: > On Tue, 16 Feb 2010, Nick Piggin wrote: > > > What is the point of removing it, though? If it doesn't significantly > > help some future patch, just leave it in. It's not worth breaking the > > user/kernel interface just to remove 3 trivial lines of code. > > > > Because it is inconsistent at the user's expense, it has never panicked > the machine for memory controller ooms, so why is a cpuset or mempolicy > constrained oom conditions any different? Well memory controller was added later, wasn't it? So if you think that's a bug then a fix to panic on memory controller ooms might be in order. > It also panics the machine even > on VM_FAULT_OOM which is ridiculous, Why? > the tunable is certainly not being > used how it was documented Why not? The documentation seems to match the implementation. > and so given the fact that mempolicy > constrained ooms are now much smarter with my rewrite and we never simply > kill current unless oom_kill_quick is enabled anymore, the compulsory > panic_on_oom == 2 mode is no longer required. Simply set all tasks > attached to a cpuset or bound to a specific mempolicy to be OOM_DISABLE, > the kernel need not provide confusing alternative modes to sysctls for > this behavior. Before panic_on_oom == 2 was introduced, it would have > only panicked the machine if panic_on_oom was set to a non-zero integer, > defining it be something different for '2' after it has held the same > semantics for years is inappropriate. Well it was always defined in the documentation that it should be 0 or 1. Just that the limit wasn't enforced. I agree that's not ideal, but anyway the existing and documented 0/1/2 has been there for 3 years and so now removing the 2 is even worse. > There is just no concrete example > that anyone can give where they want a cpuset-constrained oom to panic the > machine when other tasks on a disjoint set of mems can continue to do > work and the cpuset of interest cannot have its tasks set to OOM_DISABLE. But this is changing the way the environment is required to set up. So a kernel upgrade can break previously working setups. We don't do this without really good reason. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/