]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
codec_builtin.c: G729 audio gets corrupted by Asterisk due to smoother
authorunder <pcapdump@gmail.com>
Thu, 22 Jul 2021 16:39:11 +0000 (19:39 +0300)
committerFriendly Automation <jenkins2@gerrit.asterisk.org>
Mon, 2 Aug 2021 19:10:15 +0000 (14:10 -0500)
If Asterisk gets G.729 6-byte VAD frames inbound, then at outbound Asterisk sends this G.729 stream with non-continuous timestamps.
This makes the audio stream not-playable at the receiver side.
Linphone isn't able to play such an audio - lots of disruptions are heard.
Also I had complains of bad audio from users which use other types of phones.

After debugging, I found this is a regression connected with RTP Smoother (main/smoother.c).

Smoother has a special code to handle G.729 VAD frames (search for AST_SMOOTHER_FLAG_G729 in smoother.c).

However, this flag is never set in Asterisk-12 and newer.
Previously it has been set (see Asterisk-11).

ASTERISK-29526 #close

Change-Id: I6f51ecb1a3ecd9c6d59ec5a6811a27446e17065d

main/codec_builtin.c

index ce65754fe449b5d50c8730a30a8e94cb5afee632..5c460bf1208b533983b3d5e22fc65a39e9d70442 100644 (file)
@@ -457,6 +457,7 @@ static struct ast_codec g729a = {
        .samples_count = g729_samples,
        .get_length = g729_length,
        .smooth = 1,
+       .smoother_flags = AST_SMOOTHER_FLAG_G729,
 };
 
 static unsigned char get_n_bits_at(unsigned char *data, int n, int bit)