[Core] Fix possible race condition between locking a session and reading it's flags in switch_core_session_read_lock() and switch_core_session_read_lock_hangup().
This commit is contained in:
parent
c671ebcb88
commit
d96b6a4a8f
|
@ -85,9 +85,9 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_read_lock(switch_core_sessio
|
||||||
switch_status_t status = SWITCH_STATUS_FALSE;
|
switch_status_t status = SWITCH_STATUS_FALSE;
|
||||||
|
|
||||||
if (session->rwlock) {
|
if (session->rwlock) {
|
||||||
if (switch_test_flag(session, SSF_DESTROYED) || switch_channel_down_nosig(session->channel)) {
|
if ((status = switch_thread_rwlock_tryrdlock(session->rwlock)) == SWITCH_STATUS_SUCCESS) {
|
||||||
status = SWITCH_STATUS_FALSE;
|
if (switch_test_flag(session, SSF_DESTROYED) || switch_channel_down_nosig(session->channel)) {
|
||||||
if (switch_thread_rwlock_tryrdlock(session->rwlock) == SWITCH_STATUS_SUCCESS) {
|
status = SWITCH_STATUS_FALSE;
|
||||||
if (switch_channel_test_flag(session->channel, CF_THREAD_SLEEPING)) {
|
if (switch_channel_test_flag(session->channel, CF_THREAD_SLEEPING)) {
|
||||||
#ifdef SWITCH_DEBUG_RWLOCKS
|
#ifdef SWITCH_DEBUG_RWLOCKS
|
||||||
switch_log_printf(SWITCH_CHANNEL_ID_LOG, file, func, line, switch_core_session_get_uuid(session), SWITCH_LOG_ERROR, "%s %s Ping thread\n",
|
switch_log_printf(SWITCH_CHANNEL_ID_LOG, file, func, line, switch_core_session_get_uuid(session), SWITCH_LOG_ERROR, "%s %s Ping thread\n",
|
||||||
|
@ -95,18 +95,18 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_read_lock(switch_core_sessio
|
||||||
#endif
|
#endif
|
||||||
switch_core_session_wake_session_thread(session);
|
switch_core_session_wake_session_thread(session);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef SWITCH_DEBUG_RWLOCKS
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_ID_LOG, file, func, line, switch_core_session_get_uuid(session), SWITCH_LOG_ERROR, "%s %s Read lock FAIL\n",
|
||||||
|
switch_core_session_get_uuid(session), switch_channel_get_name(session->channel));
|
||||||
|
#endif
|
||||||
switch_thread_rwlock_unlock(session->rwlock);
|
switch_thread_rwlock_unlock(session->rwlock);
|
||||||
|
} else {
|
||||||
|
#ifdef SWITCH_DEBUG_RWLOCKS
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_ID_LOG, file, func, line, switch_core_session_get_uuid(session), SWITCH_LOG_ERROR, "%s %s Read lock ACQUIRED\n",
|
||||||
|
switch_core_session_get_uuid(session), switch_channel_get_name(session->channel));
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
#ifdef SWITCH_DEBUG_RWLOCKS
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_ID_LOG, file, func, line, switch_core_session_get_uuid(session), SWITCH_LOG_ERROR, "%s %s Read lock FAIL\n",
|
|
||||||
switch_core_session_get_uuid(session), switch_channel_get_name(session->channel));
|
|
||||||
#endif
|
|
||||||
} else {
|
|
||||||
status = (switch_status_t) switch_thread_rwlock_tryrdlock(session->rwlock);
|
|
||||||
#ifdef SWITCH_DEBUG_RWLOCKS
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_ID_LOG, file, func, line, switch_core_session_get_uuid(session), SWITCH_LOG_ERROR, "%s %s Read lock ACQUIRED\n",
|
|
||||||
switch_core_session_get_uuid(session), switch_channel_get_name(session->channel));
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -123,18 +123,20 @@ SWITCH_DECLARE(switch_status_t) switch_core_session_read_lock_hangup(switch_core
|
||||||
switch_status_t status = SWITCH_STATUS_FALSE;
|
switch_status_t status = SWITCH_STATUS_FALSE;
|
||||||
|
|
||||||
if (session->rwlock) {
|
if (session->rwlock) {
|
||||||
if (switch_test_flag(session, SSF_DESTROYED) || switch_channel_get_state(session->channel) >= CS_DESTROY) {
|
if ((status = switch_thread_rwlock_tryrdlock(session->rwlock)) == SWITCH_STATUS_SUCCESS) {
|
||||||
status = SWITCH_STATUS_FALSE;
|
if (switch_test_flag(session, SSF_DESTROYED) || switch_channel_get_state(session->channel) >= CS_DESTROY) {
|
||||||
|
status = SWITCH_STATUS_FALSE;
|
||||||
#ifdef SWITCH_DEBUG_RWLOCKS
|
#ifdef SWITCH_DEBUG_RWLOCKS
|
||||||
switch_log_printf(SWITCH_CHANNEL_ID_LOG, file, func, line, switch_core_session_get_uuid(session), SWITCH_LOG_ERROR, "%s %s Read lock FAIL\n",
|
switch_log_printf(SWITCH_CHANNEL_ID_LOG, file, func, line, switch_core_session_get_uuid(session), SWITCH_LOG_ERROR, "%s %s Read lock FAIL\n",
|
||||||
switch_core_session_get_uuid(session), switch_channel_get_name(session->channel));
|
switch_core_session_get_uuid(session), switch_channel_get_name(session->channel));
|
||||||
#endif
|
#endif
|
||||||
} else {
|
switch_thread_rwlock_unlock(session->rwlock);
|
||||||
status = (switch_status_t) switch_thread_rwlock_tryrdlock(session->rwlock);
|
} else {
|
||||||
#ifdef SWITCH_DEBUG_RWLOCKS
|
#ifdef SWITCH_DEBUG_RWLOCKS
|
||||||
switch_log_printf(SWITCH_CHANNEL_ID_LOG, file, func, line, switch_core_session_get_uuid(session), SWITCH_LOG_ERROR, "%s %s Read lock ACQUIRED\n",
|
switch_log_printf(SWITCH_CHANNEL_ID_LOG, file, func, line, switch_core_session_get_uuid(session), SWITCH_LOG_ERROR, "%s %s Read lock ACQUIRED\n",
|
||||||
switch_core_session_get_uuid(session), switch_channel_get_name(session->channel));
|
switch_core_session_get_uuid(session), switch_channel_get_name(session->channel));
|
||||||
#endif
|
#endif
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue