Main Page   Namespace List   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members   File Members  

PsnMultiThreadedScheduler.h

Go to the documentation of this file.
00001 /*
00002  * This file is part of openMask © INRIA, CNRS, Universite de Rennes 1 1993-2002, thereinafter the Software
00003  * 
00004  * The Software has been developped within the Siames Project. 
00005  * INRIA, the University of Rennes 1 and CNRS jointly hold intellectual property rights
00006  * 
00007  * The Software has been registered with the Agence pour la Protection des
00008  * Programmes (APP) under registration number IDDN.FR.001.510008.00.S.P.2001.000.41200
00009  *
00010  * This file may be distributed under the terms of the Q Public License
00011  * version 1.0 as defined by Trolltech AS of Norway and appearing in the file
00012  * LICENSE.QPL included in the packaging of this file.
00013  *
00014  * Licensees holding valid specific licenses issued by INRIA, CNRS or Université de Rennes 1 
00015  * for the software may use this file in accordance with that specific license 
00016  *
00017  */
00018 #ifndef PsnMultiThreadedSchedulerHEADER
00019 #define PsnMultiThreadedSchedulerHEADER
00020 
00021 #include "PsnScheduler.h"
00022 #include <pthread.h>
00023 #include <map>
00024 #include <vector>
00025 
00026 //include this for profiling
00027 #include <sys/time.h>
00028 
00029 class PsnFrameScheduler ;
00030 class PsnBarrier ;
00031 
00037 class PsnMultiThreadedScheduler : public PsnScheduler 
00038 {
00039 public:
00045    PsnMultiThreadedScheduler(unsigned int numberOfSteps, unsigned int numberOfThreads, bool createThreadAndLocalSchedulers ) ;
00046 
00047 
00049    virtual ~PsnMultiThreadedScheduler() ;
00050 
00052    virtual void addToScheduable (PsnReferenceObjectHandle * ref, unsigned int when) ;
00053 
00055    virtual void addToScheduable (PsnReferenceObjectHandle * ref, unsigned int when, unsigned int whichThread) ;
00056 
00058    virtual void removeFromScheduable (PsnReferenceObjectHandle * ref) ;
00059 
00061    virtual void schedule(PsnReferenceObjectHandle * ref) ;
00062 
00064    virtual void unschedule(PsnReferenceObjectHandle * ref) ;
00065 
00067    virtual void runStep (unsigned int which) ;
00068 
00070    virtual void run ( unsigned int whichFrameScheduler ) ;
00071 
00072 protected:
00074    static void * _threadContainer ( void * ) ;
00075    
00077    unsigned int _currentStep ;
00078 
00080    unsigned int _numberOfThreads ;
00081 
00083    vector <PsnScheduler * > * _localSchedulers ;
00084 
00086    PsnScheduler * _duplicatedObjectScheduler ;
00087 
00089    PsnBarrier * _barrier ;
00090 
00092    unsigned int _nextThreadForScheduling ;
00093 
00095    map<PsnReferenceObjectHandle *, unsigned int> _whichThread ;
00096 
00098    pthread_t  * _threadIds ;   
00099 
00101    itimerval  * _profilingTimer;   
00102 
00104    vector <pair<PsnScheduler *, unsigned int> * > * _threadData ;
00105 
00107    long * * _localWaitingTimes ;
00108 
00110    int _numberOfSamples ;
00111 };
00112 
00113 #endif

logo OpenMask

Documentation generated on Mon Nov 25 15:25:01 2002

Generated with doxygen 1.2.12 by Dimitri van Heesch ,   1997-2001