(root)/
gcc-13.2.0/
gcc/
testsuite/
gcc.dg/
vect/
no-vfa-vect-53.c
       1  /* { dg-require-effective-target vect_float } */
       2  
       3  #include <stdarg.h>
       4  #include "tree-vect.h"
       5  
       6  #define N 256
       7  
       8  __attribute__ ((noinline))
       9  void bar (const float *pa, const float *pb, const float *pc) 
      10  {
      11    int i;
      12  
      13    /* check results:  */
      14    for (i = 0; i < N; i++)
      15      {
      16        if (pa[i] != (pb[i] * pc[i]))
      17  	abort ();
      18      }
      19  
      20    return;
      21  }
      22  
      23  /* Unaligned pointer read accesses, aligned pointer write access.
      24     The loop bound is unknown.
      25     Can't prove that the pointers don't alias.
      26     vect-49.c is similar to this one with one difference:
      27          the loop bound is known.
      28     vect-52.c is similar to this one with one difference:
      29          aliasing is not a problem.  */
      30  
      31  __attribute__ ((noinline)) int
      32  main1 (int n, float *pb, float *pc)
      33  {
      34    float pa[N] __attribute__ ((__aligned__(__BIGGEST_ALIGNMENT__)));
      35    int i;
      36  
      37    for (i = 0; i < n; i++)
      38      {
      39        pa[i] = pb[i] * pc[i];
      40      }
      41  
      42    bar (pa,pb,pc);
      43  
      44    return 0;
      45  }
      46  
      47  int main (void)
      48  {
      49    int i;
      50    float a[N] __attribute__ ((__aligned__(__BIGGEST_ALIGNMENT__)));
      51    float b[N+1] __attribute__ ((__aligned__(__BIGGEST_ALIGNMENT__))) = {0,3,6,9,12,15,18,21,24,27,30,33,36,39,42,45,48,51,54,57,60};
      52    float c[N+1] __attribute__ ((__aligned__(__BIGGEST_ALIGNMENT__))) = {0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20};
      53  
      54    check_vect ();
      55  
      56    main1 (N,&b[1],c);
      57    main1 (N,&b[1],&c[1]);
      58  
      59    return 0;
      60  }
      61  
      62  /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" } } */