2  * Copyright (C) 2011 University of Szeged 
   3  * Copyright (C) 2011 Gabor Loki <loki@webkit.org> 
   6  * Redistribution and use in source and binary forms, with or without 
   7  * modification, are permitted provided that the following conditions 
   9  * 1. Redistributions of source code must retain the above copyright 
  10  *    notice, this list of conditions and the following disclaimer. 
  11  * 2. Redistributions in binary form must reproduce the above copyright 
  12  *    notice, this list of conditions and the following disclaimer in the 
  13  *    documentation and/or other materials provided with the distribution. 
  15  * THIS SOFTWARE IS PROVIDED BY UNIVERSITY OF SZEGED ``AS IS'' AND ANY 
  16  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 
  17  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 
  18  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL UNIVERSITY OF SZEGED OR 
  19  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 
  20  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, 
  21  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR 
  22  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY 
  23  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 
  24  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 
  25  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
  30 #if ENABLE(PARALLEL_JOBS) && ENABLE(THREADING_GENERIC) 
  32 #include "ParallelJobs.h" 
  36 Vector
< RefPtr
<ParallelEnvironment::ThreadPrivate
> >* ParallelEnvironment::s_threadPool 
= 0; 
  38 bool ParallelEnvironment::ThreadPrivate::tryLockFor(ParallelEnvironment
* parent
) 
  40     bool locked 
= m_mutex
.tryLock(); 
  51         m_threadID 
= createThread(&ParallelEnvironment::ThreadPrivate::workerThread
, this, "Parallel worker"); 
  60 void ParallelEnvironment::ThreadPrivate::execute(ThreadFunction threadFunction
, void* parameters
) 
  62     MutexLocker 
lock(m_mutex
); 
  64     m_threadFunction 
= threadFunction
; 
  65     m_parameters 
= parameters
; 
  67     m_threadCondition
.signal(); 
  70 void ParallelEnvironment::ThreadPrivate::waitForFinish() 
  72     MutexLocker 
lock(m_mutex
); 
  75         m_threadCondition
.wait(m_mutex
); 
  78 void* ParallelEnvironment::ThreadPrivate::workerThread(void* threadData
) 
  80     ThreadPrivate
* sharedThread 
= reinterpret_cast<ThreadPrivate
*>(threadData
); 
  81     MutexLocker 
lock(sharedThread
->m_mutex
); 
  83     while (sharedThread
->m_threadID
) { 
  84         if (sharedThread
->m_running
) { 
  85             (*sharedThread
->m_threadFunction
)(sharedThread
->m_parameters
); 
  86             sharedThread
->m_running 
= false; 
  87             sharedThread
->m_parent 
= 0; 
  88             sharedThread
->m_threadCondition
.signal(); 
  91         sharedThread
->m_threadCondition
.wait(sharedThread
->m_mutex
); 
  98 #endif // ENABLE(PARALLEL_JOBS) && ENABLE(THREADING_GENERIC)