mirror of
https://github.com/autc04/Retro68.git
synced 2024-11-28 05:51:04 +00:00
65 lines
1.1 KiB
C
65 lines
1.1 KiB
C
/* PR middle-end/30494 */
|
|
/* { dg-do run } */
|
|
|
|
#include <omp.h>
|
|
|
|
int errors;
|
|
|
|
int
|
|
check (int m, int i, int *v, int *w)
|
|
{
|
|
int j;
|
|
int n = omp_get_thread_num ();
|
|
for (j = 0; j < m; j++)
|
|
if (v[j] != j + n)
|
|
#pragma omp atomic
|
|
errors += 1;
|
|
for (j = 0; j < m * 3 + i; j++)
|
|
if (w[j] != j + 10 + n)
|
|
#pragma omp atomic
|
|
errors += 1;
|
|
}
|
|
|
|
int
|
|
foo (int n, int m)
|
|
{
|
|
int i;
|
|
#pragma omp for
|
|
for (i = 0; i < 6; i++)
|
|
{
|
|
int v[n], w[n * 3 + i], j;
|
|
for (j = 0; j < n; j++)
|
|
v[j] = j + omp_get_thread_num ();
|
|
for (j = 0; j < n * 3 + i; j++)
|
|
w[j] = j + 10 + omp_get_thread_num ();
|
|
check (m, i, v, w);
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
int
|
|
bar (int n, int m)
|
|
{
|
|
int i;
|
|
#pragma omp parallel for num_threads (4)
|
|
for (i = 0; i < 6; i++)
|
|
{
|
|
int v[n], w[n * 3 + i], j;
|
|
for (j = 0; j < n; j++)
|
|
v[j] = j + omp_get_thread_num ();
|
|
for (j = 0; j < n * 3 + i; j++)
|
|
w[j] = j + 10 + omp_get_thread_num ();
|
|
check (m, i, v, w);
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
int
|
|
main (void)
|
|
{
|
|
#pragma omp parallel num_threads (3)
|
|
foo (128, 128);
|
|
bar (256, 256);
|
|
return 0;
|
|
}
|