aboutsummaryrefslogtreecommitdiffstats
path: root/channels/chan_agent.c
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2005-05-26 20:24:56 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2005-05-26 20:24:56 +0000
commit09a03fa87f178222f506eb454f93fbba3de093ec (patch)
tree24950225e177b6ade77830e18f070db9e1b2de99 /channels/chan_agent.c
parent6dcf8c17ee8e0a53c0f8b6c499cd0025717c30ab (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/chan_agent.c')
-rwxr-xr-xchannels/chan_agent.c3
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);