mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-05 20:20:07 +00:00
By using the iaxdynamicthreadcount to identify a thread, it was possible
for thread identifiers to be duplicated. By using a globally-unique monotonically- increasing integer, this is now avoided. (closes issue #13009) Reported by: jpgrayson Patches: chan_iax2_dyn_threadnum.patch uploaded by jpgrayson (license 492) git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@128639 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -446,6 +446,7 @@ static AST_LIST_HEAD_STATIC(registrations, iax2_registry);
|
||||
static int iaxthreadcount = DEFAULT_THREAD_COUNT;
|
||||
static int iaxmaxthreadcount = DEFAULT_MAX_THREAD_COUNT;
|
||||
static int iaxdynamicthreadcount = 0;
|
||||
static int iaxdynamicthreadnum = 0;
|
||||
static int iaxactivethreadcount = 0;
|
||||
|
||||
struct iax_rr {
|
||||
@@ -920,7 +921,7 @@ static struct iax2_thread *find_idle_thread(void)
|
||||
if (thread == NULL && iaxmaxthreadcount > iaxdynamicthreadcount) {
|
||||
/* We need to MAKE a thread! */
|
||||
if ((thread = ast_calloc(1, sizeof(*thread)))) {
|
||||
thread->threadnum = iaxdynamicthreadcount;
|
||||
thread->threadnum = iaxdynamicthreadnum++;
|
||||
thread->type = IAX_TYPE_DYNAMIC;
|
||||
ast_mutex_init(&thread->lock);
|
||||
ast_cond_init(&thread->cond, NULL);
|
||||
|
Reference in New Issue
Block a user