[asterisk-commits] rmudgett: branch 1.8 r378427 - /branches/1.8/channels/chan_agent.c
SVN commits to the Asterisk project
asterisk-commits at lists.digium.com
Thu Jan 3 11:41:50 CST 2013
Author: rmudgett
Date: Thu Jan 3 11:41:46 2013
New Revision: 378427
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=378427
Log:
chan_agent: Fix agent_indicate() locking.
Avoid deadlock potential with local channels and simplify the locking.
Modified:
branches/1.8/channels/chan_agent.c
Modified: branches/1.8/channels/chan_agent.c
URL: http://svnview.digium.com/svn/asterisk/branches/1.8/channels/chan_agent.c?view=diff&rev=378427&r1=378426&r2=378427
==============================================================================
--- branches/1.8/channels/chan_agent.c (original)
+++ branches/1.8/channels/chan_agent.c Thu Jan 3 11:41:46 2013
@@ -784,23 +784,19 @@
{
struct agent_pvt *p = ast->tech_pvt;
int res = -1;
+
ast_mutex_lock(&p->lock);
if (p->chan && !ast_check_hangup(p->chan)) {
- while (ast_channel_trylock(p->chan)) {
- int res;
- if ((res = ast_channel_unlock(ast))) {
- ast_log(LOG_ERROR, "chan_agent bug! Channel was not locked upon entry to agent_indicate: %s\n", res > 0 ? strerror(res) : "Bad ao2obj data");
- ast_mutex_unlock(&p->lock);
- return -1;
- }
- usleep(1);
- ast_channel_lock(ast);
- }
+ ast_channel_unlock(ast);
+ ast_channel_lock(p->chan);
res = p->chan->tech->indicate ? p->chan->tech->indicate(p->chan, condition, data, datalen) : -1;
ast_channel_unlock(p->chan);
- } else
+ ast_mutex_unlock(&p->lock);
+ ast_channel_lock(ast);
+ } else {
+ ast_mutex_unlock(&p->lock);
res = 0;
- ast_mutex_unlock(&p->lock);
+ }
return res;
}
More information about the asterisk-commits
mailing list