// @(#)root/thread:$Id: TMutex.cxx 29797 2009-08-17 14:35:51Z rdm $ // Author: Fons Rademakers 26/06/97 /************************************************************************* * Copyright (C) 1995-2000, Rene Brun and Fons Rademakers. * * All rights reserved. * * * * For the licensing terms see $ROOTSYS/LICENSE. * * For the list of contributors see $ROOTSYS/README/CREDITS. * *************************************************************************/ ////////////////////////////////////////////////////////////////////////// // // // TMutex // // // // This class implements mutex locks. A mutex is a mutual exclusive // // lock. The actual work is done via the TMutexImp class (either // // TPosixMutex or TWin32Mutex). // // // ////////////////////////////////////////////////////////////////////////// #include "TInterpreter.h" #include "TMutex.h" #include "TThreadFactory.h" #include <errno.h> ClassImp(TMutex) //______________________________________________________________________________ TMutex::TMutex(Bool_t recursive) { // Create a mutex lock. The actual mutex implementation will be // provided via the TThreadFactory. fMutexImp = gThreadFactory->CreateMutexImp(recursive); if (!fMutexImp) Error("TMutex", "could not create TMutexImp"); } //______________________________________________________________________________ Int_t TMutex::Lock() { // Lock the mutex. Returns 0 when no error, EDEADLK when mutex was already // locked by this thread and this mutex is not reentrant. Int_t iret = fMutexImp->Lock(); return iret; } //______________________________________________________________________________ Int_t TMutex::TryLock() { // Try to lock mutex. Returns 0 when no error, EDEADLK when mutex was // already locked by this thread and this mutex is not reentrant. Int_t iret = fMutexImp->TryLock(); return iret; } //______________________________________________________________________________ Int_t TMutex::UnLock() { // Unlock the mutex. Returns 0 when no error, EPERM when mutex was already // unlocked by this thread. return fMutexImp->UnLock(); } //______________________________________________________________________________ Int_t TMutex::CleanUp() { // Clean up of mutex. return UnLock(); } //______________________________________________________________________________ TVirtualMutex *TMutex::Factory(Bool_t recursive) { // Create mutex and return pointer to it. Calling function must care // about proper deletion. The function is intended to be used in connection // with the R__LOCKGUARD2 macro for local thread protection. Since "new" is // used the TStorage class has to be protected by gGlobalMutex. TVirtualMutex *ret = new TMutex(recursive); return ret; }