]> git.ipfire.org Git - thirdparty/asterisk.git/commit
app_dial.c: Moved channel lock to prevent deadlock 21
authorAlexey Khabulyak <khabalex@gmail.com>
Mon, 4 Aug 2025 14:48:57 +0000 (17:48 +0300)
committerAlexey Khabulyak <khabalex@gmail.com>
Mon, 11 Aug 2025 14:37:12 +0000 (14:37 +0000)
commit15f93f8cfa586d2f0d688b8534e915eefa00cbc2
treed0348ec9ed0e7bf289f5637832efbf2eacabf696
parent9fa3bb031efb0e78a2472cf187f758413fb3fb28
app_dial.c: Moved channel lock to prevent deadlock

It's reproducible with pbx_lua, not regular dialplan.

deadlock description:
1. asterisk locks a channel
2. calls function onedigit_goto
3. calls ast_goto_if_exists funciton
4. checks ast_exists_extension -> pbx_extension_helper
5. pbx_extension_helper calls pbx_find_extension
6. Then asterisk starts autoservice in a new thread
7. autoservice run tries to lock the channel again

Because our channel is locked already, autoservice can't lock.
Autoservice can't lock -> autoservice stop is waiting forever.
onedigit_goto waits for autoservice stop.

Resolves: https://github.com/asterisk/asterisk/issues/1335
apps/app_dial.c