------- Comment #7 from pault at gcc dot gnu dot org 2008-09-16 17:51 -------
(In reply to comment #2)
Hi Andrew,
Does this do it for you or is this all to rarified for this
Bear-of-little-brain to follow?
D.1359 = *start - *offset;
D.1360 = *end + *offset;
D.1361 = *step;
D.1364 = D.1361 > 0 ? D.1360 < D.1359 : D.1360 > D.1359; /* Fix the
result*/
if (D.1364) goto L.2; /* Then branch */
countm1.0 = (D.1361 > 0 ? (character(kind=4)) (D.1360 - D.1359) :
(character(kind=4)) (D.1359 - D.1360)) / (character(kind=4)) ABS_EXPR <D.1361>;
i = D.1359;
while (1)
Cheers
Paul
(In reply to comment #6)
> (In reply to comment #5)
> > (In reply to comment #2)
> > Hi Andrew,
> >
> > Does this do it for you or is this all to rarified for this
> > Bear-of-little-brain to follow?
> >
> > D.1359 = *start - *offset;
> > D.1360 = *end + *offset;
> > D.1361 = *step;
> > D.1364 = D.1361 > 0 ? D.1360 < D.1359 : D.1360 > D.1359; /* Fix the
> > result*/
> > if (D.1364) goto L.2; /* Then branch
> > */
>
> The issue is that D.1364 is used to the store of the result of a comparison.
> Since GCC does not currently optimize that case, the front-end could rewrite
> the if statement to begin with; this is what Jabuk's patch does (Thanks
> Jabuk!).
>
Ahhhhh....!
Thanks
P.
--
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=37536