123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 |
- /* { dg-do run } */
- /* { dg-options "-O2" } */
- /* { dg-additional-options "-msse2" { target sse2_runtime } } */
- /* { dg-additional-options "-mavx" { target avx_runtime } } */
- int
- main ()
- {
- int i, j, b, c = 0;
- i = 4; j = 4; b = 7;
- #pragma omp simd linear(b:2) reduction(+:c)
- for (i = 0; i < 64; i++)
- {
- c = c + (b != 7 + 2 * i);
- b = b + 2;
- }
- if (c || i != 64 || b != 7 + 64 * 2)
- __builtin_abort ();
- i = 4; j = 4; b = 7;
- #pragma omp simd linear(b:3) reduction(+:c)
- for (i = 0; i < 64; i += 4)
- {
- c = c + (b != 7 + i / 4 * 3);
- b = b + 3;
- }
- if (c || i != 64 || b != 7 + 16 * 3)
- __builtin_abort ();
- i = 4; j = 4; b = 7;
- #pragma omp simd linear(i) linear(b:2) reduction(+:c)
- for (i = 0; i < 64; i++)
- {
- c = c + (b != 7 + 2 * i);
- b = b + 2;
- }
- if (c || i != 64 || b != 7 + 64 * 2)
- __builtin_abort ();
- i = 4; j = 4; b = 7;
- #pragma omp simd linear(i:4) linear(b:3) reduction(+:c)
- for (i = 0; i < 64; i += 4)
- {
- c = c + (b != 7 + i / 4 * 3);
- b = b + 3;
- }
- if (c || i != 64 || b != 7 + 16 * 3)
- __builtin_abort ();
- i = 4; j = 4; b = 7;
- #pragma omp simd collapse (2) linear(b:2) reduction(+:c)
- for (i = 0; i < 8; i++)
- for (j = 0; j < 8; j++)
- {
- c = c + (b != 7 + 2 * j + 2 * 8 * i);
- b = b + 2;
- }
- if (c || i != 8 || j != 8 || b != 7 + 64 * 2)
- __builtin_abort ();
- i = 4; j = 4; b = 7;
- #pragma omp simd collapse (2) lastprivate (i, j) linear(b:2) reduction(+:c)
- for (i = 0; i < 8; i++)
- for (j = 0; j < 8; j++)
- {
- c = c + (b != 7 + 2 * j + 2 * 8 * i);
- b = b + 2;
- }
- if (c || i != 8 || j != 8 || b != 7 + 64 * 2)
- __builtin_abort ();
- i = 4; j = 4; b = 7;
- #pragma omp parallel for simd schedule (static, 4) linear(b:2) reduction(+:c)
- for (i = 0; i < 64; i++)
- {
- c = c + (b != 7 + 2 * i);
- b = b + 2;
- }
- if (c || i != 64 || b != 7 + 64 * 2)
- __builtin_abort ();
- i = 4; j = 4; b = 7;
- #pragma omp parallel for simd schedule (static, 4) linear(b:3) reduction(+:c)
- for (i = 0; i < 64; i += 4)
- {
- c = c + (b != 7 + i / 4 * 3);
- b = b + 3;
- }
- if (c || i != 64 || b != 7 + 16 * 3)
- __builtin_abort ();
- i = 4; j = 4; b = 7;
- #pragma omp parallel for simd schedule (static, 4) linear(i) linear(b:2) reduction(+:c)
- for (i = 0; i < 64; i++)
- {
- c = c + (b != 7 + 2 * i);
- b = b + 2;
- }
- if (c || i != 64 || b != 7 + 64 * 2)
- __builtin_abort ();
- i = 4; j = 4; b = 7;
- #pragma omp parallel for simd schedule (static, 4) linear(i:4) linear(b:3) reduction(+:c)
- for (i = 0; i < 64; i += 4)
- {
- c = c + (b != 7 + i / 4 * 3);
- b = b + 3;
- }
- if (c || i != 64 || b != 7 + 16 * 3)
- __builtin_abort ();
- i = 4; j = 4; b = 7;
- #pragma omp parallel for simd lastprivate (i, j) collapse (2) schedule (static, 4) linear(b:2) reduction(+:c)
- for (i = 0; i < 8; i++)
- for (j = 0; j < 8; j++)
- {
- c = c + (b != 7 + 2 * j + 2 * 8 * i);
- b = b + 2;
- }
- if (c || i != 8 || j != 8 || b != 7 + 64 * 2)
- __builtin_abort ();
- i = 4; j = 4; b = 7;
- #pragma omp parallel for simd collapse (2) schedule (static, 4) linear(b:2) reduction(+:c)
- for (i = 0; i < 8; i++)
- for (j = 0; j < 8; j++)
- {
- c = c + (b != 7 + 2 * j + 2 * 8 * i);
- b = b + 2;
- }
- if (c || i != 8 || j != 8 || b != 7 + 64 * 2)
- __builtin_abort ();
- return 0;
- }
|