[asterisk-bugs] [JIRA] (ASTERISK-26570) Macro allows an infinite loop of dialplan inclusion
Rusty Newton (JIRA)
noreply at issues.asterisk.org
Thu Nov 10 16:30:10 CST 2016
[ https://issues.asterisk.org/jira/browse/ASTERISK-26570?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=233590#comment-233590 ]
Rusty Newton edited comment on ASTERISK-26570 at 11/10/16 4:29 PM:
-------------------------------------------------------------------
Attaching a huge backtrace for what it is worth.
was (Author: rnewton):
Huge backtrace for what it is worth.
> Macro allows an infinite loop of dialplan inclusion
> ---------------------------------------------------
>
> Key: ASTERISK-26570
> URL: https://issues.asterisk.org/jira/browse/ASTERISK-26570
> Project: Asterisk
> Issue Type: Bug
> Security Level: None
> Affects Versions: 11.22.0, 14.1.1
> Environment: Note: not tested with 14. Instead, tested with a fairly recent master (bf01ff53f8d93d637981720331405e56f0b3b118), on both my Debian Testing laptoop and a Centos 6 server.
> Reporter: Tzafrir Cohen
> Severity: Minor
> Attachments: backtrace.txt
>
>
> When app_macro considers the dialplan extension to execute, it loops through contexts and fails to protect from an infinite loop. The result may be a crash with over 5700 recursive calls to find_matching_priority() called from macro_exec().
> Reproduce: An Asterisk system with the following dialplan:
> {code}
> [test]
> include => test2
> ; A simplistic recursive scan never gets here
> include => test1
> exten => macro,1,Answer()
> same => n,Macro(test)
> same => n,Hangup()
> [test2]
> include => test
> [test1]
> exten => s,1,NoOp(Starting Macro)
> [macro-test]
> include => test
> {code}
> Now call the macro. E.g.:
> {code}
> channel originate Local/macro at test Application Wait 40
> {code}
--
This message was sent by Atlassian JIRA
(v6.2#6252)
More information about the asterisk-bugs
mailing list