Fix stuck channel in ARI through the introduction of synchronous bridge actions.
authorMark Michelson <mmichelson@digium.com>
Mon, 17 Mar 2014 17:22:12 +0000 (17:22 +0000)
committerMark Michelson <mmichelson@digium.com>
Mon, 17 Mar 2014 17:22:12 +0000 (17:22 +0000)
commitd44aefeef476d744f2915d47c3fdc9b138cdd584
tree59aa013e9a8c0fb7ab1607e2e98076dd88a60f1b
parent1900bae7b6cec9479ba0e89aed31d02aa71f3133
Fix stuck channel in ARI through the introduction of synchronous bridge actions.

Playing back a file to a channel in an ARI bridge would attempt to wait until
the playback concluded before returning. The method used involved signaling the
waiting thread in the ARI custom playback function.

The problem with this is that there were some corner cases that were not accounted for:
* If a bridge channel could not be found, then we never would attempt the playback but
  would still attempt to wait for the playback to complete.
* If the bridge playfile action failed to queue, we would still attempt to wait for the
  playback to complete.
* If the bridge playfile action were queued but some circumstance caused the playback
  not to occur (the bridge dies, the channel is removed from the bridge), then we would
  never be notified.

The solution to this is to move the waiting logic into the bridge code. A new bridge
API function is added to queue a synchronous action on a bridge. The waiting thread
is notified when the queued frame has been freed, either due to an error occurring
or due to successful playback. As a failsafe, the waiting thread has a 10 minute
timeout just in case there is a frame leak somewhere.

Review: https://reviewboard.asterisk.org/r/3338
........

Merged revisions 410673 from http://svn.asterisk.org/svn/asterisk/branches/12

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@410684 65c4cc65-6c06-0410-ace0-fbb531ad65f3
17 files changed:
bridges/bridge_softmix.c
configs/sorcery.conf.sample
funcs/func_frame_trace.c
include/asterisk/bridge_channel.h
include/asterisk/frame.h
include/asterisk/sorcery.h
main/bridge_channel.c
main/channel.c
main/frame.c
main/sorcery.c
res/res_mwi_external.c
res/res_pjsip/config_system.c
res/res_pjsip/pjsip_configuration.c
res/res_stasis_playback.c
tests/test_sorcery.c
tests/test_sorcery_astdb.c
tests/test_sorcery_realtime.c