[llvm-bugs] [Bug 37580] New: Handling doacross loops: no collapse

via llvm-bugs llvm-bugs at lists.llvm.org
Thu May 24 07:42:09 PDT 2018


https://bugs.llvm.org/show_bug.cgi?id=37580

            Bug ID: 37580
           Summary: Handling doacross loops: no collapse
           Product: OpenMP
           Version: unspecified
          Hardware: PC
                OS: Linux
            Status: NEW
          Severity: enhancement
          Priority: P
         Component: Clang Compiler Support
          Assignee: unassignedclangbugs at nondot.org
          Reporter: protze at itc.rwth-aachen.de
                CC: llvm-bugs at lists.llvm.org

#include <stdio.h>
#include <omp.h>
int main()
{
  int i, j;
#pragma omp parallel for ordered(2) num_threads(2) schedule(static,1) \
                                                   private(i,j)
  for (i = 0; i < 10; i++)
    for (j = 0; j < 10; j++)
    {
#pragma omp ordered depend(sink:i-1,j) depend (sink:i,j-1)
      printf ("test %i i=%d j=%d\n",omp_get_thread_num(),i,j);
#pragma omp ordered depend(source)
    }
  return 0;
}


According to the OpenMP spec, this code should execute i=0 and i=2 on thread 0
and i=1, i=3 on thread 1. The ordered(2) clause does not change the scheduling.
The behavior of clang looks like collapse(2) is implied.

-> expected behavior: i is distributed between the threads, 
-> observed behavior: j is distributed between the threads.


Since icc in combination with the same (LLVM) OpenMP runtime provides correct
behavior (besides a bug in privatization of j), this should be a compiler bug
in clang.

Also, explicitly adding collapse(1) does not help.

-- 
You are receiving this mail because:
You are on the CC list for the bug.
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.llvm.org/pipermail/llvm-bugs/attachments/20180524/4f19c42d/attachment-0001.html>


More information about the llvm-bugs mailing list