diff options
author | alecdavis <alecdavis@f38db490-d61c-443f-a65b-d21fe96a405b> | 2009-12-15 03:10:36 +0000 |
---|---|---|
committer | alecdavis <alecdavis@f38db490-d61c-443f-a65b-d21fe96a405b> | 2009-12-15 03:10:36 +0000 |
commit | 2771f1aa9706153b6e774732a2927c4cba162208 (patch) | |
tree | f7b3d39104bad5af43bb44a1eba848213629a3ac /main | |
parent | e8c131f161de9d8891d44556a8716de156d6cbfa (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.c | 6 |
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) { |