mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-25 15:08:53 +00:00
Set threshold for silence detection defaults to 256
(closes issue #15685) Reported by: david_s5 Patches: dsp-silence-threshold-init.diff uploaded by dant (license 670) issue15685.patch.v5 uploaded by pabelanger (license 224) Tested by: danti Review: https://reviewboard.asterisk.org/r/670/ git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@268690 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
22
main/dsp.c
22
main/dsp.c
@@ -213,6 +213,12 @@ enum gsamp_thresh {
|
|||||||
/* How many successive misses needed to consider end of a digit */
|
/* How many successive misses needed to consider end of a digit */
|
||||||
#define DTMF_MISSES_TO_END 3
|
#define DTMF_MISSES_TO_END 3
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* \brief The default silence threshold we will use if an alternate
|
||||||
|
* configured value is not present or is invalid.
|
||||||
|
*/
|
||||||
|
static const int DEFAULT_SILENCE_THRESHOLD = 256;
|
||||||
|
|
||||||
#define CONFIG_FILE_NAME "dsp.conf"
|
#define CONFIG_FILE_NAME "dsp.conf"
|
||||||
|
|
||||||
typedef struct {
|
typedef struct {
|
||||||
@@ -1674,19 +1680,25 @@ static int _dsp_init(int reload)
|
|||||||
struct ast_config *cfg;
|
struct ast_config *cfg;
|
||||||
|
|
||||||
cfg = ast_config_load2(CONFIG_FILE_NAME, "dsp", config_flags);
|
cfg = ast_config_load2(CONFIG_FILE_NAME, "dsp", config_flags);
|
||||||
if (cfg == CONFIG_STATUS_FILEMISSING || cfg == CONFIG_STATUS_FILEUNCHANGED || cfg == CONFIG_STATUS_FILEINVALID) {
|
if (cfg == CONFIG_STATUS_FILEMISSING || cfg == CONFIG_STATUS_FILEINVALID) {
|
||||||
|
ast_verb(5, "Can't find dsp config file %s. Assuming default silencethreshold of %d.\n", CONFIG_FILE_NAME, DEFAULT_SILENCE_THRESHOLD);
|
||||||
|
thresholds[THRESHOLD_SILENCE] = DEFAULT_SILENCE_THRESHOLD;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cfg && cfg != CONFIG_STATUS_FILEUNCHANGED) {
|
if (cfg == CONFIG_STATUS_FILEUNCHANGED) {
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (cfg) {
|
||||||
const char *value;
|
const char *value;
|
||||||
|
|
||||||
value = ast_variable_retrieve(cfg, "default", "silencethreshold");
|
value = ast_variable_retrieve(cfg, "default", "silencethreshold");
|
||||||
if (value && sscanf(value, "%30d", &thresholds[THRESHOLD_SILENCE]) != 1) {
|
if (value && sscanf(value, "%30d", &thresholds[THRESHOLD_SILENCE]) != 1) {
|
||||||
ast_log(LOG_WARNING, "%s: '%s' is not a valid silencethreshold value\n", CONFIG_FILE_NAME, value);
|
ast_verb(5, "%s: '%s' is not a valid silencethreshold value\n", CONFIG_FILE_NAME, value);
|
||||||
thresholds[THRESHOLD_SILENCE] = 256;
|
thresholds[THRESHOLD_SILENCE] = DEFAULT_SILENCE_THRESHOLD;
|
||||||
} else if (!value) {
|
} else if (!value) {
|
||||||
thresholds[THRESHOLD_SILENCE] = 256;
|
thresholds[THRESHOLD_SILENCE] = DEFAULT_SILENCE_THRESHOLD;
|
||||||
}
|
}
|
||||||
|
|
||||||
ast_config_destroy(cfg);
|
ast_config_destroy(cfg);
|
||||||
|
Reference in New Issue
Block a user