]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
channel: Fix memory leak in suppress API.
authorJoshua C. Colp <jcolp@sangoma.com>
Wed, 3 Mar 2021 13:32:22 +0000 (09:32 -0400)
committerJoshua Colp <jcolp@sangoma.com>
Wed, 3 Mar 2021 16:15:10 +0000 (10:15 -0600)
A frame suppression API exists as part of channels
which allows audio frames to or from a channel to
be dropped. The MuteAudio AMI action uses this
API to perform its job.

This API uses a framehook to intercept flowing
audio and drop it when appropriate. It is the
responsibility of the framehook to free the
frame it is given if it changes the frame. The
suppression API failed to do this resulting in
a leak of audio frames.

This change adds the freeing of these frames.

ASTERISK-29071

Change-Id: Ie50acd454d672d36af914050c327d2e120d8ba7b

main/channel.c

index 253b6635041f342d27d39dcd9f43c20a5a563b6b..64d93c4fe731bea3a65e93953c23e18cae803a44 100644 (file)
@@ -10845,6 +10845,7 @@ static struct ast_frame *suppress_framehook_event_cb(struct ast_channel *chan, s
        if (suppress_frame) {
                switch (frame->frametype) {
                case AST_FRAME_VOICE:
+                       ast_frfree(frame);
                        frame = &ast_null_frame;
                        break;
                default: