Ai
1 Star 0 Fork 0

wangcichen/urbackup_backend

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
SharedMutex_lin.cpp 3.69 KB
一键复制 编辑 原始数据 按行查看 历史
/*************************************************************************
* UrBackup - Client/Server backup system
* Copyright (C) 2011-2016 Martin Raiber
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program 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 Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
**************************************************************************/
#include "SharedMutex_lin.h"
#include "Server.h"
#include "stringtools.h"
#include <assert.h>
SharedMutex::SharedMutex()
{
pthread_rwlockattr_t attr;
int rc;
if((rc=pthread_rwlockattr_init(&attr))!=0)
{
Server->Log("Error initializing rwlockattr rc="+convert(rc), LL_ERROR);
assert(false);
}
#ifdef __GLIBC__
if((rc=pthread_rwlockattr_setkind_np(&attr, PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP))!=0)
{
Server->Log("Error setting PTHREAD_RWLOCK_PREFER_WRITER_NONRECURSIVE_NP rc="+convert(rc), LL_ERROR);
assert(false);
}
#endif
rc = pthread_rwlock_init(&lock, &attr);
if(rc)
{
Server->Log("Error initializing rwlock rc="+convert(rc), LL_ERROR);
assert(false);
}
if((rc=pthread_rwlockattr_destroy(&attr))!=0)
{
Server->Log("Error destroing rwlockattr rc="+convert(rc), LL_ERROR);
assert(false);
}
#ifdef SHARED_MUTEX_CHECK
check_mutex.reset(Server->createMutex());
#endif
}
SharedMutex::~SharedMutex()
{
int rc = pthread_rwlock_destroy(&lock);
if(rc)
{
Server->Log("Error destroying rwlock rc="+convert(rc), LL_ERROR);
assert(false);
}
}
ILock* SharedMutex::readLock()
{
#ifdef SHARED_MUTEX_CHECK
{
IScopedLock lock(check_mutex.get());
std::pair<std::set<pthread_t>::iterator, bool> ins = check_threads.insert(pthread_self());
assert(ins.second);
}
#endif
return new ReadLock(&lock
SHARED_MUTEX_CHECK_P(this));
}
ILock* SharedMutex::writeLock()
{
#ifdef SHARED_MUTEX_CHECK
{
IScopedLock lock(check_mutex.get());
assert(check_threads.find(pthread_self())
== check_threads.end());
}
#endif
return new WriteLock(&lock);
}
#ifdef SHARED_MUTEX_CHECK
void SharedMutex::rmLockCheck()
{
IScopedLock lock(check_mutex.get());
assert(check_threads.erase(pthread_self()) == 1);
}
#endif
ReadLock::ReadLock( pthread_rwlock_t* read_lock
SHARED_MUTEX_CHECK_P(SharedMutex* shared_mutex))
: read_lock(read_lock)
SHARED_MUTEX_CHECK_P(shared_mutex(shared_mutex))
{
int rc = pthread_rwlock_rdlock(read_lock);
if(rc)
{
Server->Log("Error locking rwlock_rdlock rc="+convert(rc), LL_ERROR);
assert(false);
}
}
ReadLock::~ReadLock()
{
int rc = pthread_rwlock_unlock(read_lock);
if(rc)
{
Server->Log("Error unlocking rwlock rc="+convert(rc), LL_ERROR);
assert(false);
}
#ifdef SHARED_MUTEX_CHECK
shared_mutex->rmLockCheck();
#endif
}
WriteLock::WriteLock( pthread_rwlock_t* write_lock )
: write_lock(write_lock)
{
int rc = pthread_rwlock_wrlock(write_lock);
if(rc)
{
Server->Log("Error locking rwlock_wrlock rc="+convert(rc), LL_ERROR);
assert(false);
}
}
WriteLock::~WriteLock()
{
int rc = pthread_rwlock_unlock(write_lock);
if(rc)
{
Server->Log("Error unlocking rwlock rc="+convert(rc), LL_ERROR);
assert(false);
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C
1
https://gitee.com/wangcichen/urbackup_backend.git
git@gitee.com:wangcichen/urbackup_backend.git
wangcichen
urbackup_backend
urbackup_backend
dev

搜索帮助