On Thu, Jun 04, 2015 at 06:36:33PM +0200, Ondřej Bílka wrote:
> On Thu, Jun 04, 2015 at 04:01:50PM +0000, Joseph Myers wrote:
> > On Thu, 4 Jun 2015, Richard Earnshaw wrote:
> > 
> > > > Change that into
> > > > 
> > > > int foo(char *s)
> > > > {
> > > >   int l = strlen (s);
> > > >   char *p = memchr (s, 'a', l);
> > > >   return p+l;
> > > > }

> And Joseph you shouldn't restrict yourself only to values that are
> present in variables to cover case where its implicit one from strcpy
> converted to stpcpy.

memchr isn't handled in that pass right now at all, of course it could be
added, shouldn't be really hard.  Feel free to file a PR and/or write
a patch.

As for e.g. the inlining of the first (or a few more) iterations of strcmp
etc., that is certainly something that can be done in the compiler too and
the compiler should have much better information whether to do it or not,
as it shouldn't be done for -Os, or for basic blocks or functions predicted
cold, because it enlarges the code size quite a lot.
For strcmp in particular, right now we handle the cast of two string
literals at compile time, or e.g. strcmp (str, "").  For anything further,
supposedly it should check if the target has inline expansion of strcmp
(e.g. s390 or sh have them), then inlining one iteration is hardly
beneficial.

        Jakub

Reply via email to