int type;
int transport;
int stream_id;
+ switch_thread_t *thread;
};
typedef struct switch_unicast_conninfo switch_unicast_conninfo_t;
switch_queue_create(&memory_manager.pool_recycle_queue, 50000, memory_manager.memory_pool);
switch_threadattr_create(&thd_attr, memory_manager.memory_pool);
- switch_threadattr_detach_set(thd_attr, 0);
switch_threadattr_stacksize_set(thd_attr, SWITCH_THREAD_STACKSIZE);
switch_thread_create(&pool_thread_p, thd_attr, pool_thread, NULL, memory_manager.memory_pool);
static void unicast_thread_launch(switch_unicast_conninfo_t *conninfo)
{
- switch_thread_t *thread;
switch_threadattr_t *thd_attr = NULL;
switch_threadattr_create(&thd_attr, switch_core_session_get_pool(conninfo->session));
- switch_threadattr_detach_set(thd_attr, 1);
switch_threadattr_stacksize_set(thd_attr, SWITCH_THREAD_STACKSIZE);
switch_set_flag_locked(conninfo, SUF_THREAD_RUNNING);
- switch_thread_create(&thread, thd_attr, unicast_thread_run, conninfo, switch_core_session_get_pool(conninfo->session));
+ switch_thread_create(&conninfo->thread, thd_attr, unicast_thread_run, conninfo, switch_core_session_get_pool(conninfo->session));
}
SWITCH_DECLARE(switch_status_t) switch_ivr_deactivate_unicast(switch_core_session_t *session)
}
if ((conninfo = switch_channel_get_private(channel, "unicast"))) {
+ switch_status_t st;
+
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Shutting down unicast connection\n");
switch_clear_flag_locked(conninfo, SUF_READY);
switch_socket_shutdown(conninfo->socket, SWITCH_SHUTDOWN_READWRITE);
+ switch_thread_join(&st, conninfo->thread);
+
while (switch_test_flag(conninfo, SUF_THREAD_RUNNING)) {
switch_yield(10000);
if (++sanity >= 10000) {
switch_mutex_t *mutex;
switch_thread_cond_t *cond;
switch_memory_pool_t *pool;
+ switch_thread_t *thread;
int ready;
};
frame.buflen = SWITCH_RECOMMENDED_BUFFER_SIZE;
switch (type) {
- case SWITCH_ABC_TYPE_INIT:{
- switch_thread_t *thread;
+ case SWITCH_ABC_TYPE_INIT:
+ {
switch_threadattr_t *thd_attr = NULL;
-
+
switch_threadattr_create(&thd_attr, sth->pool);
- switch_threadattr_detach_set(thd_attr, 1);
switch_threadattr_stacksize_set(thd_attr, SWITCH_THREAD_STACKSIZE);
- switch_thread_create(&thread, thd_attr, speech_thread, sth, sth->pool);
+ switch_thread_create(&sth->thread, thd_attr, speech_thread, sth, sth->pool);
}
break;
- case SWITCH_ABC_TYPE_CLOSE:{
+ case SWITCH_ABC_TYPE_CLOSE:
+ {
+ switch_status_t st;
+
switch_core_asr_close(sth->ah, &flags);
if (sth->mutex && sth->cond && sth->ready) {
- switch_mutex_lock(sth->mutex);
- switch_thread_cond_signal(sth->cond);
- switch_mutex_unlock(sth->mutex);
+ if (switch_mutex_trylock(sth->mutex) == SWITCH_STATUS_SUCCESS) {
+ switch_thread_cond_signal(sth->cond);
+ switch_mutex_unlock(sth->mutex);
+ }
}
+
+ switch_thread_join(&st, sth->thread);
+
}
break;
case SWITCH_ABC_TYPE_READ:
LOG_POOL = pool;
switch_threadattr_create(&thd_attr, LOG_POOL);
- switch_threadattr_detach_set(thd_attr, 1);
-
switch_queue_create(&LOG_QUEUE, SWITCH_CORE_QUEUE_LEN, LOG_POOL);
#ifdef SWITCH_LOG_RECYCLE
}
switch_threadattr_create(&thd_attr, nat_globals_perm.pool);
- switch_threadattr_detach_set(thd_attr, 1);
switch_thread_create(&nat_thread_p, thd_attr, switch_nat_multicast_runtime, NULL, nat_globals_perm.pool);
}
switch_mutex_init(&globals.task_mutex, SWITCH_MUTEX_NESTED, globals.memory_pool);
switch_queue_create(&globals.event_queue, 250000, globals.memory_pool);
- switch_threadattr_detach_set(thd_attr, 1);
switch_thread_create(&task_thread_p, thd_attr, switch_scheduler_task_thread, NULL, globals.memory_pool);
}