res_format_attr_g729: Add annexb=no format parameter to SDPs
authorKevin Harwell <kharwell@digium.com>
Tue, 16 Aug 2016 20:57:24 +0000 (15:57 -0500)
committerKevin Harwell <kharwell@digium.com>
Thu, 18 Aug 2016 22:14:04 +0000 (17:14 -0500)
Historically, Asterisk has always specified annexb=no for the g729 format.
However, when using res_pjsip no format attribute was specified. This patch
makes it so the SDP now contains a format attribute line with annexb=no.

Note, that this means only g729a is negotiated. Even for pass through support.
According to rfc7261 the type of annex used (a or b) is dependent upon the
answerer. However, Asterisk being a back to back user agent makes this tricky
to support at this time, thus we only allow annex 'a' for now.

ASTERISK-26228 #close
patches:
  res_format_attr_g729.c submitted by Jason Parker (license 4993)

Change-Id: I76bc20cc0a01af01536e9915afef319c269c22d0

channels/chan_sip.c
res/res_format_attr_g729.c [new file with mode: 0644]

index f57d467..6250731 100644 (file)
@@ -12982,10 +12982,7 @@ static void add_codec_to_sdp(const struct sip_pvt *p,
 
        framing = ast_format_cap_get_format_framing(p->caps, format);
 
-       if (ast_format_cmp(format, ast_format_g729) == AST_FORMAT_CMP_EQUAL) {
-               /* Indicate that we don't support VAD (G.729 annex B) */
-               ast_str_append(a_buf, 0, "a=fmtp:%d annexb=no\r\n", rtp_code);
-       } else if (ast_format_cmp(format, ast_format_g723) == AST_FORMAT_CMP_EQUAL) {
+       if (ast_format_cmp(format, ast_format_g723) == AST_FORMAT_CMP_EQUAL) {
                /* Indicate that we don't support VAD (G.723.1 annex A) */
                ast_str_append(a_buf, 0, "a=fmtp:%d annexa=no\r\n", rtp_code);
        } else if (ast_format_cmp(format, ast_format_g719) == AST_FORMAT_CMP_EQUAL) {
diff --git a/res/res_format_attr_g729.c b/res/res_format_attr_g729.c
new file mode 100644 (file)
index 0000000..5ba4920
--- /dev/null
@@ -0,0 +1,76 @@
+/*
+ * Asterisk -- An open source telephony toolkit.
+ *
+ * Copyright (C) 2016, Digium, Inc.
+ *
+ * Jason Parker <jparker@sangoma.com>
+ *
+ * See http://www.asterisk.org for more information about
+ * the Asterisk project. Please do not directly contact
+ * any of the maintainers of this project for assistance;
+ * the project provides a web site, mailing lists and IRC
+ * channels for your use.
+ *
+ * This program is free software, distributed under the terms of
+ * the GNU General Public License Version 2. See the LICENSE file
+ * at the top of the source tree.
+ */
+
+/*** MODULEINFO
+       <support_level>core</support_level>
+ ***/
+
+#include "asterisk.h"
+
+ASTERISK_REGISTER_FILE()
+
+#include "asterisk/module.h"
+#include "asterisk/format.h"
+
+/* Destroy is a required callback and must exist */
+static void g729_destroy(struct ast_format *format)
+{
+}
+
+/* Clone is a required callback and must exist */
+static int g729_clone(const struct ast_format *src, struct ast_format *dst)
+{
+       return 0;
+}
+
+static void g729_generate_sdp_fmtp(const struct ast_format *format, unsigned int payload, struct ast_str **str)
+{
+       /*
+        * According to the rfc the joint annexb format parameter should be set to 'yes'
+        * or 'no' based on the answerer (rfc7261 - 3.3). However, Asterisk being a B2BUA
+        * makes things tricky. So for now Asterisk will set annexb=no.
+        */
+       ast_str_append(str, 0, "a=fmtp:%u annexb=no\r\n", payload);
+}
+
+static struct ast_format_interface g729_interface = {
+       .format_destroy = g729_destroy,
+       .format_clone = g729_clone,
+       .format_generate_sdp_fmtp = g729_generate_sdp_fmtp,
+};
+
+static int load_module(void)
+{
+       if (ast_format_interface_register("g729", &g729_interface)) {
+               return AST_MODULE_LOAD_DECLINE;
+       }
+
+       return AST_MODULE_LOAD_SUCCESS;
+}
+
+static int unload_module(void)
+{
+       return 0;
+}
+
+AST_MODULE_INFO(ASTERISK_GPL_KEY, AST_MODFLAG_LOAD_ORDER, "G.729 Format Attribute Module",
+       .support_level = AST_MODULE_SUPPORT_CORE,
+       .load = load_module,
+       .unload = unload_module,
+       .load_pri = AST_MODPRI_CHANNEL_DEPEND,
+);