view libgomp/testsuite/libgomp.c/pr35130.c @ 0:a06113de4d67

first commit
author kent <kent@cr.ie.u-ryukyu.ac.jp>
date Fri, 17 Jul 2009 14:47:48 +0900
parents
children
line wrap: on
line source

/* PR middle-end/35130 */

extern void abort (void);

void
f1 (void)
{
  int a[4], k;
  void nested (int x)
  {
    a[x] = 42;
  }

  for (k = 0; k < 4; k++)
    a[k] = 0;
#pragma omp parallel for
  for (k = 0; k < 4; k++)
    nested (k);

  if (a[0] != 42 || a[1] != 42 || a[2] != 42 || a[3] != 42)
    abort ();
}

void
f2 (void)
{
  int a[4], k;
  void nested (void)
  {
    int l;
    void nested2 (int x)
    {
      a[x] = 42;
    }
#pragma omp parallel for
    for (l = 0; l < 4; l++)
      nested2 (l);
  }

  for (k = 0; k < 4; k++)
    a[k] = 0;

  nested ();

  if (a[0] != 42 || a[1] != 42 || a[2] != 42 || a[3] != 42)
    abort ();
}

void
f3 (void)
{
  int a[4], b[4], c[4], k;
  void nested (int x)
  {
    a[x] = b[x] = c[x] = 42;
  }

  for (k = 0; k < 4; k++)
    a[k] = b[k] = c[k] = 0;
  nested (0);

#pragma omp parallel
  {
  #pragma omp single
    {
      a[1] = 43;
      b[1] = 43;
    }
  #pragma omp parallel
    {
    #pragma omp single
      {
	b[2] = 44;
	c[2] = 44;
      }
    }
  }

  if (a[0] != 42 || a[1] != 43 || a[2] != 0 || a[3] != 0)
    abort ();
  if (b[0] != 42 || b[1] != 43 || b[2] != 44 || b[3] != 0)
    abort ();
  if (c[0] != 42 || c[1] != 0 || c[2] != 44 || c[3] != 0)
    abort ();
}

void
f4 (void)
{
  int a[4], b[4], c[4], k;
  void nested ()
  {
  #pragma omp parallel
    {
    #pragma omp single
      {
	a[1] = 43;
	b[1] = 43;
      }
    #pragma omp parallel
      {
      #pragma omp single
	{
	  b[2] = 44;
	  c[2] = 44;
	}
      }
    }
  }

  for (k = 0; k < 4; k++)
    a[k] = b[k] = c[k] = k == 0 ? 42 : 0;
  nested ();

  if (a[0] != 42 || a[1] != 43 || a[2] != 0 || a[3] != 0)
    abort ();
  if (b[0] != 42 || b[1] != 43 || b[2] != 44 || b[3] != 0)
    abort ();
  if (c[0] != 42 || c[1] != 0 || c[2] != 44 || c[3] != 0)
    abort ();
}

int
main (void)
{
  f1 ();
  f2 ();
  f3 ();
  f4 ();
  return 0;
}