[asterisk-bugs] [JIRA] (ASTERISK-21916) Call hangs when FILTER function is used in dial plan
Walter Doekes (JIRA)
noreply at issues.asterisk.org
Mon Jun 17 06:25:03 CDT 2013
[ https://issues.asterisk.org/jira/browse/ASTERISK-21916?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=207300#comment-207300 ]
Walter Doekes commented on ASTERISK-21916:
------------------------------------------
{noformat}
[Jun 16 19:44:29] VERBOSE[13295][C-00000003] pbx.c: [Jun 16 19:44:29] -- Executing [**4 at admin:1] Goto("SIP/lizzy-00000001", "dialing,**4,1") in new stack
[Jun 16 19:44:29] VERBOSE[13295][C-00000003] pbx.c: [Jun 16 19:44:29] -- Goto (dialing,**4,1)
[Jun 16 19:44:29] DEBUG[13295][C-00000003] func_strings.c: c1=48, c2=57
{noformat}
The FILTER func is being run:
{noformat}
static int filter(struct ast_channel *chan, const char *cmd, char *parse, char *buf,
size_t len)
...
ast_debug(4, "c1=%d, c2=%d\n", c1, c2);
{noformat}
So it runs through the loop, and on the next run, it stalls?
For it to loop without the next debug message ("Allowed..."), it would have to stall either here:
{noformat}
if (ast_get_encoded_char(args.allowed, &c1, &consumed))
return -1;
{noformat}
here:
{noformat}
for (ac = (unsigned char) c1; ac != (unsigned char) c2; ac++) {
bitfield[ac / 32] |= 1 << (ac % 32);
}
{noformat}
or here:
{noformat}
for (ac = 1; ac != 0; ac++) {
if (bitfield[ac / 32] & (1 << (ac % 32))) {
allowed[allowedlen++] = ac;
}
}
{noformat}
Get the backtrace (thread apply all bt [full]) when it's running 100% cpu and we'll know which one it is.
> Call hangs when FILTER function is used in dial plan
> ----------------------------------------------------
>
> Key: ASTERISK-21916
> URL: https://issues.asterisk.org/jira/browse/ASTERISK-21916
> Project: Asterisk
> Issue Type: Bug
> Security Level: None
> Components: Functions/func_strings
> Affects Versions: 11.4.0
> Environment: Latest binaries of Asterisk 11.4.0 from Optware repository running on an Asus RT-n66u (Tomato USB based router, MIPS 74K V4.9) with firmware 3.0.0.4.270.25 (rmerlin variant) and Linux 2.6.22.19, installed on an ext3 partition on external HD
> Reporter: Elizabeth Hudnott
> Assignee: Elizabeth Hudnott
> Severity: Critical
> Attachments: debug.log
>
>
> Whenever the FILTER function is used in the dial plan the call hangs. No further dial plan steps get executed, ringing tone ceases, the call remains open until Asterisk is restarted and CPU utilization increases sharply.
> Simple dial plan extract to reproduce the problem:
> exten=>**4,1,Verbose(${FILTER(0-9,123)})
> same=>n,Hangup()
> This behaviour occurs consistently every time the extension is dialled from CSipSimple sofphone.
--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: https://issues.asterisk.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira
More information about the asterisk-bugs
mailing list