From d6916b35106e946b42d6508ee65fab9eabcbfe6d Mon Sep 17 00:00:00 2001 From: Evangelos Ribeiro Tzaras Date: Mon, 26 Apr 2021 18:08:43 +0200 Subject: [PATCH] sip: media-pipeline: Do not set the stream properties prematurely --- plugins/sip/calls-sip-media-pipeline.c | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/plugins/sip/calls-sip-media-pipeline.c b/plugins/sip/calls-sip-media-pipeline.c index 288fb75..a7aa02e 100644 --- a/plugins/sip/calls-sip-media-pipeline.c +++ b/plugins/sip/calls-sip-media-pipeline.c @@ -384,6 +384,22 @@ initable_init (GInitable *initable, "stream-properties", props, NULL); + gst_structure_free (props); + } + + env_var = g_getenv ("CALLS_AUDIOSRC"); + if (env_var) { + self->audiosrc = gst_element_factory_make (env_var, "source"); + } else { + /* could also use autoaudiosrc instead of pulsesrc */ + self->audiosrc = gst_element_factory_make ("pulsesrc", "source"); + + /* enable echo cancellation and set buffer size to 40ms */ + props = gst_structure_new ("props", + "media.role", G_TYPE_STRING, "phone", + "filter.want", G_TYPE_STRING, "echo-cancel", + NULL); + g_object_set (self->audiosrc, "buffer-time", (gint64) 40000, "stream-properties", props, @@ -392,12 +408,6 @@ initable_init (GInitable *initable, gst_structure_free (props); } - env_var = g_getenv ("CALLS_AUDIOSRC"); - if (env_var) - self->audiosrc = gst_element_factory_make (env_var, "source"); - else - self->audiosrc = gst_element_factory_make ("pulsesrc", "source"); - if (!self->audiosrc || !self->audiosink) { g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED, "Could not create audiosink or audiosrc");