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

PsnRelaxedMemoryManager.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 PsnRelaxedMemoryManagerHEADER
00019 #define PsnRelaxedMemoryManagerHEADER
00020 
00021 #ifdef _SGI
00022 #include <list.h>
00023 #else
00024 #include <list>
00025 #endif
00026 
00027 #include <sys/time.h>
00028 #include <time.h>
00029 
00030 class PsnMemoryElementDescriptor; 
00031 class PsnLock;
00032 
00033 #include <PsnSharedMemoryManager.h>
00034 class PsnSharedFreeStoreMemoryManager ;
00035 class PsnSharedArrayMemoryManager ;
00036 class PsnLatencySyncedSharedMemoryManager ;
00037 class PsnOnceSyncedSharedMemoryManager ;
00038 class PsnUniqueCreator ;
00039 
00040 
00046 using namespace std ;
00047 
00048 class PsnRelaxedMemoryManager : public PsnSharedMemoryManager {
00049 public:
00053    PsnRelaxedMemoryManager(void * startDsm, size_t sizeDsm, size_t pageSize, PsnUniqueCreator * creator, int queueSize);
00056    virtual ~PsnRelaxedMemoryManager();
00057 
00059    virtual void sync() ;
00060 
00062    virtual void strongSync() ;
00063 
00065    virtual void strongSynchronizeRegion(unsigned int startRegion, size_t sizeRegion) ;
00066 
00071    virtual void synchronizeAfterLock(void* beginningAdress, long length);
00072 
00074    enum PageState { Free , StepSync , LatencySync , Allocated } ; 
00075 
00076 
00077    //-------------- fonction spéciales d'allocation ----------------------//
00078 
00080    virtual void * mRelaxedMalloc ( size_t size ) ;
00081 
00083    virtual void mRelaxedFree (void * ptr, size_t size) ;
00084 
00086    virtual void * mSyncMalloc ( size_t size ) ;
00087 
00089    virtual void mSyncFree (void * ptr, size_t size) ;
00090  
00093    virtual void *allocateSizeRemembered (size_t size) ;
00094 
00096    virtual void freeSizeRemembered ( void * ptr) ;
00097 
00099    virtual void * mmallocInPages (size_t size, unsigned int * initialOffsetForWrite, size_t * stepSize) ;
00100 
00102    virtual void mfreeInPages(void * ptr, size_t size) ;
00103 
00105    virtual void * mmallocForOnce ( size_t size ) ;
00106 
00108    virtual void mfreeForOnce(void * ptr, size_t size) ;
00109 
00112    virtual void anticipateFreeStoreAllocation(int frame) ;
00113 
00115    static inline int getWritableQueueIndex()  {
00116       return _writableQueueIndex ;
00117    }
00118 
00120    static inline int getNextSyncedQueueIndex()  {
00121       return _nextSyncedQueueIndex ;
00122    }
00123 
00125    static inline int getReadableQueueIndex()  {
00126       return _readableQueueIndex ;
00127    }
00128 
00129 protected:
00131    virtual void * mLatencyMalloc(size_t size, list < PsnLatencySyncedSharedMemoryManager *> & memoryManagerList, int latency) ;
00132 
00134    virtual void mLatencyFree(void * ptr, size_t size, list < PsnLatencySyncedSharedMemoryManager * > & memoryManagerList) ;
00135 
00136 
00140    virtual void lock();
00141 
00144    virtual void unlock();
00145 
00147    virtual bool lockNeeded ( ) ;
00148 
00153    virtual void * getFromFree ( size_t size );
00154 
00159    virtual void addInFree (void *addr, size_t size);
00160 
00162    PsnLock * _myLock;
00163 
00165    PageState * _pageState ;
00166 
00168    bool * _myPage ;
00169 
00171    int * _whenSynced ;
00172 
00174    friend class PsnFramedMemoryManager ;
00175    friend class PsnLatencySyncedSharedMemoryManager;
00176    friend class PsnOnceSyncedSharedMemoryManager;
00178    int _numberOfManagedPages ;
00179 
00181    int _firstFreePage ;
00182 
00184    PsnUniqueCreator * const _myCreator ;
00185 
00187    list < PsnSharedFreeStoreMemoryManager * > freeStoreManagers ;
00188 
00190    list < PsnSharedArrayMemoryManager * > sharedArrayManagers ;
00191 
00193    list < PsnLatencySyncedSharedMemoryManager * > stepSyncedMemoryManagers ;
00194 
00196    list < PsnLatencySyncedSharedMemoryManager * > relaxedSyncedMemoryManagers ;
00197 
00199    list < PsnOnceSyncedSharedMemoryManager * > onceSyncedMemoryManagers ;
00200 
00202    static int _readableQueueIndex ;
00203 
00205    static int _writableQueueIndex ;
00206 
00208    static int _nextSyncedQueueIndex ;
00209 
00211    const int _queueSize ;
00212 
00214    virtual void syncSecondaryMemoryManagers() ;
00215 
00216 public:
00217    virtual void syncStepSyncedMemory() ;
00218 
00219 protected:
00220    /* the frame current free store allocation needs to be ready for 
00221     * -1 meens next writable frame */
00222    int _frameForFreeStoreAllocation ;
00223 
00225    unsigned long * oldSyncDate ;
00226 
00228    bool _lockIsNeeded ;
00229 
00231    long _timelost ;
00232    timeval _dateReelleDebut ;
00233    timeval _dateReelleFin ;
00234    
00235 
00236 };
00237 
00238 #endif
00239 
00240 
00241 
00242 

logo OpenMask

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

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