chan_sip.c: Fix t38id deadlock potential.
authorRichard Mudgett <rmudgett@digium.com>
Thu, 10 Mar 2016 18:17:09 +0000 (12:17 -0600)
committerRichard Mudgett <rmudgett@digium.com>
Wed, 16 Mar 2016 19:44:51 +0000 (14:44 -0500)
commitfbf8e04aed120930bca370fb41a40e4eac7dd134
tree5ed27615440834439be50f1b647add196dbbae12
parentc7fdff2e379c65413187433f9f4fac3f332fcf20
chan_sip.c: Fix t38id deadlock potential.

This patch is part of a series to resolve deadlocks in chan_sip.c.

Stopping a scheduled event can result in a deadlock if the scheduled event
is running when you try to stop the event.  If you hold a lock needed by
the scheduled event while trying to stop the scheduled event then a
deadlock can happen.  The general strategy for resolving the deadlock
potential is to push the actual starting and stopping of the scheduled
events off onto the scheduler/do_monitor() thread by scheduling an
immediate one shot scheduled event.  Some restructuring may be needed
because the code may assume that the start/stop of the scheduled events is
immediate.

ASTERISK-25023

Change-Id: If595e4456cd059d7171880c7f354e844c21b5f5f
channels/chan_sip.c