mirror of
https://github.com/s3fs-fuse/s3fs-fuse.git
synced 2025-01-10 00:07:49 +00:00
Merge pull request #1301 from gaul/pthread-result
Check results from pthread mutex calls
This commit is contained in:
commit
94e67c9c58
@ -169,7 +169,11 @@ StatCache::StatCache() : IsExpireTime(false), IsExpireIntervalType(false), Expir
|
|||||||
#if S3FS_PTHREAD_ERRORCHECK
|
#if S3FS_PTHREAD_ERRORCHECK
|
||||||
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK);
|
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK);
|
||||||
#endif
|
#endif
|
||||||
pthread_mutex_init(&StatCache::stat_cache_lock, &attr);
|
int res;
|
||||||
|
if(0 != (res = pthread_mutex_init(&StatCache::stat_cache_lock, &attr))){
|
||||||
|
S3FS_PRN_CRIT("failed to init stat_cache_lock: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
}else{
|
}else{
|
||||||
abort();
|
abort();
|
||||||
}
|
}
|
||||||
@ -179,7 +183,11 @@ StatCache::~StatCache()
|
|||||||
{
|
{
|
||||||
if(this == StatCache::getStatCacheData()){
|
if(this == StatCache::getStatCacheData()){
|
||||||
Clear();
|
Clear();
|
||||||
pthread_mutex_destroy(&StatCache::stat_cache_lock);
|
int res = pthread_mutex_destroy(&StatCache::stat_cache_lock);
|
||||||
|
if(res != 0){
|
||||||
|
S3FS_PRN_CRIT("failed to destroy stat_cache_lock: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
}else{
|
}else{
|
||||||
abort();
|
abort();
|
||||||
}
|
}
|
||||||
|
22
src/curl.cpp
22
src/curl.cpp
@ -596,11 +596,18 @@ void S3fsCurl::LockCurlShare(CURL* handle, curl_lock_data nLockData, curl_lock_a
|
|||||||
if(!hCurlShare){
|
if(!hCurlShare){
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
int res;
|
||||||
pthread_mutex_t* lockmutex = static_cast<pthread_mutex_t*>(useptr);
|
pthread_mutex_t* lockmutex = static_cast<pthread_mutex_t*>(useptr);
|
||||||
if(CURL_LOCK_DATA_DNS == nLockData){
|
if(CURL_LOCK_DATA_DNS == nLockData){
|
||||||
pthread_mutex_lock(&lockmutex[SHARE_MUTEX_DNS]);
|
if(0 != (res = pthread_mutex_lock(&lockmutex[SHARE_MUTEX_DNS]))){
|
||||||
|
S3FS_PRN_CRIT("pthread_mutex_lock returned: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
}else if(CURL_LOCK_DATA_SSL_SESSION == nLockData){
|
}else if(CURL_LOCK_DATA_SSL_SESSION == nLockData){
|
||||||
pthread_mutex_lock(&lockmutex[SHARE_MUTEX_SSL_SESSION]);
|
if(0 != (res = pthread_mutex_lock(&lockmutex[SHARE_MUTEX_SSL_SESSION]))){
|
||||||
|
S3FS_PRN_CRIT("pthread_mutex_lock returned: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -609,11 +616,18 @@ void S3fsCurl::UnlockCurlShare(CURL* handle, curl_lock_data nLockData, void* use
|
|||||||
if(!hCurlShare){
|
if(!hCurlShare){
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
int res;
|
||||||
pthread_mutex_t* lockmutex = static_cast<pthread_mutex_t*>(useptr);
|
pthread_mutex_t* lockmutex = static_cast<pthread_mutex_t*>(useptr);
|
||||||
if(CURL_LOCK_DATA_DNS == nLockData){
|
if(CURL_LOCK_DATA_DNS == nLockData){
|
||||||
pthread_mutex_unlock(&lockmutex[SHARE_MUTEX_DNS]);
|
if(0 != (res = pthread_mutex_unlock(&lockmutex[SHARE_MUTEX_DNS]))){
|
||||||
|
S3FS_PRN_CRIT("pthread_mutex_unlock returned: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
}else if(CURL_LOCK_DATA_SSL_SESSION == nLockData){
|
}else if(CURL_LOCK_DATA_SSL_SESSION == nLockData){
|
||||||
pthread_mutex_unlock(&lockmutex[SHARE_MUTEX_SSL_SESSION]);
|
if(0 != (res = pthread_mutex_unlock(&lockmutex[SHARE_MUTEX_SSL_SESSION]))){
|
||||||
|
S3FS_PRN_CRIT("pthread_mutex_unlock returned: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1045,18 +1045,21 @@ FdEntity::FdEntity(const char* tpath, const char* cpath)
|
|||||||
fd(-1), pfile(NULL), inode(0), size_orgmeta(0), upload_id(""), mp_start(0), mp_size(0),
|
fd(-1), pfile(NULL), inode(0), size_orgmeta(0), upload_id(""), mp_start(0), mp_size(0),
|
||||||
cachepath(SAFESTRPTR(cpath)), mirrorpath("")
|
cachepath(SAFESTRPTR(cpath)), mirrorpath("")
|
||||||
{
|
{
|
||||||
try{
|
pthread_mutexattr_t attr;
|
||||||
pthread_mutexattr_t attr;
|
pthread_mutexattr_init(&attr);
|
||||||
pthread_mutexattr_init(&attr);
|
|
||||||
#if S3FS_PTHREAD_ERRORCHECK
|
#if S3FS_PTHREAD_ERRORCHECK
|
||||||
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK);
|
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK);
|
||||||
#endif
|
#endif
|
||||||
pthread_mutex_init(&fdent_lock, &attr);
|
int res;
|
||||||
pthread_mutex_init(&fdent_data_lock, &attr);
|
if(0 != (res = pthread_mutex_init(&fdent_lock, &attr))){
|
||||||
is_lock_init = true;
|
S3FS_PRN_CRIT("failed to init fdent_lock: %d", res);
|
||||||
}catch(exception& e){
|
abort();
|
||||||
S3FS_PRN_CRIT("failed to init mutex");
|
|
||||||
}
|
}
|
||||||
|
if(0 != (res = pthread_mutex_init(&fdent_data_lock, &attr))){
|
||||||
|
S3FS_PRN_CRIT("failed to init fdent_data_lock: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
is_lock_init = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
FdEntity::~FdEntity()
|
FdEntity::~FdEntity()
|
||||||
@ -1064,11 +1067,14 @@ FdEntity::~FdEntity()
|
|||||||
Clear();
|
Clear();
|
||||||
|
|
||||||
if(is_lock_init){
|
if(is_lock_init){
|
||||||
try{
|
int res;
|
||||||
pthread_mutex_destroy(&fdent_data_lock);
|
if(0 != (res = pthread_mutex_destroy(&fdent_data_lock))){
|
||||||
pthread_mutex_destroy(&fdent_lock);
|
S3FS_PRN_CRIT("failed to destroy fdent_data_lock: %d", res);
|
||||||
}catch(exception& e){
|
abort();
|
||||||
S3FS_PRN_CRIT("failed to destroy mutex");
|
}
|
||||||
|
if(0 != (res = pthread_mutex_destroy(&fdent_lock))){
|
||||||
|
S3FS_PRN_CRIT("failed to destroy fdent_lock: %d", res);
|
||||||
|
abort();
|
||||||
}
|
}
|
||||||
is_lock_init = false;
|
is_lock_init = false;
|
||||||
}
|
}
|
||||||
@ -2580,15 +2586,20 @@ FdManager::FdManager()
|
|||||||
#if S3FS_PTHREAD_ERRORCHECK
|
#if S3FS_PTHREAD_ERRORCHECK
|
||||||
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK);
|
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK);
|
||||||
#endif
|
#endif
|
||||||
try{
|
int res;
|
||||||
pthread_mutex_init(&FdManager::fd_manager_lock, &attr);
|
if(0 != (res = pthread_mutex_init(&FdManager::fd_manager_lock, &attr))){
|
||||||
pthread_mutex_init(&FdManager::cache_cleanup_lock, &attr);
|
S3FS_PRN_CRIT("failed to init fd_manager_lock: %d", res);
|
||||||
pthread_mutex_init(&FdManager::reserved_diskspace_lock, &attr);
|
abort();
|
||||||
FdManager::is_lock_init = true;
|
|
||||||
}catch(exception& e){
|
|
||||||
FdManager::is_lock_init = false;
|
|
||||||
S3FS_PRN_CRIT("failed to init mutex");
|
|
||||||
}
|
}
|
||||||
|
if(0 != (res = pthread_mutex_init(&FdManager::cache_cleanup_lock, &attr))){
|
||||||
|
S3FS_PRN_CRIT("failed to init cache_cleanup_lock: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
if(0 != (res = pthread_mutex_init(&FdManager::reserved_diskspace_lock, &attr))){
|
||||||
|
S3FS_PRN_CRIT("failed to init reserved_diskspace_lock: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
FdManager::is_lock_init = true;
|
||||||
}else{
|
}else{
|
||||||
abort();
|
abort();
|
||||||
}
|
}
|
||||||
@ -2604,12 +2615,18 @@ FdManager::~FdManager()
|
|||||||
fent.clear();
|
fent.clear();
|
||||||
|
|
||||||
if(FdManager::is_lock_init){
|
if(FdManager::is_lock_init){
|
||||||
try{
|
int res;
|
||||||
pthread_mutex_destroy(&FdManager::fd_manager_lock);
|
if(0 != (res = pthread_mutex_destroy(&FdManager::fd_manager_lock))){
|
||||||
pthread_mutex_destroy(&FdManager::cache_cleanup_lock);
|
S3FS_PRN_CRIT("failed to destroy fd_manager_lock: %d", res);
|
||||||
pthread_mutex_destroy(&FdManager::reserved_diskspace_lock);
|
abort();
|
||||||
}catch(exception& e){
|
}
|
||||||
S3FS_PRN_CRIT("failed to init mutex");
|
if(0 != (res = pthread_mutex_destroy(&FdManager::cache_cleanup_lock))){
|
||||||
|
S3FS_PRN_CRIT("failed to destroy cache_cleanup_lock: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
if(0 != (res = pthread_mutex_destroy(&FdManager::reserved_diskspace_lock))){
|
||||||
|
S3FS_PRN_CRIT("failed to destroy reserved_diskspace_lock: %d", res);
|
||||||
|
abort();
|
||||||
}
|
}
|
||||||
FdManager::is_lock_init = false;
|
FdManager::is_lock_init = false;
|
||||||
}
|
}
|
||||||
|
@ -86,10 +86,17 @@ static void s3fs_crypt_mutex_lock(int mode, int pos, const char* file, int line)
|
|||||||
static void s3fs_crypt_mutex_lock(int mode, int pos, const char* file, int line)
|
static void s3fs_crypt_mutex_lock(int mode, int pos, const char* file, int line)
|
||||||
{
|
{
|
||||||
if(s3fs_crypt_mutex){
|
if(s3fs_crypt_mutex){
|
||||||
|
int res;
|
||||||
if(mode & CRYPTO_LOCK){
|
if(mode & CRYPTO_LOCK){
|
||||||
pthread_mutex_lock(&s3fs_crypt_mutex[pos]);
|
if(0 != (res = pthread_mutex_lock(&s3fs_crypt_mutex[pos]))){
|
||||||
|
S3FS_PRN_CRIT("pthread_mutex_lock returned: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
}else{
|
}else{
|
||||||
pthread_mutex_unlock(&s3fs_crypt_mutex[pos]);
|
if(0 != (res = pthread_mutex_unlock(&s3fs_crypt_mutex[pos]))){
|
||||||
|
S3FS_PRN_CRIT("pthread_mutex_unlock returned: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -111,7 +118,11 @@ static struct CRYPTO_dynlock_value* s3fs_dyn_crypt_mutex(const char* file, int l
|
|||||||
#if S3FS_PTHREAD_ERRORCHECK
|
#if S3FS_PTHREAD_ERRORCHECK
|
||||||
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK);
|
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK);
|
||||||
#endif
|
#endif
|
||||||
pthread_mutex_init(&(dyndata->dyn_mutex), &attr);
|
int res;
|
||||||
|
if(0 != (res = pthread_mutex_init(&(dyndata->dyn_mutex), &attr))){
|
||||||
|
S3FS_PRN_CRIT("pthread_mutex_init returned: %d", res);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
return dyndata;
|
return dyndata;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -119,10 +130,17 @@ static void s3fs_dyn_crypt_mutex_lock(int mode, struct CRYPTO_dynlock_value* dyn
|
|||||||
static void s3fs_dyn_crypt_mutex_lock(int mode, struct CRYPTO_dynlock_value* dyndata, const char* file, int line)
|
static void s3fs_dyn_crypt_mutex_lock(int mode, struct CRYPTO_dynlock_value* dyndata, const char* file, int line)
|
||||||
{
|
{
|
||||||
if(dyndata){
|
if(dyndata){
|
||||||
|
int res;
|
||||||
if(mode & CRYPTO_LOCK){
|
if(mode & CRYPTO_LOCK){
|
||||||
pthread_mutex_lock(&(dyndata->dyn_mutex));
|
if(0 != (res = pthread_mutex_lock(&(dyndata->dyn_mutex)))){
|
||||||
|
S3FS_PRN_CRIT("pthread_mutex_lock returned: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
}else{
|
}else{
|
||||||
pthread_mutex_unlock(&(dyndata->dyn_mutex));
|
if(0 != (res = pthread_mutex_unlock(&(dyndata->dyn_mutex)))){
|
||||||
|
S3FS_PRN_CRIT("pthread_mutex_unlock returned: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -131,7 +149,11 @@ static void s3fs_destroy_dyn_crypt_mutex(struct CRYPTO_dynlock_value* dyndata, c
|
|||||||
static void s3fs_destroy_dyn_crypt_mutex(struct CRYPTO_dynlock_value* dyndata, const char* file, int line)
|
static void s3fs_destroy_dyn_crypt_mutex(struct CRYPTO_dynlock_value* dyndata, const char* file, int line)
|
||||||
{
|
{
|
||||||
if(dyndata){
|
if(dyndata){
|
||||||
pthread_mutex_destroy(&(dyndata->dyn_mutex));
|
int res = pthread_mutex_destroy(&(dyndata->dyn_mutex));
|
||||||
|
if(res != 0){
|
||||||
|
S3FS_PRN_CRIT("failed to destroy dyn_mutex");
|
||||||
|
abort();
|
||||||
|
}
|
||||||
delete dyndata;
|
delete dyndata;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -152,7 +174,11 @@ bool s3fs_init_crypt_mutex()
|
|||||||
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK);
|
pthread_mutexattr_settype(&attr, PTHREAD_MUTEX_ERRORCHECK);
|
||||||
#endif
|
#endif
|
||||||
for(int cnt = 0; cnt < CRYPTO_num_locks(); cnt++){
|
for(int cnt = 0; cnt < CRYPTO_num_locks(); cnt++){
|
||||||
pthread_mutex_init(&s3fs_crypt_mutex[cnt], &attr);
|
int res = pthread_mutex_init(&s3fs_crypt_mutex[cnt], &attr);
|
||||||
|
if(res != 0){
|
||||||
|
S3FS_PRN_CRIT("pthread_mutex_init returned: %d", res);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
// static lock
|
// static lock
|
||||||
CRYPTO_set_locking_callback(s3fs_crypt_mutex_lock);
|
CRYPTO_set_locking_callback(s3fs_crypt_mutex_lock);
|
||||||
@ -178,7 +204,11 @@ bool s3fs_destroy_crypt_mutex()
|
|||||||
CRYPTO_set_locking_callback(NULL);
|
CRYPTO_set_locking_callback(NULL);
|
||||||
|
|
||||||
for(int cnt = 0; cnt < CRYPTO_num_locks(); cnt++){
|
for(int cnt = 0; cnt < CRYPTO_num_locks(); cnt++){
|
||||||
pthread_mutex_destroy(&s3fs_crypt_mutex[cnt]);
|
int res = pthread_mutex_destroy(&s3fs_crypt_mutex[cnt]);
|
||||||
|
if(res != 0){
|
||||||
|
S3FS_PRN_CRIT("failed to destroy s3fs_crypt_mutex[%d]", cnt);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
CRYPTO_cleanup_all_ex_data();
|
CRYPTO_cleanup_all_ex_data();
|
||||||
delete[] s3fs_crypt_mutex;
|
delete[] s3fs_crypt_mutex;
|
||||||
|
@ -459,7 +459,11 @@ bool AutoLock::isLockAcquired() const
|
|||||||
AutoLock::~AutoLock()
|
AutoLock::~AutoLock()
|
||||||
{
|
{
|
||||||
if (is_lock_acquired) {
|
if (is_lock_acquired) {
|
||||||
pthread_mutex_unlock(auto_mutex);
|
int res = pthread_mutex_unlock(auto_mutex);
|
||||||
|
if(res != 0){
|
||||||
|
S3FS_PRN_CRIT("pthread_mutex_lock returned: %d", res);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user