From: Russell Bryant Date: Wed, 15 Dec 2004 19:07:10 +0000 (+0000) Subject: Fix use count for agent/local (bug #2996) X-Git-Tag: 1.0.11.1~341 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=8d135aa5aecf4f2e0059a16d1e17f5b7060872b8;p=thirdparty%2Fasterisk.git Fix use count for agent/local (bug #2996) git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/v1-0@4457 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/channels/chan_agent.c b/channels/chan_agent.c index 6e8c3661ae..5d3781017c 100755 --- a/channels/chan_agent.c +++ b/channels/chan_agent.c @@ -527,6 +527,10 @@ static int agent_hangup(struct ast_channel *ast) * as in apps/app_chanisavail.c:chanavail_exec() */ + ast_mutex_lock(&usecnt_lock); + usecnt--; + ast_mutex_unlock(&usecnt_lock); + ast_log(LOG_DEBUG, "Hangup called for state %s\n", ast_state2str(ast->_state)); if (p->start && (ast->_state != AST_STATE_UP)) { howlong = time(NULL) - p->start; diff --git a/channels/chan_local.c b/channels/chan_local.c index 1a81db14a0..439bd3dfe8 100755 --- a/channels/chan_local.c +++ b/channels/chan_local.c @@ -304,6 +304,10 @@ static int local_hangup(struct ast_channel *ast) p->owner = NULL; ast->pvt->pvt = NULL; + ast_mutex_lock(&usecnt_lock); + usecnt--; + ast_mutex_unlock(&usecnt_lock); + if (!p->owner && !p->chan) { /* Okay, done with the private part now, too. */ glaredetect = p->glaredetect; @@ -441,6 +445,7 @@ static struct ast_channel *local_new(struct local_pvt *p, int state) p->chan = tmp2; ast_mutex_lock(&usecnt_lock); usecnt++; + usecnt++; ast_mutex_unlock(&usecnt_lock); ast_update_use_count(); strncpy(tmp->context, p->context, sizeof(tmp->context)-1);