<p>Pirmin Walthert has uploaded this change for <strong>review</strong>.</p><p><a href="https://gerrit.asterisk.org/9069">View Change</a></p><pre style="font-family: monospace,monospace; white-space: pre-wrap;">bridge_channel.c: Fix Deadlock when using Local channels and fax gateway<br><br>ast_indicate is invoked with the bridge locked. As ast_indicate locks the<br>other end of the bridge as well this can lead to a deadlock in some situations.<br>(Especially when a different thread does the same in the reverse order).<br>This patch calls ast_indicate after unlocking the bridge, what fixes the<br>deadlock. Calling ast_indicate with these parameters without locking the<br>bridge should be safe as this is done at different places without a<br>bridge lock.<br><br>Change-Id: I5f86c1e2ce75b9929a36ab589b18c450e62ea35f<br>---<br>M main/bridge_channel.c<br>1 file changed, 6 insertions(+), 1 deletion(-)<br><br></pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;">git pull ssh://gerrit.asterisk.org:29418/asterisk refs/changes/69/9069/1</pre><pre style="font-family: monospace,monospace; white-space: pre-wrap;">diff --git a/main/bridge_channel.c b/main/bridge_channel.c<br>index 3eefd44..1a7df87 100644<br>--- a/main/bridge_channel.c<br>+++ b/main/bridge_channel.c<br>@@ -2677,6 +2677,7 @@<br> int bridge_channel_internal_join(struct ast_bridge_channel *bridge_channel)<br> {<br> int res = 0;<br>+ uint8_t indicate_src_change = 0;<br> struct ast_bridge_features *channel_features;<br> struct ast_channel *swap;<br> <br>@@ -2746,7 +2747,7 @@<br> */<br> if (!(bridge_channel->bridge->technology->capabilities<br> & AST_BRIDGE_CAPABILITY_MULTIMIX)) {<br>- ast_indicate(bridge_channel->chan, AST_CONTROL_SRCCHANGE);<br>+ indicate_src_change = 1;<br> }<br> <br> bridge_channel_impart_signal(bridge_channel->chan);<br>@@ -2756,6 +2757,10 @@<br> ao2_t_cleanup(swap, "Bridge push with swap successful");<br> swap = NULL;<br> <br>+ if (indicate_src_change) {<br>+ ast_indicate(bridge_channel->chan, AST_CONTROL_SRCCHANGE);<br>+ }<br>+<br> bridge_channel_event_join_leave(bridge_channel, AST_BRIDGE_HOOK_TYPE_JOIN);<br> <br> while (bridge_channel->state == BRIDGE_CHANNEL_STATE_WAIT) {<br></pre><p>To view, visit <a href="https://gerrit.asterisk.org/9069">change 9069</a>. To unsubscribe, visit <a href="https://gerrit.asterisk.org/settings">settings</a>.</p><div itemscope itemtype="http://schema.org/EmailMessage"><div itemscope itemprop="action" itemtype="http://schema.org/ViewAction"><link itemprop="url" href="https://gerrit.asterisk.org/9069"/><meta itemprop="name" content="View Change"/></div></div>
<div style="display:none"> Gerrit-Project: asterisk </div>
<div style="display:none"> Gerrit-Branch: 13 </div>
<div style="display:none"> Gerrit-MessageType: newchange </div>
<div style="display:none"> Gerrit-Change-Id: I5f86c1e2ce75b9929a36ab589b18c450e62ea35f </div>
<div style="display:none"> Gerrit-Change-Number: 9069 </div>
<div style="display:none"> Gerrit-PatchSet: 1 </div>
<div style="display:none"> Gerrit-Owner: Pirmin Walthert <infos@nappsoft.ch> </div>