1  /* { dg-do compile } */
       2  /* { dg-options "-fopenmp" } */
       3  /* { dg-additional-options "-std=c99" { target c } } */
       4  
       5  extern int a[13*13*13*13*2], b[1024], *k, l, m;
       6  
       7  void
       8  foo (int *q, float *p)
       9  {
      10    int *i, *j, *n, *o;
      11  #pragma omp simd collapse (4) linear(k : m + 1) aligned(p, q)
      12    for (i = &a[0]; i < &a[13*13*13*13*2]; i += 13*13*13*2)
      13      for (j = &a[0]; j < &a[13*13*13*2]; j += 13*13*2)
      14        for (n = &a[0]; n < &a[13*13*2]; n += 13*2)
      15  	for (o = &a[0]; o < &a[13*2]; o += 2)
      16  	  q[k - &a[0]] *= p[k - &a[0]] + 7 * (i-&a[0]) + 14 * (j-&a[0]) + 21 * (n-&a[0]) + 28 * (o-&a[0]), k += m + 1;
      17  }
      18  
      19  void
      20  bar ()
      21  {
      22    int *i;
      23    #pragma omp simd safelen(16) aligned(a, b : 32)
      24    for (i = &a[0]; i < &a[1024]; i++)
      25      *i *= b[i - &a[0]];
      26  }