Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752598AbYLRJf0 (ORCPT ); Thu, 18 Dec 2008 04:35:26 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1751559AbYLRJfH (ORCPT ); Thu, 18 Dec 2008 04:35:07 -0500 Received: from E23SMTP05.au.ibm.com ([202.81.18.174]:53975 "EHLO e23smtp05.au.ibm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751542AbYLRJfE (ORCPT ); Thu, 18 Dec 2008 04:35:04 -0500 Date: Thu, 18 Dec 2008 15:05:38 +0530 From: Vaidyanathan Srinivasan To: Andrew Morton Cc: linux-kernel@vger.kernel.org, suresh.b.siddha@intel.com, venkatesh.pallipadi@intel.com, a.p.zijlstra@chello.nl, mingo@elte.hu, dipankar@in.ibm.com, balbir@linux.vnet.ibm.com, vatsa@linux.vnet.ibm.com, ego@in.ibm.com, andi@firstfloor.org, davecb@sun.com, tconnors@astro.swin.edu.au, maxk@qualcomm.com, gregory.haskins@gmail.com, pavel@suse.cz Subject: Re: [PATCH v6 6/7] sched: add SD_BALANCE_NEWIDLE at MC and CPU level for sched_mc>0 Message-ID: <20081218093538.GB4272@dirshya.in.ibm.com> Reply-To: svaidy@linux.vnet.ibm.com Mail-Followup-To: Andrew Morton , linux-kernel@vger.kernel.org, suresh.b.siddha@intel.com, venkatesh.pallipadi@intel.com, a.p.zijlstra@chello.nl, mingo@elte.hu, dipankar@in.ibm.com, balbir@linux.vnet.ibm.com, vatsa@linux.vnet.ibm.com, ego@in.ibm.com, andi@firstfloor.org, davecb@sun.com, tconnors@astro.swin.edu.au, maxk@qualcomm.com, gregory.haskins@gmail.com, pavel@suse.cz References: <20081217172309.534.28847.stgit@drishya.in.ibm.com> <20081217172738.534.3118.stgit@drishya.in.ibm.com> <20081217174254.ea19a246.akpm@linux-foundation.org> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline In-Reply-To: <20081217174254.ea19a246.akpm@linux-foundation.org> User-Agent: Mutt/1.5.18 (2008-05-17) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org * Andrew Morton [2008-12-17 17:42:54]: > On Wed, 17 Dec 2008 22:57:38 +0530 > Vaidyanathan Srinivasan wrote: > > > --- a/include/linux/sched.h > > +++ b/include/linux/sched.h > > @@ -782,6 +782,16 @@ enum powersavings_balance_level { > > ((sched_mc_power_savings || sched_smt_power_savings) ? \ > > SD_POWERSAVINGS_BALANCE : 0) > > What's with all the crappy macros in here? Hi Andrew, These macros set the SD_POWERSAVINGS_BALANCE flag based on the sysfs tunable. > > +/* > > + * Optimise SD flags for power savings: > > + * SD_BALANCE_NEWIDLE helps agressive task consolidation and power savings. > > + * Keep default SD flags if sched_{smt,mc}_power_saving=0 > > + */ > > + > > +#define POWERSAVING_SD_FLAGS \ > > + ((sched_mc_power_savings || sched_smt_power_savings) ? \ > > + SD_BALANCE_NEWIDLE : 0) > > This one purports to be a constant, but it isn't - it's code. > > It would be cleaner, clearer and more idiomatic to do > > static inline int powersaving_sd_flags(void) > { > ... > } Your are suggesting to move these to inline functions. I will write a patch and post for review. > Also, doing (sched_mc_power_savings | sched_smt_power_saving) might > save a branch. > > > #define test_sd_parent(sd, flag) ((sd->parent && \ > > (sd->parent->flags & flag)) ? 1 : 0) > > buggy when passed an expression with side-effects. Doesn't need to be > implemented as a macro. Agreed, but these macros are used throughout sched.c and are performance sensitive. Inline functions are a close enough replacement for the macro let me look for any performance penalty as well and report. Thanks for the review and comments. --Vaidy -- 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/