Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1764929AbZANRG2 (ORCPT ); Wed, 14 Jan 2009 12:06:28 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1764095AbZANRGK (ORCPT ); Wed, 14 Jan 2009 12:06:10 -0500 Received: from tservice.net.ru ([195.178.208.66]:45661 "EHLO tservice.net.ru" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1762249AbZANRGJ (ORCPT ); Wed, 14 Jan 2009 12:06:09 -0500 Date: Wed, 14 Jan 2009 20:06:06 +0300 From: Evgeniy Polyakov To: linux-kernel@vger.kernel.org Cc: David Rientjes , Balbir Singh , Alan Cox , Dave Jones , Andrew Morton , Linus Torvalds , Theodore Tso , Matthias Andree Subject: [take2] OOM documentation update [was: Linux killed Kenny, bastard!] Message-ID: <20090114170606.GB12102@ioremap.net> References: <20090112155108.2646b3ae@lxorguk.ukuu.org.uk> <20090113135246.GA29251@ioremap.net> <20090113140627.507f15e1@lxorguk.ukuu.org.uk> <20090113142423.GA30710@ioremap.net> <661de9470901130700m34c4938cm6feeb6fc561d605a@mail.gmail.com> <20090113152106.GA1134@ioremap.net> <20090113213316.GB27227@ioremap.net> <20090114161225.GA9584@ioremap.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20090114161225.GA9584@ioremap.net> User-Agent: Mutt/1.5.13 (2006-08-11) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2329 Lines: 52 Updated version fixes some errors and extends description by adding swapping and children relation explaintaion. Signed. diff --git a/Documentation/filesystems/proc.txt b/Documentation/filesystems/proc.txt index d105eb4..4aa1918 100644 --- a/Documentation/filesystems/proc.txt +++ b/Documentation/filesystems/proc.txt @@ -2311,6 +2311,33 @@ increase the likelihood of this process being killed by the oom-killer. Valid values are in the range -16 to +15, plus the special value -17, which disables oom-killing altogether for this process. +The process to be killed in an out-of-memory situation is selected among all others +based on its badness score. This value equals the original memory size of the process +originally and is then updated according to its CPU time (utime + stime) and the +run time (uptime - start time). The longer it runs the smaller is the score. +Badness score is divided by the square root of the cpu time and then by +the double square root of the run time. + +Swapped out tasks are killed first. Half of each child's memory size is added to +the parent's score if they do not share the same memory. Thus forking servers +are the prime candidates to be killed. Having only one 'hungry' child will make +parent less preferable than the child. + +/proc//oom_score shows process' current badness score. + +The following heuristics are then applied: + * if the task was reniced, its score doubles + * superuser or direct hardware access tasks (CAP_SYS_ADMIN, CAP_SYS_RESOURCE + or CAP_SYS_RAWIO) have their score divided by 4 + * if oom condition happened in one cpuset and checked task does not belong + to it, its score is divided by 8 + * resulted score is multiplied by the two in the power of oom_adj when it is + positive, and divided otherwise, i.e. + points <<= oom_adj when it is positive and + points >>= oom_adj otherwise + +The task with the highest badness score is then killed. + 2.13 /proc//oom_score - Display current oom-killer score ------------------------------------------------------------- -- Evgeniy Polyakov -- 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/