Blame IlmThread/IlmThreadPool.h

Packit 8dc392
///////////////////////////////////////////////////////////////////////////
Packit 8dc392
//
Packit 8dc392
// Copyright (c) 2005-2012, Industrial Light & Magic, a division of Lucas
Packit 8dc392
// Digital Ltd. LLC
Packit 8dc392
// 
Packit 8dc392
// All rights reserved.
Packit 8dc392
// 
Packit 8dc392
// Redistribution and use in source and binary forms, with or without
Packit 8dc392
// modification, are permitted provided that the following conditions are
Packit 8dc392
// met:
Packit 8dc392
// *       Redistributions of source code must retain the above copyright
Packit 8dc392
// notice, this list of conditions and the following disclaimer.
Packit 8dc392
// *       Redistributions in binary form must reproduce the above
Packit 8dc392
// copyright notice, this list of conditions and the following disclaimer
Packit 8dc392
// in the documentation and/or other materials provided with the
Packit 8dc392
// distribution.
Packit 8dc392
// *       Neither the name of Industrial Light & Magic nor the names of
Packit 8dc392
// its contributors may be used to endorse or promote products derived
Packit 8dc392
// from this software without specific prior written permission. 
Packit 8dc392
// 
Packit 8dc392
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
Packit 8dc392
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
Packit 8dc392
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
Packit 8dc392
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
Packit 8dc392
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
Packit 8dc392
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
Packit 8dc392
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
Packit 8dc392
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
Packit 8dc392
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
Packit 8dc392
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
Packit 8dc392
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
Packit 8dc392
//
Packit 8dc392
///////////////////////////////////////////////////////////////////////////
Packit 8dc392
Packit 8dc392
#ifndef INCLUDED_ILM_THREAD_POOL_H
Packit 8dc392
#define INCLUDED_ILM_THREAD_POOL_H
Packit 8dc392
Packit 8dc392
Packit 8dc392
//-----------------------------------------------------------------------------
Packit 8dc392
//
Packit 8dc392
//	class Task, class ThreadPool, class TaskGroup
Packit 8dc392
//
Packit 8dc392
//	Class ThreadPool manages a set of worker threads and accepts
Packit 8dc392
//	tasks for processing.  Tasks added to the thread pool are
Packit 8dc392
//	executed concurrently by the worker threads.  
Packit 8dc392
//	
Packit 8dc392
//	Class Task provides an abstract interface for a task which
Packit 8dc392
//	a ThreadPool works on.  Derived classes need to implement the
Packit 8dc392
//	execute() function which performs the actual task.
Packit 8dc392
//
Packit 8dc392
//	Class TaskGroup allows synchronization on the completion of a set
Packit 8dc392
//	of tasks.  Every task that is added to a ThreadPool belongs to a
Packit 8dc392
//	single TaskGroup.  The destructor of the TaskGroup waits for all
Packit 8dc392
//	tasks in the group to finish.
Packit 8dc392
//
Packit 8dc392
//	Note: if you plan to use the ThreadPool interface in your own
Packit 8dc392
//	applications note that the implementation of the ThreadPool calls
Packit 8dc392
//	operator delete on tasks as they complete.  If you define a custom
Packit 8dc392
//	operator new for your tasks, for instance to use a custom heap,
Packit 8dc392
//	then you must also write an appropriate operator delete.
Packit 8dc392
//
Packit 8dc392
//-----------------------------------------------------------------------------
Packit 8dc392
Packit 8dc392
#include "IlmThreadNamespace.h"
Packit 8dc392
#include "IlmThreadExport.h"
Packit 8dc392
Packit 8dc392
ILMTHREAD_INTERNAL_NAMESPACE_HEADER_ENTER
Packit 8dc392
Packit 8dc392
class TaskGroup;
Packit 8dc392
class Task;
Packit 8dc392
Packit 8dc392
Packit 8dc392
class ILMTHREAD_EXPORT ThreadPool  
Packit 8dc392
{
Packit 8dc392
  public:
Packit 8dc392
Packit 8dc392
    //-------------------------------------------------------
Packit 8dc392
    // Constructor -- creates numThreads worker threads which
Packit 8dc392
    // wait until a task is available. 
Packit 8dc392
    //-------------------------------------------------------
Packit 8dc392
Packit 8dc392
    ThreadPool (unsigned numThreads = 0);
Packit 8dc392
    
Packit 8dc392
    
Packit 8dc392
    //-----------------------------------------------------------
Packit 8dc392
    // Destructor -- waits for all tasks to complete, joins all
Packit 8dc392
    // the threads to the calling thread, and then destroys them.
Packit 8dc392
    //-----------------------------------------------------------
Packit 8dc392
Packit 8dc392
    virtual ~ThreadPool ();
Packit 8dc392
    
Packit 8dc392
Packit 8dc392
    //--------------------------------------------------------
Packit 8dc392
    // Query and set the number of worker threads in the pool.
Packit 8dc392
    //
Packit 8dc392
    // Warning: never call setNumThreads from within a worker
Packit 8dc392
    // thread as this will almost certainly cause a deadlock
Packit 8dc392
    // or crash.
Packit 8dc392
    //--------------------------------------------------------
Packit 8dc392
    
Packit 8dc392
    int		numThreads () const;
Packit 8dc392
    void	setNumThreads (int count);
Packit 8dc392
    
Packit 8dc392
    
Packit 8dc392
    //------------------------------------------------------------
Packit 8dc392
    // Add a task for processing.  The ThreadPool can handle any
Packit 8dc392
    // number of tasks regardless of the number of worker threads.
Packit 8dc392
    // The tasks are first added onto a queue, and are executed
Packit 8dc392
    // by threads as they become available, in FIFO order.
Packit 8dc392
    //------------------------------------------------------------
Packit 8dc392
Packit 8dc392
    void addTask (Task* task);
Packit 8dc392
    
Packit 8dc392
Packit 8dc392
    //-------------------------------------------
Packit 8dc392
    // Access functions for the global threadpool
Packit 8dc392
    //-------------------------------------------
Packit 8dc392
    
Packit 8dc392
    static ThreadPool&	globalThreadPool ();
Packit 8dc392
    static void		addGlobalTask (Task* task);
Packit 8dc392
Packit 8dc392
    struct Data;
Packit 8dc392
Packit 8dc392
  protected:
Packit 8dc392
Packit 8dc392
    Data *		_data;
Packit 8dc392
};
Packit 8dc392
Packit 8dc392
Packit 8dc392
class ILMTHREAD_EXPORT Task
Packit 8dc392
{
Packit 8dc392
  public:
Packit 8dc392
Packit 8dc392
    Task (TaskGroup* g);
Packit 8dc392
    virtual ~Task ();
Packit 8dc392
Packit 8dc392
    virtual void	execute () = 0;
Packit 8dc392
    TaskGroup *		group();
Packit 8dc392
Packit 8dc392
  protected:
Packit 8dc392
Packit 8dc392
    TaskGroup *		_group;
Packit 8dc392
};
Packit 8dc392
Packit 8dc392
Packit 8dc392
class ILMTHREAD_EXPORT TaskGroup
Packit 8dc392
{
Packit 8dc392
  public:
Packit 8dc392
Packit 8dc392
    TaskGroup();
Packit 8dc392
    ~TaskGroup();
Packit 8dc392
Packit 8dc392
    struct Data;
Packit 8dc392
    Data* const		_data;
Packit 8dc392
};
Packit 8dc392
Packit 8dc392
Packit 8dc392
ILMTHREAD_INTERNAL_NAMESPACE_HEADER_EXIT
Packit 8dc392
Packit 8dc392
#endif // INCLUDED_ILM_THREAD_POOL_H