Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752712Ab0K3OAN (ORCPT ); Tue, 30 Nov 2010 09:00:13 -0500 Received: from mx3.mail.elte.hu ([157.181.1.138]:54040 "EHLO mx3.mail.elte.hu" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751991Ab0K3OAK (ORCPT ); Tue, 30 Nov 2010 09:00:10 -0500 Date: Tue, 30 Nov 2010 14:59:59 +0100 From: Ingo Molnar To: Peter Zijlstra Cc: Mike Galbraith , Paul Turner , Linus Torvalds , Oleg Nesterov , LKML Subject: Re: [PATCH v4] sched: automated per session task groups Message-ID: <20101130135959.GA20703@elte.hu> References: <1291031593.32004.19.camel@laptop> <1291052268.32004.171.camel@laptop> <1291057565.20709.2.camel@marge.simson.net> <20101129192033.GA18372@elte.hu> <1291090455.7550.7.camel@marge.simson.net> <1291123083.28239.18.camel@marge.simson.net> <1291124887.32004.791.camel@laptop> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1291124887.32004.791.camel@laptop> User-Agent: Mutt/1.5.20 (2009-08-17) X-ELTE-SpamScore: -1.3 X-ELTE-SpamLevel: X-ELTE-SpamCheck: no X-ELTE-SpamVersion: ELTE 2.0 X-ELTE-SpamCheck-Details: score=-1.3 required=5.9 tests=BAYES_00,FUZZY_VPILL autolearn=no SpamAssassin version=3.2.5 0.7 FUZZY_VPILL BODY: Attempt to obfuscate words in spam -2.0 BAYES_00 BODY: Bayesian spam probability is 0 to 1% [score: 0.0000] Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3088 Lines: 66 * Peter Zijlstra wrote: > On Tue, 2010-11-30 at 14:18 +0100, Mike Galbraith wrote: > > > > From: Mike Galbraith > > Date: Tue Nov 30 14:07:12 CET 2010 > > Subject: [PATCH] sched: Improve desktop interactivity: Implement automated per session task groups > > > > A recurring complaint from CFS users is that parallel kbuild has a negative > > impact on desktop interactivity. This patch implements an idea from Linus, > > to automatically create task groups. Currently, only per session autogroups > > are implemented, but the patch leaves the way open for enhancement. > > > > Implementation: each task's signal struct contains an inherited pointer to > > a refcounted autogroup struct containing a task group pointer, the default > > for all tasks pointing to the init_task_group. When a task calls setsid(), > > a new task group is created, the process is moved into the new task group, > > and a reference to the preveious task group is dropped. Child processes > > inherit this task group thereafter, and increase it's refcount. When the > > last thread of a process exits, the process's reference is dropped, such > > that when the last process referencing an autogroup exits, the autogroup > > is destroyed. > > > > At runqueue selection time, IFF a task has no cgroup assignment, its current > > autogroup is used. > > > > Autogroup bandwidth is controllable via setting it's nice level through the > > proc filesystem. cat /proc//autogroup displays the task's group and the > > group's nice level. echo > /proc//autogroup Sets the task > > group's shares to the weight of nice task. Setting nice level is rate > > limited for !admin users due to the abuse risk of task group locking. > > > > The feature is enabled from boot by default if CONFIG_SCHED_AUTOGROUP=y is > > selected, but can be disabled via the boot option noautogroup, and can also > > be turned on/off on the fly via.. > > echo [01] > /proc/sys/kernel/sched_autogroup_enabled. > > ..which will automatically move tasks to/from the root task group. > > > > Signed-off-by: Mike Galbraith > > Cc: Oleg Nesterov > > Cc: Peter Zijlstra > > Cc: Linus Torvalds > > Cc: Markus Trippelsdorf > > Cc: Mathieu Desnoyers > > LKML-Reference: <1290281700.28711.9.camel@maggy.simson.net> > > Signed-off-by: Ingo Molnar > > Looks good to me, Thanks Mike! > > Acked-by: Peter Zijlstra Ok, great! I've queued it up in tip:sched/core and started testing it - will push it out if it passes basic tests. Added Linus's Acked-by - i presume that's still valid for v4 as well, right? Thanks, Ingo -- 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/