[asterisk-bugs] [JIRA] (ASTERISK-22976) app_queue function queue_show() and find_queue_by_name_rt() cause deadlock

Joshua C. Colp (JIRA) noreply at issues.asterisk.org
Mon Jan 4 04:57:17 CST 2021


     [ https://issues.asterisk.org/jira/browse/ASTERISK-22976?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Joshua C. Colp closed ASTERISK-22976.
-------------------------------------

    Resolution: Fixed

> app_queue function queue_show() and find_queue_by_name_rt() cause deadlock 
> ---------------------------------------------------------------------------
>
>                 Key: ASTERISK-22976
>                 URL: https://issues.asterisk.org/jira/browse/ASTERISK-22976
>             Project: Asterisk
>          Issue Type: Bug
>      Security Level: None
>          Components: Applications/app_queue
>    Affects Versions: 1.8.24.0, 13.18.4
>         Environment: CentOS5.8 X64 DellR410 Asterisk 1.8 trunk version
>            Reporter: Aaron An
>            Assignee: Unassigned
>            Severity: Critical
>
> I use "queue show xxxx" to monitor queue status, and use realtime queue. concurrency is about 100 calls. deadlock will be occur after 10-30minutes.
> analysis result:
> in find_queue_by_name_rt() first lock single queue "ao2_lock(q);" and then lock global queues "queues_t_unlink(queues, q, "Unused; removing from container");";
> in __queues_show() first lock global queues "ao2_lock(queues);" then lock single queue "ao2_lock(q);"
> so it causes dead lock.



--
This message was sent by Atlassian JIRA
(v6.2#6252)



More information about the asterisk-bugs mailing list