34#define HAVE_STRUCT_TIMESPEC 1
46#include <mach/clock.h>
51 template<
typename TYPE >
52 void get_apple_realtime( TYPE & wait )
55 clock_gettime(CLOCK_REALTIME, &wait);
59 host_get_clock_service(mach_host_self(), CALENDAR_CLOCK, &cclock);
60 clock_get_time(cclock, &mts);
61 mach_port_deallocate(mach_task_self(), cclock);
62 wait.tv_sec = mts.tv_sec;
63 wait.tv_nsec = mts.tv_nsec;
85 pthread_cond_signal(&
cvar);
90 pthread_cond_broadcast(&
cvar);
102 ) {pthread_cond_init(&
cvar, NULL);
103 pthread_mutex_init(&
cmut, NULL);
107 pthread_mutex_destroy(&
cmut);
143 {
if (CndVar) CndVar->Lock();
170 {
if (pthread_mutex_trylock( &
cs ))
return 0;
176 struct timespec wait, cur, dur;
177 get_apple_realtime(wait);
178 wait.tv_sec += (wait_ms / 1000);
179 wait.tv_nsec += (wait_ms % 1000) * 1000000;
180 wait.tv_sec += (wait.tv_nsec / 1000000000);
181 wait.tv_nsec = wait.tv_nsec % 1000000000;
184 while( ( rc = pthread_mutex_trylock( &
cs ) ) == EBUSY )
186 get_apple_realtime(cur);
187 if( ( cur.tv_sec > wait.tv_sec ) ||
188 ( ( cur.tv_sec == wait.tv_sec ) && ( cur.tv_nsec >= wait.tv_nsec ) ) )
191 dur.tv_sec = wait.tv_sec - cur.tv_sec;
192 dur.tv_nsec = wait.tv_nsec - cur.tv_nsec;
193 if( dur.tv_nsec < 0 )
196 dur.tv_nsec += 1000000000;
199 if( ( dur.tv_sec != 0 ) || ( dur.tv_nsec > 1000000 ) )
202 dur.tv_nsec = 1000000;
205 nanosleep( &dur, 0 );
212 {
struct timespec wait;
213 clock_gettime(CLOCK_REALTIME, &wait);
214 wait.tv_sec += (wait_ms / 1000);
215 wait.tv_nsec += (wait_ms % 1000) * 1000000;
216 wait.tv_sec += (wait.tv_nsec / 1000000000);
217 wait.tv_nsec = wait.tv_nsec % 1000000000;
218 return !pthread_mutex_timedlock(&
cs, &wait);
222inline void Lock() {pthread_mutex_lock(&
cs);}
277 {
if (mutex) mutex->Lock();
312 {pthread_cond_init(&
cvar, NULL);}
334 {
if (pthread_rwlock_tryrdlock( &
lock ))
return 0;
338 {
if (pthread_rwlock_trywrlock( &
lock ))
return 0;
345inline void ReadLock(
int &status ) {status = pthread_rwlock_rdlock(&
lock);}
346inline void WriteLock(
int &status ) {status = pthread_rwlock_wrlock(&
lock);}
354#if defined(__linux__) && (defined(__GLIBC__) || defined(__UCLIBC__))
355 pthread_rwlockattr_t attr;
356 pthread_rwlockattr_setkind_np(&attr,
357 PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP);
358 pthread_rwlock_init(&
lock, &attr);
360 pthread_rwlock_init(&
lock, NULL);
369 pthread_rwlock_destroy(&
lock);
370#if defined(__linux__) && (defined(__GLIBC__) || defined(__UCLIBC__))
371 pthread_rwlockattr_t attr;
372 pthread_rwlockattr_setkind_np(&attr,
373 PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP);
374 pthread_rwlock_init(&
lock, &attr);
376 pthread_rwlock_init(&
lock, NULL);
382 pthread_rwlock_destroy(&
lock);
383 pthread_rwlock_init(&
lock, NULL);
413 {
if (l) {
if (rd) l->ReadLock();
467#if defined(__APPLE__) || defined(__GNU__)
478static void CleanUp(
void *semVar);
481 {semVal = semval; semWait = 0;}
499 {
if (errno == EAGAIN)
return 0;
500 if (errno != EINTR) {
throw "sem_CondWait() failed";}
506 {
throw "sem_post() failed";}
511 {
throw "sem_wait() failed";}
517 {
throw "sem_init() failed";}
543#define XRDSYSTHREAD_BIND 0x001
548#define XRDSYSTHREAD_HOLD 0x002
554static int Cancel(pthread_t tid) {
return pthread_cancel(tid);}
556static int Detach(pthread_t tid) {
return pthread_detach(tid);}
560 return pthread_setcancelstate(PTHREAD_CANCEL_DISABLE, 0);
563static int Join(pthread_t tid,
void **ret) {
564 return pthread_join(tid, ret);
568 return pthread_setcancelstate(PTHREAD_CANCEL_ENABLE, 0);
572 return pthread_setcanceltype(PTHREAD_CANCEL_ASYNCHRONOUS, 0);
576 return pthread_setcanceltype(PTHREAD_CANCEL_DEFERRED, 0);
580 pthread_testcancel();
584static pthread_t
ID(
void) {
return pthread_self();}
586static int Kill(pthread_t tid) {
return pthread_cancel(tid);}
588static unsigned long Num(
void);
590static int Run(pthread_t *,
void *(*proc)(
void *),
void *arg,
591 int opts=0,
const char *desc = 0);
593static int Same(pthread_t t1, pthread_t t2)
594 {
return pthread_equal(t1, t2);}
600static int Signal(pthread_t tid,
int snum)
601 {
return pthread_kill(tid, snum);}
Definition XrdSysPthread.hh:300
pthread_mutex_t * mtxP
Definition XrdSysPthread.hh:319
int Wait()
Definition XrdSysPthread.hh:307
pthread_cond_t cvar
Definition XrdSysPthread.hh:318
~XrdSysCondVar2()
Definition XrdSysPthread.hh:314
void Signal()
Definition XrdSysPthread.hh:303
void Broadcast()
Definition XrdSysPthread.hh:305
XrdSysCondVar2(XrdSysMutex &mtx)
Definition XrdSysPthread.hh:311
bool Wait(int sec)
Definition XrdSysPthread.hh:308
Definition XrdSysPthread.hh:129
void UnLock()
Definition XrdSysPthread.hh:140
void Lock(XrdSysCondVar *CndVar)
Definition XrdSysPthread.hh:132
XrdSysCondVar * cnd
Definition XrdSysPthread.hh:153
~XrdSysCondVarHelper()
Definition XrdSysPthread.hh:151
XrdSysCondVarHelper(XrdSysCondVar *CndVar=0)
Definition XrdSysPthread.hh:142
XrdSysCondVarHelper(XrdSysCondVar &CndVar)
Definition XrdSysPthread.hh:146
Definition XrdSysPthread.hh:79
XrdSysCondVar(int relm=1, const char *cid=0)
Definition XrdSysPthread.hh:100
~XrdSysCondVar()
Definition XrdSysPthread.hh:106
const char * condID
Definition XrdSysPthread.hh:114
void UnLock()
Definition XrdSysPthread.hh:94
pthread_cond_t cvar
Definition XrdSysPthread.hh:111
void Lock()
Definition XrdSysPthread.hh:82
void Signal()
Definition XrdSysPthread.hh:84
int relMutex
Definition XrdSysPthread.hh:113
void Broadcast()
Definition XrdSysPthread.hh:89
pthread_mutex_t cmut
Definition XrdSysPthread.hh:112
Definition XrdSysError.hh:90
Definition XrdSysPthread.hh:434
void UnLock()
Definition XrdSysPthread.hh:443
XrdSysRWLock * rwLok
Definition XrdSysPthread.hh:454
~XrdSysFusedMutex()
Definition XrdSysPthread.hh:451
void Lock()
Definition XrdSysPthread.hh:437
XrdSysFusedMutex(XrdSysMutex &mtx)
Definition XrdSysPthread.hh:448
bool isRW
Definition XrdSysPthread.hh:455
XrdSysMutex * mutex
Definition XrdSysPthread.hh:454
XrdSysFusedMutex(XrdSysRWLock &mtx)
Definition XrdSysPthread.hh:445
void ReadLock()
Definition XrdSysPthread.hh:439
void WriteLock()
Definition XrdSysPthread.hh:441
Definition XrdSysPthread.hh:263
XrdSysMutexHelper(XrdSysMutex *mutex=0)
Definition XrdSysPthread.hh:276
void UnLock()
Definition XrdSysPthread.hh:274
~XrdSysMutexHelper()
Definition XrdSysPthread.hh:285
void Lock(XrdSysMutex *Mutex)
Definition XrdSysPthread.hh:266
XrdSysMutexHelper(XrdSysMutex &mutex)
Definition XrdSysPthread.hh:280
XrdSysMutex * mtx
Definition XrdSysPthread.hh:287
Definition XrdSysPthread.hh:165
XrdSysMutex()
Definition XrdSysPthread.hh:226
pthread_mutex_t cs
Definition XrdSysPthread.hh:231
int CondLock()
Definition XrdSysPthread.hh:169
void Lock()
Definition XrdSysPthread.hh:222
~XrdSysMutex()
Definition XrdSysPthread.hh:227
int TimedLock(int wait_ms)
Definition XrdSysPthread.hh:211
void UnLock()
Definition XrdSysPthread.hh:224
Definition XrdSysPthread.hh:398
XrdSysRWLockHelper(XrdSysRWLock *l=0, bool rd=1)
Definition XrdSysPthread.hh:412
void Lock(XrdSysRWLock *lock, bool rd=1)
Definition XrdSysPthread.hh:401
void UnLock()
Definition XrdSysPthread.hh:410
XrdSysRWLock * lck
Definition XrdSysPthread.hh:426
~XrdSysRWLockHelper()
Definition XrdSysPthread.hh:424
XrdSysRWLockHelper(XrdSysRWLock &l, bool rd=1)
Definition XrdSysPthread.hh:418
Definition XrdSysPthread.hh:330
void ReadLock()
Definition XrdSysPthread.hh:342
void ReadLock(int &status)
Definition XrdSysPthread.hh:345
void WriteLock()
Definition XrdSysPthread.hh:343
void ReInitialize()
Definition XrdSysPthread.hh:380
int CondWriteLock()
Definition XrdSysPthread.hh:337
XrdSysRWLock(PrefType ptype)
Definition XrdSysPthread.hh:352
void ReInitialize(PrefType ptype)
Definition XrdSysPthread.hh:367
PrefType
Definition XrdSysPthread.hh:350
@ prefWR
Definition XrdSysPthread.hh:350
void UnLock()
Definition XrdSysPthread.hh:348
pthread_rwlock_t lock
Definition XrdSysPthread.hh:388
void WriteLock(int &status)
Definition XrdSysPthread.hh:346
~XrdSysRWLock()
Definition XrdSysPthread.hh:365
XrdSysRWLock()
Definition XrdSysPthread.hh:364
int CondReadLock()
Definition XrdSysPthread.hh:333
Definition XrdSysPthread.hh:242
Definition XrdSysPthread.hh:494
void Wait()
Definition XrdSysPthread.hh:509
void Post()
Definition XrdSysPthread.hh:505
~XrdSysSemaphore()
Definition XrdSysPthread.hh:519
int CondWait()
Definition XrdSysPthread.hh:497
sem_t h_semaphore
Definition XrdSysPthread.hh:525
XrdSysSemaphore(int semval=1, const char *=0)
Definition XrdSysPthread.hh:515
Definition XrdSysPthread.hh:551
static void setDebug(XrdSysError *erp)
Definition XrdSysPthread.hh:596
static unsigned long Num(void)
static void CancelPoint()
Definition XrdSysPthread.hh:579
static int Same(pthread_t t1, pthread_t t2)
Definition XrdSysPthread.hh:593
static int SetCancelAsynchronous()
Definition XrdSysPthread.hh:571
static int Join(pthread_t tid, void **ret)
Definition XrdSysPthread.hh:563
static void setStackSize(size_t stsz, bool force=false)
static int Cancel(pthread_t tid)
Definition XrdSysPthread.hh:554
XrdSysThread()
Definition XrdSysPthread.hh:605
static int SetCancelOn()
Definition XrdSysPthread.hh:567
~XrdSysThread()
Definition XrdSysPthread.hh:606
static pthread_t ID(void)
Definition XrdSysPthread.hh:584
static int Signal(pthread_t tid, int snum)
Definition XrdSysPthread.hh:600
static size_t stackSize
Definition XrdSysPthread.hh:610
static int Run(pthread_t *, void *(*proc)(void *), void *arg, int opts=0, const char *desc=0)
static int Wait(pthread_t tid)
static int Kill(pthread_t tid)
Definition XrdSysPthread.hh:586
static int Detach(pthread_t tid)
Definition XrdSysPthread.hh:556
static XrdSysError * eDest
Definition XrdSysPthread.hh:609
static int SetCancelOff()
Definition XrdSysPthread.hh:559
static int SetCancelDeferred()
Definition XrdSysPthread.hh:575