Why do c++11 threads become unjoinable when using nested OpenMP pragmas?

前端 未结 1 511
感动是毒
感动是毒 2021-01-18 09:09

The following code should be pretty straightforward but seems to end up in a hanging situation when trying to do a .join() on the threads with nested OpenMP code. Using GCC

1条回答
  •  慢半拍i
    慢半拍i (楼主)
    2021-01-18 10:07

    Mixing OpenMP and any other threading library (pthreads, Win32 threading, etc.) might not be a good idea. The OpenMP run-time might be written with the presumption that it is fully in control of threading and might not support parallel regions being run concurrently (e.g. it might use global variables like semaphores to control the thread pools).

    A better pure OpenMP way to implement this would be:

    #include 
    #include 
    
    using namespace std;
    
    void hello(int a) {
    
        #pragma omp parallel for
        for (int i=0;i<5;++i) {
            #pragma omp critical
            cout << "Hello from " << a << "! " << "OMP thread iter " << i << endl;
        }
    
        cout << "About to return from hello function" << endl;
    }
    
    int main (int argc, char ** argv) {
    
        omp_set_nested(1);
    
        #pragma omp parallel sections num_threads(2)
        {
           #pragma omp section
           {
               hello(1);
           }
           #pragma omp section
           {
               hello(2);
           }
        }
    
        return 0;
    }
    

    The call to omp_set_nested() is needed in order to enable nested parallelism which is disabled by default.

    0 讨论(0)
提交回复
热议问题