[asterisk-bugs] [Asterisk 0018165]: hint state changes deadlock problem
Asterisk Bug Tracker
noreply at bugs.digium.com
Tue Oct 19 14:37:01 CDT 2010
A NOTE has been added to this issue.
======================================================================
https://issues.asterisk.org/view.php?id=18165
======================================================================
Reported By: antonio
Assigned To:
======================================================================
Project: Asterisk
Issue ID: 18165
Category: Core/PBX
Reproducibility: have not tried
Severity: major
Priority: normal
Status: new
Asterisk Version: 1.6.2.13
JIRA:
Regression: No
Reviewboard Link:
SVN Branch (only for SVN checkouts, not tarball releases): N/A
SVN Revision (number only!):
Request Review:
======================================================================
Date Submitted: 2010-10-19 13:45 CDT
Last Modified: 2010-10-19 14:37 CDT
======================================================================
Summary: hint state changes deadlock problem
Description:
What happens is there are two threads that lock resources in a different
order causing a deadlock.
The threads are:
1. from taskprocessor handle_statechange() is called. This one locks
ast_rdlock_contexts, and then eventually call cb_extensionstate() which
immediately does a sip_pvt_lock()
2. do_monitor calls sipsock_read() which calls handle_request_do() which
calls find_call(), which does a sip_pvt_lock() too. The incoming request is
a subscription, so it calls ast_get_hint(), which calls
ast_hint_extension() which calls ast_rdlock_contexts(). Deadlock.
======================================================================
----------------------------------------------------------------------
(0128209) schmidts (manager) - 2010-10-19 14:37
https://issues.asterisk.org/view.php?id=18165#c128209
----------------------------------------------------------------------
with 1.6.2.14rc1 it should happens on more times cause handle_statechange
is just much slower in 1.6.2.14 so the possible deadlock could easier
occur.
i had found an easy way to reproduce this by sending 400 subscribes per
second with sipp but it doesnt happen allways.
Issue History
Date Modified Username Field Change
======================================================================
2010-10-19 14:37 schmidts Note Added: 0128209
======================================================================
More information about the asterisk-bugs
mailing list