aboutsummaryrefslogtreecommitdiff
path: root/rc3/runtime/test/parallel/omp_nested.c
diff options
context:
space:
mode:
Diffstat (limited to 'rc3/runtime/test/parallel/omp_nested.c')
-rw-r--r--rc3/runtime/test/parallel/omp_nested.c48
1 files changed, 48 insertions, 0 deletions
diff --git a/rc3/runtime/test/parallel/omp_nested.c b/rc3/runtime/test/parallel/omp_nested.c
new file mode 100644
index 0000000..d2d5b08
--- /dev/null
+++ b/rc3/runtime/test/parallel/omp_nested.c
@@ -0,0 +1,48 @@
+// RUN: %libomp-compile-and-run
+#include <stdio.h>
+#include "omp_testsuite.h"
+
+/*
+ * Test if the compiler supports nested parallelism
+ * By Chunhua Liao, University of Houston
+ * Oct. 2005
+ */
+int test_omp_nested()
+{
+#ifdef _OPENMP
+ if (omp_get_max_threads() > 4)
+ omp_set_num_threads(4);
+ if (omp_get_max_threads() < 2)
+ omp_set_num_threads(2);
+#endif
+
+ int counter = 0;
+#ifdef _OPENMP
+ omp_set_nested(1);
+#endif
+
+ #pragma omp parallel shared(counter)
+ {
+ #pragma omp critical
+ counter++;
+ #pragma omp parallel
+ {
+ #pragma omp critical
+ counter--;
+ }
+ }
+ return (counter != 0);
+}
+
+int main()
+{
+ int i;
+ int num_failed=0;
+
+ for(i = 0; i < REPETITIONS; i++) {
+ if(!test_omp_nested()) {
+ num_failed++;
+ }
+ }
+ return num_failed;
+}