]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
Let channels joining a MeetMe conference opt out of the denoiser
authorMatthew Jordan <mjordan@digium.com>
Thu, 28 Feb 2013 16:49:46 +0000 (16:49 +0000)
committerMatthew Jordan <mjordan@digium.com>
Thu, 28 Feb 2013 16:49:46 +0000 (16:49 +0000)
For some channel drivers, specifically those that have a varying rate in the
number of audio samples, the audio quality for a MeetMe conference can be
exceedingly poor. This is due to a unilateral application of the DENOISE
function in func_speex to channels joining the conference.

The denoiser function in the speex library is initialized with the number of
audio samples in each sample that will be provided to it. If the number of
audio samples changes, the denoiser has to be thrown away and re-initialized.

While this could be worked around by removing func_speex, that doesn't help
if you actually use the denoiser with other channels on the system.

This patches does the following:
 * Checks for the presence of func_speex as opposed to codec_speex when
   determining if the DENOISE function is present (which is where the function
   is actually implemented)
 * Adds an option to MeetMe 'n' that causes the denoiser to not be applied
   to a channel when it joins. This keeps the current behavior the default, but
   let's users disable the denoiser if it causes problems on their system.

Review: https://reviewboard.asterisk.org/r/2358

(closes issue AST-1062)
Reported by: Thomas Arimont
........

Merged revisions 382227 from http://svn.asterisk.org/svn/asterisk/branches/1.8

git-svn-id: https://origsvn.digium.com/svn/asterisk/certified/branches/1.8.15@382228 65c4cc65-6c06-0410-ace0-fbb531ad65f3

UPGRADE.txt
apps/app_meetme.c

index 507babd8431866e4a1f772e6252feb97096dbfe0..8e22cb736af56413b22472bcb38aa8c2133360c7 100644 (file)
 === UPGRADE-1.6.txt -- Upgrade info for 1.4 to 1.6
 ===
 ===========================================================
-from 1.8.17 to 1.8.18:
+
+from 1.8.15-cert1 to 1.8.15-cert2
+* Added the 'n' option to MeetMe to prevent application of the DENOISE function
+  to a channel joining a conference. Some channel drivers that vary the number
+  of audio samples in a voice frame will experience significant quality problems
+  if a denoiser is attached to the channel; this option gives them the ability
+  to remove the denoiser without having to unload func_speex.
+
+from 1.8.11 to 1.8.15-cert1
 * Queue strategy rrmemory now has a predictable order similar to strategy
   rrordered. Members will be called in the order that they are added to the
   queue.
index 77db47bfc942b0e94577a6c4bb71994d7ef07d63..481a024c77beb43fa45bbeb86751377944612c4f 100644 (file)
@@ -134,6 +134,14 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
                                                channel's currently set music class, or <literal>default</literal>.</para>
                                                <argument name="class" required="true" />
                                        </option>
+                                       <option name="n">
+                                               <para>Disable the denoiser. By default, if <literal>func_speex</literal> is loaded, Asterisk
+                                               will apply a denoiser to channels in the MeetMe conference. However, channel
+                                               drivers that present audio with a varying rate will experience degraded
+                                               performance with a denoiser attached. This parameter allows a channel joining
+                                               the conference to choose not to have a denoiser attached without having to
+                                               unload <literal>func_speex</literal>.</para>
+                                       </option>
                                        <option name="o">
                                                <para>Set talker optimization - treats talkers who aren't speaking as
                                                being muted, meaning (a) No encode is done on transmission and (b)
@@ -616,6 +624,8 @@ enum {
 #define CONFFLAG_NO_AUDIO_UNTIL_UP  (1ULL << 31)
 /*! If set play an intro announcement at start of conference */
 #define CONFFLAG_INTROMSG           (1ULL << 32)
+/*! If set, don't enable a denoiser for the channel */
+#define CONFFLAG_DONT_DENOISE       (1ULL << 33)
 
 enum {
        OPT_ARG_WAITMARKED = 0,
@@ -643,6 +653,7 @@ AST_APP_OPTIONS(meetme_opts, BEGIN_OPTIONS
        AST_APP_OPTION('I', CONFFLAG_INTROUSERNOREVIEW ),
        AST_APP_OPTION_ARG('M', CONFFLAG_MOH, OPT_ARG_MOH_CLASS ),
        AST_APP_OPTION('m', CONFFLAG_STARTMUTED ),
+       AST_APP_OPTION('n', CONFFLAG_DONT_DENOISE ),
        AST_APP_OPTION('o', CONFFLAG_OPTIMIZETALKER ),
        AST_APP_OPTION('P', CONFFLAG_ALWAYSPROMPT ),
        AST_APP_OPTION_ARG('p', CONFFLAG_KEYEXIT, OPT_ARG_EXITKEYS ),
@@ -2588,7 +2599,8 @@ static int conf_run(struct ast_channel *chan, struct ast_conference *conf, struc
        }
 
        /* Reduce background noise from each participant */
-       if ((mod_speex = ast_module_helper("", "codec_speex", 0, 0, 0, 0))) {
+       if (!ast_test_flag64(confflags, CONFFLAG_DONT_DENOISE) &&
+               (mod_speex = ast_module_helper("", "func_speex", 0, 0, 0, 0))) {
                ast_free(mod_speex);
                ast_func_write(chan, "DENOISE(rx)", "on");
        }