[asterisk-bugs] [Asterisk 0012354]: [patch] Race condition in manager interface.
noreply at bugs.digium.com
noreply at bugs.digium.com
Wed Apr 2 11:34:11 CDT 2008
The following issue has been ASSIGNED.
======================================================================
http://bugs.digium.com/view.php?id=12354
======================================================================
Reported By: bamby
Assigned To: putnopvut
======================================================================
Project: Asterisk
Issue ID: 12354
Category: Core/ManagerInterface
Reproducibility: random
Severity: major
Priority: normal
Status: assigned
Asterisk Version: 1.4.18
SVN Branch (only for SVN checkouts, not tarball releases): N/A
SVN Revision (number only!):
Disclaimer on File?: N/A
Request Review:
======================================================================
Date Submitted: 04-02-2008 08:48 CDT
Last Modified: 04-02-2008 11:34 CDT
======================================================================
Summary: [patch] Race condition in manager interface.
Description:
I use the manager interface (not HTTP) to identify the state of the channel
and state changes are to be detected as soon as possible. However I
experienced strange random delays that could last for several seconds
especially if the system had small load.
I've made investigation of the issue and found a cause of the problem. An
events get reported via manager_event() function which appends the event to
event queue and tries to inform the manager session thread about new event.
Notification is done via pthread_kill(s->waiting_thread, SIGURG) call in
order to interrupt the poll() call in get_input() function. But the problem
is that the waiting_thread field has valid value only during the poll()
call. Immediately after the poll() the waiting_thread is cleared and stays
NULL until next poll(). So if an event comes at the instant when
waiting_thread is AST_PTHREAD_NULL then this event has a good chance to
stay unnoticed until next event or input from client.
I've added a field to the struct mansession that act as a pending event
indicator when the waiting_thread is NULL. This works pretty well for me.
======================================================================
Issue History
Date Modified Username Field Change
======================================================================
04-02-08 11:34 putnopvut Status new => assigned
04-02-08 11:34 putnopvut Assigned To => putnopvut
======================================================================
More information about the asterisk-bugs
mailing list