diff options
author | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2005-05-26 20:24:56 +0000 |
---|---|---|
committer | markster <markster@f38db490-d61c-443f-a65b-d21fe96a405b> | 2005-05-26 20:24:56 +0000 |
commit | 09a03fa87f178222f506eb454f93fbba3de093ec (patch) | |
tree | 24950225e177b6ade77830e18f070db9e1b2de99 /channels | |
parent | 6dcf8c17ee8e0a53c0f8b6c499cd0025717c30ab (diff) |
Fix agent deadlock and remove braindead tags dependency
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@5777 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels')
-rwxr-xr-x | channels/chan_agent.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/channels/chan_agent.c b/channels/chan_agent.c index a330764a1..f537cf4f8 100755 --- a/channels/chan_agent.c +++ b/channels/chan_agent.c @@ -705,14 +705,12 @@ static int agent_hangup(struct ast_channel *ast) snprintf(agent, sizeof(agent), "Agent/%s", p->agent); ast_queue_log("NONE", ast->uniqueid, agent, "AGENTCALLBACKLOGOFF", "%s|%ld|%s", p->loginchan, logintime, "Autologoff"); p->loginchan[0] = '\0'; - ast_device_state_changed("Agent/%s", p->agent); } } else if (p->dead) { ast_mutex_lock(&p->chan->lock); ast_softhangup(p->chan, AST_SOFTHANGUP_EXPLICIT); ast_mutex_unlock(&p->chan->lock); } else { - ast_device_state_changed("Agent/%s", p->agent); ast_mutex_lock(&p->chan->lock); ast_moh_start(p->chan, p->moh); ast_mutex_unlock(&p->chan->lock); @@ -734,6 +732,7 @@ static int agent_hangup(struct ast_channel *ast) } #endif ast_mutex_unlock(&p->lock); + ast_device_state_changed("Agent/%s", p->agent); if (p->pending) { ast_mutex_lock(&agentlock); |