aboutsummaryrefslogtreecommitdiffstats
path: root/main
diff options
context:
space:
mode:
authoralecdavis <alecdavis@f38db490-d61c-443f-a65b-d21fe96a405b>2009-12-15 03:10:36 +0000
committeralecdavis <alecdavis@f38db490-d61c-443f-a65b-d21fe96a405b>2009-12-15 03:10:36 +0000
commit2771f1aa9706153b6e774732a2927c4cba162208 (patch)
treef7b3d39104bad5af43bb44a1eba848213629a3ac /main
parente8c131f161de9d8891d44556a8716de156d6cbfa (diff)
restarts busydetector (if enabled) when DTMF is received.
(closes issue #16389) Reported by: alecdavis Tested by: alecdavis Patch dtmf_busydetector.diff.txt uploaded by alecdavis (license 585) git-svn-id: http://svn.digium.com/svn/asterisk/branches/1.6.1@234899 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'main')
-rw-r--r--main/dsp.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/main/dsp.c b/main/dsp.c
index eaa5c66c3..54323576f 100644
--- a/main/dsp.c
+++ b/main/dsp.c
@@ -1367,6 +1367,12 @@ struct ast_frame *ast_dsp_process(struct ast_channel *chan, struct ast_dsp *dsp,
memmove(dsp->digit_state.digits, dsp->digit_state.digits + 1, dsp->digit_state.current_digits);
dsp->digit_state.current_digits--;
dsp->dtmf_began = 0;
+
+ if (dsp->features & DSP_FEATURE_BUSY_DETECT) {
+ /* Reset Busy Detector as we have some confirmed activity */
+ memset(dsp->historicsilence, 0, sizeof(dsp->historicsilence));
+ memset(dsp->historicnoise, 0, sizeof(dsp->historicnoise));
+ }
}
if (event) {