summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Spencer <markster@digium.com>2005-05-26 20:24:56 +0000
committerMark Spencer <markster@digium.com>2005-05-26 20:24:56 +0000
commit2f1e6379b3fdf00a5df716b0a9b0c9d4e91f4db2 (patch)
tree24950225e177b6ade77830e18f070db9e1b2de99
parent8adbac17df85b386cf548a5a118762532ee5c696 (diff)
Fix agent deadlock and remove braindead tags dependency
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@5777 65c4cc65-6c06-0410-ace0-fbb531ad65f3
-rwxr-xr-xMakefile8
-rwxr-xr-xchannels/chan_agent.c3
2 files changed, 5 insertions, 6 deletions
diff --git a/Makefile b/Makefile
index 3b6b4cb00..538b0c343 100755
--- a/Makefile
+++ b/Makefile
@@ -118,7 +118,7 @@ DEBUG=-g #-pg
#endif
# Optional debugging parameters
-DEBUG_THREADS = #-DDEBUG_THREADS #-DDO_CRASH #-DDETECT_DEADLOCKS
+DEBUG_THREADS = -DDEBUG_THREADS #-DDO_CRASH #-DDETECT_DEADLOCKS
# Uncomment next one to enable ast_frame tracing (for debugging)
TRACE_FRAMES = #-DTRACE_FRAMES
@@ -294,9 +294,9 @@ _all: all
all: cleantest depend asterisk subdirs
-ifneq ($(wildcard tags),)
-all: tags
-endif
+#ifneq ($(wildcard tags),)
+ctags: tags
+#endif
ifneq ($(wildcard TAGS),)
all: TAGS
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);