Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752226AbbF1Tn1 (ORCPT ); Sun, 28 Jun 2015 15:43:27 -0400 Received: from mail-wi0-f174.google.com ([209.85.212.174]:34269 "EHLO mail-wi0-f174.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752648AbbF1TnT (ORCPT ); Sun, 28 Jun 2015 15:43:19 -0400 Date: Sun, 28 Jun 2015 22:43:14 +0300 From: Alexey Dobriyan To: joe@perches.com Cc: linux-kernel@vger.kernel.org, linux@rasmusvillemoes.dk, akpm@linux-foundation.org Subject: Re: [PATCH] un-improve strrchr() Message-ID: <20150628194314.GA16858@p183.telecom.by> References: <20150628163252.GA1991@p183.telecom.by> <20150628164403.GA7169@p183.telecom.by> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20150628164403.GA7169@p183.telecom.by> User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1681 Lines: 50 Joe Perches wrote: > On Sun, 2015-06-28 at 19:44 +0300, Alexey Dobriyan wrote: > > Commit 8da53d4595a53fb9a3380dd4d1c9bc24c7c9aab8 > > ("lib/string.c: improve strrchr()") changed strrchr() implementation > > from "rewind to the end and search backwards" to "search forward" > > optimizing for characher not found case. However, common case is exactly > > the opposite: string is absolute pathname, c is '/' always to be found. > > > > Previous code did 1 branch per character + 1 branch for every character > > in the last path component. Current code does 2 branches per characher > > regardless. > > Are you comparing total cycles of all of the branches > in the called functions too? I'm comparing branches to branches. For strrchr() you don't need 2xN branches even in theory. strlen() might even be optimized (gcc does have the impudence to inline it's own CMPB version though). > As written the current version removes the strlen call. It does. > > --- a/lib/string.c > > +++ b/lib/string.c > > @@ -313,12 +313,13 @@ EXPORT_SYMBOL(strchrnul); > > */ > > char *strrchr(const char *s, int c) > > { > > - const char *last = NULL; > > + const char *p = s + strlen(s); > > + > > do { > > - if (*s == (char)c) > > - last = s; > > - } while (*s++); > > - return (char *)last; > > + if (*p == (char)c) > > + return (char *)p; > > + } while (--p >= s); > > + return NULL; > > } > > EXPORT_SYMBOL(strrchr); > > #endif -- 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/