Files
asterisk/include/asterisk
Richard Mudgett 01b999f833 Allow AMI action callback to be reentrant.
Fix AMI module reload deadlock regression from ASTERISK-18479 when it
tried to fix the race between calling an AMI action callback and
unregistering that action.  Refixes ASTERISK-13784 broken by
ASTERISK-17785 change.

Locking the ao2 object guaranteed that there were no active callbacks that
mattered when ast_manager_unregister() was called.  Unfortunately, this
causes the deadlock situation.  The patch stops locking the ao2 object to
allow multiple threads to invoke the callback re-entrantly.  There is no
way to guarantee a module unload will not crash because of an active
callback.  The code attempts to minimize the chance with the registered
flag and the maximum 5 second delay before ast_manager_unregister()
returns.

The trunk version of the patch changes the API to fix the race condition
correctly to prevent the module code from unloading from memory while an
action callback is active.

* Don't hold the lock while calling the AMI action callback.

(closes issue ASTERISK-19487)
Reported by: Philippe Lindheimer

Review: https://reviewboard.asterisk.org/r/1818/
Review: https://reviewboard.asterisk.org/r/1820/
........

Merged revisions 359979 from http://svn.asterisk.org/svn/asterisk/branches/1.8


git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/10@359980 65c4cc65-6c06-0410-ace0-fbb531ad65f3
2012-03-20 17:25:44 +00:00
..
2010-06-02 18:10:15 +00:00
2009-04-29 18:53:01 +00:00
2010-06-08 14:38:18 +00:00
2011-12-16 21:04:01 +00:00
2011-12-22 20:17:39 +00:00
2010-06-08 14:38:18 +00:00
2011-11-23 17:14:41 +00:00
2011-11-29 00:00:11 +00:00
2009-06-15 16:07:23 +00:00
2010-07-23 16:19:21 +00:00
2012-02-24 15:07:41 +00:00
2010-08-30 08:25:50 +00:00
2011-10-11 18:41:05 +00:00
2010-06-08 14:38:18 +00:00
2010-06-08 14:38:18 +00:00
2010-06-08 14:38:18 +00:00