8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-27 20:43:03 +01:00
firebird-mirror/src/common/classes/locks.h

197 lines
4.6 KiB
C
Raw Normal View History

/*
* PROGRAM: Client/Server Common Code
* MODULE: locks.h
* DESCRIPTION: Single-state locks
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
* You may obtain a copy of the Licence at
* http://www.gnu.org/licences/lgpl.html
*
* As a special exception this file can also be included in modules
* with other source code as long as that source code has been
* released under an Open Source Initiative certificed licence.
* More information about OSI certification can be found at:
* http://www.opensource.org
*
* This module is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Lesser General Public Licence for more details.
*
* This module was created by members of the firebird development
* team. All individual contributions remain the Copyright (C) of
* those individuals and all rights are reserved. Contributors to
* this file are either listed below or can be obtained from a CVS
* history command.
*
* Created by: Nickolay Samofatov <skidder@bssys.com>
*
* Contributor(s):
*
*
* $Id: locks.h,v 1.16 2004-06-11 14:23:24 kkuznetsov Exp $
*
*/
2004-03-07 08:58:55 +01:00
#ifndef CLASSES_LOCKS_H
#define CLASSES_LOCKS_H
#include "firebird.h"
#ifdef MULTI_THREAD
#ifdef WIN_NT
// It is relatively easy to avoid using this header. Maybe do the same stuff like
// in thd.h ? This is Windows platform maintainers choice
#include <windows.h>
#else
#ifndef SOLARIS
#include <pthread.h>
#else
#include <thread.h>
#include <synch.h>
#endif
#endif
#endif /* MULTI_THREAD */
namespace Firebird {
#ifdef MULTI_THREAD
#ifdef WIN_NT
/* Process-local spinlock. Used to manage memory heaps in threaded environment. */
// Windows version of the class
2003-01-20 19:38:34 +01:00
typedef WINBASEAPI DWORD WINAPI tSetCriticalSectionSpinCount (
LPCRITICAL_SECTION lpCriticalSection,
DWORD dwSpinCount
);
class Mutex {
private:
CRITICAL_SECTION spinlock;
2003-01-20 19:38:34 +01:00
static tSetCriticalSectionSpinCount* SetCriticalSectionSpinCount;
public:
Mutex();
~Mutex() {
DeleteCriticalSection(&spinlock);
}
void enter() {
EnterCriticalSection(&spinlock);
}
void leave() {
LeaveCriticalSection(&spinlock);
}
};
#else
/* Process-local spinlock. Used to manage memory heaps in threaded environment. */
// Pthreads version of the class
2004-05-21 01:05:02 +02:00
#if !defined(SOLARIS) && !defined(DARWIN) && !defined(FREEBSD) && !defined(NETBSD)
class Mutex {
private:
pthread_spinlock_t spinlock;
public:
Mutex() {
if (pthread_spin_init(&spinlock, false))
system_call_failed::raise("pthread_spin_init");
}
~Mutex() {
if (pthread_spin_destroy(&spinlock))
system_call_failed::raise("pthread_spin_destroy");
}
void enter() {
if (pthread_spin_lock(&spinlock))
system_call_failed::raise("pthread_spin_lock");
}
void leave() {
if (pthread_spin_unlock(&spinlock))
system_call_failed::raise("pthread_spin_unlock");
}
};
#else
2003-11-12 00:58:49 +01:00
#ifdef SOLARIS
// Who knows why Solaris 2.6 have not THIS funny spins?
//The next code is not comlpeted but let me compile //Konstantin
class Mutex {
private:
mutex_t spinlock;
public:
Mutex() {
if (mutex_init(&spinlock, USYNC_PROCESS, NULL))
system_call_failed::raise("mutex_init");
}
~Mutex() {
if (mutex_destroy(&spinlock))
system_call_failed::raise("mutex_destroy");
}
void enter() {
if (mutex_lock(&spinlock))
system_call_failed::raise("mutex_lock");
}
void leave() {
if (mutex_unlock(&spinlock))
system_call_failed::raise("mutex_unlock");
}
};
2004-05-21 01:05:02 +02:00
#else // DARWIN and FREEBSD and NETBSD
class Mutex {
2003-11-12 00:58:49 +01:00
private:
pthread_mutex_t mlock;
public:
Mutex() {
2003-11-12 00:58:49 +01:00
if (pthread_mutex_init(&mlock, 0))
system_call_failed::raise("pthread_mutex_init");
2003-11-12 00:58:49 +01:00
}
~Mutex() {
2003-11-12 00:58:49 +01:00
if (pthread_mutex_destroy(&mlock))
system_call_failed::raise("pthread_mutex_destroy");
2003-11-12 00:58:49 +01:00
}
void enter() {
if (pthread_mutex_lock(&mlock))
system_call_failed::raise("pthread_mutex_lock");
2003-11-12 00:58:49 +01:00
}
void leave() {
if (pthread_mutex_unlock(&mlock))
system_call_failed::raise("pthread_mutex_unlock");
2003-11-12 00:58:49 +01:00
}
};
#endif
#endif
#endif
#else
// Non-MT version
class Mutex {
public:
Mutex() {
}
~Mutex() {
}
void enter() {
}
void leave() {
}
};
#endif /* MULTI_THREAD */
2004-05-03 01:06:37 +02:00
// RAII holder of mutex lock
class MutexLockGuard {
public:
2004-06-08 08:51:13 +02:00
explicit MutexLockGuard(Mutex &alock)
: lock(&alock) { lock->enter(); }
2004-05-03 01:06:37 +02:00
~MutexLockGuard() { lock->leave(); };
private:
// Forbid copy constructor
MutexLockGuard(const MutexLockGuard& source);
Mutex *lock;
};
} //namespace Firebird
2004-03-07 08:58:55 +01:00
#endif // CLASSES_LOCKS_H