Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758859AbYBPRnA (ORCPT ); Sat, 16 Feb 2008 12:43:00 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1755986AbYBPRmw (ORCPT ); Sat, 16 Feb 2008 12:42:52 -0500 Received: from pentafluge.infradead.org ([213.146.154.40]:54324 "EHLO pentafluge.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755944AbYBPRmv (ORCPT ); Sat, 16 Feb 2008 12:42:51 -0500 Date: Sat, 16 Feb 2008 09:42:26 -0800 From: Arjan van de Ven To: Willy Tarreau Cc: Roel Kluin <12o3l@tiscali.nl>, geoffrey.levand@am.sony.com, linuxppc-dev@ozlabs.org, cbe-oss-dev@ozlabs.org, lkml Subject: Re: [PATCH 1/3] Fix Unlikely(x) == y Message-ID: <20080216094226.1e8eede1@laptopd505.fenrus.org> In-Reply-To: <20080216173315.GU8953@1wt.eu> References: <47B70A61.9030306@tiscali.nl> <20080216092552.325e5726@laptopd505.fenrus.org> <20080216173315.GU8953@1wt.eu> Organization: Intel X-Mailer: Claws Mail 3.2.0 (GTK+ 2.12.5; i386-redhat-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-SRS-Rewrite: SMTP reverse-path rewritten from by pentafluge.infradead.org See http://www.infradead.org/rpr.html Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2107 Lines: 47 On Sat, 16 Feb 2008 18:33:16 +0100 Willy Tarreau wrote: > On Sat, Feb 16, 2008 at 09:25:52AM -0800, Arjan van de Ven wrote: > > On Sat, 16 Feb 2008 17:08:01 +0100 > > Roel Kluin <12o3l@tiscali.nl> wrote: > > > > > The patch below was not yet tested. If it's correct as it is, > > > please comment. --- > > > Fix Unlikely(x) == y > > > > > > > you found a great set of bugs.. > > but to be honest... I suspect it's just best to remove unlikely > > altogether for these cases; unlikely() is almost a > > go-faster-stripes thing, and if you don't know how to use it you > > shouldn't be using it... so just removing it for all wrong cases is > > actually the best thing to do imo. > > Well, eventhough the author may not know how to use it, "unlikely" at > least indicates the intention of the author, or his knowledge of what > should happen here. I'd suggest leaving it where it is because the > authot of this code is in best position to know that this branch is > unlikely to happen, eventhough he does not correctly use the macro. > you have more faith in the authors knowledge of how his code actually behaves than I think is warranted :) Or faith in that he knows what "unlikely" means. I should write docs about this; but unlikely() means: 1) It happens less than 0.01% of the cases. 2) The compiler couldn't have figured this out by itself (NULL pointer checks are compiler done already, same for some other conditions) 3) It's a hot codepath where shaving 0.5 cycles (less even on x86) matters (and the author is ok with taking a 500 cycles hit if he's wrong) If you think unlikely() means something else, we should fix what it maps to towards gcc ;) (to.. be empty ;) -- If you want to reach me at my work email, use arjan@linux.intel.com For development, discussion and tips for power savings, visit http://www.lesswatts.org -- 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/