[asterisk-dev] [Code Review] Fix local channel chains optimizing themselves out of a call.

Alec Davis reviewboard at asterisk.org
Wed May 2 03:18:26 CDT 2012


-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://reviewboard.asterisk.org/r/1894/#review6126
-----------------------------------------------------------


Referring to https://issues.asterisk.org/jira/browse/18028

Tested by dialling 10127 (thus 127 looped calls)
   the exceptionally long queue, wasn't reported before or after applying this patch.
   After patch successfully (very fast) optimizes out all required calls when using the dialplan.

Any more calls (ie 128) I did have hung channels, but was able to hang them up with 'channel request hangup'

- Alec


On May 1, 2012, 5:52 p.m., rmudgett wrote:
> 
> -----------------------------------------------------------
> This is an automatically generated e-mail. To reply, visit:
> https://reviewboard.asterisk.org/r/1894/
> -----------------------------------------------------------
> 
> (Updated May 1, 2012, 5:52 p.m.)
> 
> 
> Review request for Asterisk Developers.
> 
> 
> Summary
> -------
> 
> The masquerade torture test (ASTERISK-19807) is a long chain of local channels to be optimized out of a call when answered.
> This patch fixes local channel so it can successfully optimize itself out when there are chains of channels.
> 
> The principle problem was check_bridge() failed to check the ast_channel_masquerade() return value to see if the masquerade was actually setup.  In long chains of local channels, the masquerade occasionally fails to get setup because there is another masquerade already setup on an adjacent local channel in the chain.
> 
> * Checks the return value of ast_channel_masquerade().
> 
> * Made sure that the outgoing local channel (the ;2 channel) also does not have any frames in its queue before the masquerade.
> 
> * The outgoing channel will flush one voice or video frame per optimization attempt.
> 
> * Do the masquerade immediately to ensure that the outgoing channel queue does not get any new frames added and thus unconditionally flushed.
> 
> * Blocks indication -1 (Stop tones event) when the local channel is going to optimize itself out.  When the call is answered, a chain of local channels pass down a -1 indication for each bridge.  This blizzard of -1 events really slows down the optimization process.
> 
> 
> Diffs
> -----
> 
>   /branches/1.8/channels/chan_local.c 364846 
> 
> Diff: https://reviewboard.asterisk.org/r/1894/diff
> 
> 
> Testing
> -------
> 
> Chains of 100 local channels now are able to optimize themselves out.
> 
> 
> Thanks,
> 
> rmudgett
> 
>

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.digium.com/pipermail/asterisk-dev/attachments/20120502/e55e5128/attachment.htm>


More information about the asterisk-dev mailing list