[asterisk-bugs] [JIRA] (ASTERISK-28143) app_amd: Infinite loop on silent calls

Jessie Kid Fernando (JIRA) noreply at issues.asterisk.org
Fri Oct 25 08:12:48 CDT 2019


    [ https://issues.asterisk.org/jira/browse/ASTERISK-28143?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=248528#comment-248528 ] 

Jessie Kid Fernando edited comment on ASTERISK-28143 at 10/25/19 8:10 AM:
--------------------------------------------------------------------------

I have compiled this one and currently this is the code from line 280 - 308. Let me know if this is correct.

 280         /* Now we go into a loop waiting for frames from the channel */
    281         while ((res = ast_waitfor(chan, 2 * maxWaitTimeForFrame)) > -1) {
    282                 int ms = 0;
    283
    284                 /* Figure out how long we waited */
    285                 if (res > 0) {
    286                         ms = 2 * maxWaitTimeForFrame - res;
    287                 } else {
    288                         ms = 2 * maxWaitTimeForFrame;
    289                 }
    290
    291                 /* If we fail to read in a frame, that means they hung up */
    292                 if (!(f = ast_read(chan))) {
    293                         ast_verb(3, "AMD: Channel [%s]. HANGUP\n", ast_channel_name(chan));
    294                         ast_debug(1, "Got hangup\n");
    295                         strcpy(amdStatus, "HANGUP");
    296                         res = 1;
    297                         break;
    298                 }
    299
    300                 if (f->frametype == AST_FRAME_VOICE || f->frametype == AST_FRAME_CNG || f->frametype == AST_FRAME        _NULL) {
    301                         /* Figure out how long the frame is in milliseconds */
    302                         if (f->frametype == AST_FRAME_VOICE) {
    303                                 framelength = (ast_codec_samples_count(f) / DEFAULT_SAMPLES_PER_MS);
    304                         } else {
    305                                 framelength = ms;
    306                         }
    307
    308                         iTotalTime += framelength;



was (Author: jessiekidf at gmail.com):
I have compiled this one and currently this is the code from line 280 - 308

 280         /* Now we go into a loop waiting for frames from the channel */
    281         while ((res = ast_waitfor(chan, 2 * maxWaitTimeForFrame)) > -1) {
    282                 int ms = 0;
    283
    284                 /* Figure out how long we waited */
    285                 if (res > 0) {
    286                         ms = 2 * maxWaitTimeForFrame - res;
    287                 } else {
    288                         ms = 2 * maxWaitTimeForFrame;
    289                 }
    290
    291                 /* If we fail to read in a frame, that means they hung up */
    292                 if (!(f = ast_read(chan))) {
    293                         ast_verb(3, "AMD: Channel [%s]. HANGUP\n", ast_channel_name(chan));
    294                         ast_debug(1, "Got hangup\n");
    295                         strcpy(amdStatus, "HANGUP");
    296                         res = 1;
    297                         break;
    298                 }
    299
    300                 if (f->frametype == AST_FRAME_VOICE || f->frametype == AST_FRAME_CNG || f->frametype == AST_FRAME        _NULL) {
    301                         /* Figure out how long the frame is in milliseconds */
    302                         if (f->frametype == AST_FRAME_VOICE) {
    303                                 framelength = (ast_codec_samples_count(f) / DEFAULT_SAMPLES_PER_MS);
    304                         } else {
    305                                 framelength = ms;
    306                         }
    307
    308                         iTotalTime += framelength;


> app_amd: Infinite loop on silent calls 
> ---------------------------------------
>
>                 Key: ASTERISK-28143
>                 URL: https://issues.asterisk.org/jira/browse/ASTERISK-28143
>             Project: Asterisk
>          Issue Type: Bug
>      Security Level: None
>          Components: Applications/app_amd
>    Affects Versions: 15.6.1
>         Environment: Ubuntu with asterisk 
>            Reporter: Abhay Gupta
>            Assignee: Abhay Gupta
>              Labels: patch
>      Target Release: 13.27.0, 16.4.0, 17.0.0
>
>         Attachments: amd.patch
>
>
> On our production server , some of the calls never return from AMD application , from logs we could see that they have last gone into AMD() of dialplan and comes out only when the call is HANGUP .
> The suggested patch is to remove that infinite loop and has been tested for last few months and have been working well .



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



More information about the asterisk-bugs mailing list