On Wed, Aug 3, 2016 at 12:06 PM, Vikram Mulukutla
<mark...@codeaurora.org> wrote:
> Hi,
>
> The program listed below seems to invoke optimization behavior that produces
> different results pre 4.8 and 4.8+ versions of gcc. Using the -fno-tree-vrp
> option makes things consistent again. I make no claim of an understanding of
> what this flag really does.
>
> The program is badly written since the first operand to && in the while loop
> conditional will cause an invalid array access. I'm assuming that
> optimization behavior is unpredictable when the assumption that there will
> be no invalid array accesses is broken (and thus execution/output is
> untrustworthy), but I am curious as to why there is a change with 4.8+. The
> only concern I'd have is if this change may somehow affect other, correctly
> written code.
>
> # gcc 4.8 produces this:
> $ gcc-4.8 -O2 fk2.c && ./a.out
> i after loop (array size is 5): 5
> found at 5, answer is 0
>
> # pre gcc 4.8 produces this:
> $ gcc-4.4 -O2 fk2.c && ./a.out
> i after loop (array size is 5): 5
> This should be printed.
> found at 4, answer is 6
>
> $ gcc-4.6 -O2 fk2.c && ./a.out
> i after loop (array size is 5): 5
> This should be printed.
> found at 4, answer is 6
>
> Program:
>
> #include <stdio.h>
>
> #define ARRAY_SIZE(x) (sizeof(x)/sizeof(x[0]))
>
> unsigned int numbers[] = {
>         10,
>         9,
>         8,
>         7,
>         6,
> };
>
> /* find the element closest to elem */
> int main()
> {
>         unsigned int elem = 0;
>         unsigned int i = 0;
>
>         while ((elem < numbers[i]) && (i < ARRAY_SIZE(numbers)))
>                         i++;


You are invoking undefined behavior by accessing numbers[5].

Thanks,
Andrew Pinski

>
>         printf("i after loop (array size is %lu): %d\n",
> ARRAY_SIZE(numbers), i);
>
>         if (i == ARRAY_SIZE(numbers)) {
>                 printf("This should be printed.\n");
>                 i--;
>         }
>
>         printf("found at %d, answer is %u\n", i, numbers[i]);
>
>         return 0;
> }
>
> Thanks,
> Vikram

Reply via email to