[svn-commits] moy: branch moy/mfcr2 r114871 - in /team/moy/mfcr2: channels/ include/asteris...

SVN commits to the Digium repositories svn-commits at lists.digium.com
Tue Apr 29 21:45:02 CDT 2008


Author: moy
Date: Tue Apr 29 21:45:02 2008
New Revision: 114871

URL: http://svn.digium.com/view/asterisk?view=rev&rev=114871
Log:
Merged revisions 112652,114716 from https://origsvn.digium.com/svn/asterisk/team/markster/mfr2/

Modified:
    team/moy/mfcr2/channels/chan_zap.c
    team/moy/mfcr2/include/asterisk/dsp.h
    team/moy/mfcr2/main/dsp.c

Modified: team/moy/mfcr2/channels/chan_zap.c
URL: http://svn.digium.com/view/asterisk/team/moy/mfcr2/channels/chan_zap.c?view=diff&rev=114871&r1=114870&r2=114871
==============================================================================
--- team/moy/mfcr2/channels/chan_zap.c (original)
+++ team/moy/mfcr2/channels/chan_zap.c Tue Apr 29 21:45:02 2008
@@ -6224,7 +6224,7 @@
 		/* set digit mode appropriately */
 		if (p->dsp) {
 			if (NEED_MFDETECT(p))
-				ast_dsp_set_digitmode(p->dsp, DSP_DIGITMODE_MF | p->dtmfrelax); 
+				ast_dsp_set_digitmode(p->dsp, DSP_DIGITMODE_MFR1 | p->dtmfrelax); 
 			else 
 				ast_dsp_set_digitmode(p->dsp, DSP_DIGITMODE_DTMF | p->dtmfrelax);
 		}
@@ -6340,7 +6340,7 @@
 	                        return NULL;
 			}
                         zt_set_hook(p->subs[SUB_REAL].zfd, ZT_OFFHOOK);
-                        ast_dsp_set_digitmode(p->dsp, DSP_DIGITMODE_MF | p->dtmfrelax);
+                        ast_dsp_set_digitmode(p->dsp, DSP_DIGITMODE_MFR1 | p->dtmfrelax);
                         res = my_getsigstr(chan, anibuf, "#", 10000);
                         if ((res > 0) && (strlen(anibuf) > 2)) {
 				if (anibuf[strlen(anibuf) - 1] == '#')

Modified: team/moy/mfcr2/include/asterisk/dsp.h
URL: http://svn.digium.com/view/asterisk/team/moy/mfcr2/include/asterisk/dsp.h?view=diff&rev=114871&r1=114870&r2=114871
==============================================================================
--- team/moy/mfcr2/include/asterisk/dsp.h (original)
+++ team/moy/mfcr2/include/asterisk/dsp.h Tue Apr 29 21:45:02 2008
@@ -28,8 +28,14 @@
 #define DSP_FEATURE_DIGIT_DETECT	(1 << 3)
 #define DSP_FEATURE_FAX_DETECT		(1 << 4)
 
-#define	DSP_DIGITMODE_DTMF			0				/*!< Detect DTMF digits */
-#define DSP_DIGITMODE_MF			1				/*!< Detect MF digits */
+
+#define DSP_DIGITMODE_MASK			0x3
+#define	DSP_DIGITMODE_DTMF			0x0				/*!< Detect DTMF digits */
+#define DSP_DIGITMODE_MFR1			0x1				/*!< Detect MF digits */
+#define DSP_DIGITMODE_MFR2_FWD			0x2
+/*!< Detect MFR2 Forward */
+#define DSP_DIGITMODE_MFR2_REV			0x3
+/*!< Detect MFR2 Reverse */
 
 #define DSP_DIGITMODE_NOQUELCH		(1 << 8)		/*!< Do not quelch DTMF from in-band */
 #define DSP_DIGITMODE_MUTECONF		(1 << 9)		/*!< Mute conference */

Modified: team/moy/mfcr2/main/dsp.c
URL: http://svn.digium.com/view/asterisk/team/moy/mfcr2/main/dsp.c?view=diff&rev=114871&r1=114870&r2=114871
==============================================================================
--- team/moy/mfcr2/main/dsp.c (original)
+++ team/moy/mfcr2/main/dsp.c Tue Apr 29 21:45:02 2008
@@ -193,8 +193,16 @@
  */
 #define SAMPLES_IN_FRAME	160
 
+#define MFR1_GSIZE		120
+
+#define MFR2_GSIZE		133
+
 /* MF goertzel size */
-#define MF_GSIZE		120
+static int mf_gsize[] = {
+	MFR1_GSIZE,
+	MFR2_GSIZE,
+	MFR2_GSIZE
+};
 
 /* DTMF goertzel size */
 #define DTMF_GSIZE		102
@@ -203,6 +211,7 @@
 #define DTMF_HITS_TO_BEGIN	2
 /* How many successive misses needed to consider end of a digit */
 #define DTMF_MISSES_TO_END	3
+
 
 #define CONFIG_FILE_NAME "dsp.conf"
 
@@ -255,6 +264,8 @@
 typedef struct
 {
 	goertzel_state_t tone_out[6];
+	int mode;
+	int gsize; /* Size of goertzel */
 	int current_hit;
 	int hits[5];
 	int current_sample;
@@ -283,14 +294,24 @@
 	1209.0, 1336.0, 1477.0, 1633.0
 };
 
-static float mf_tones[] =
-{
-	700.0, 900.0, 1100.0, 1300.0, 1500.0, 1700.0
+#define MF_MFR1 	0
+#define MF_MFR2_FWD 	1
+#define MF_MFR2_REV 	2
+
+static float mf_tones[][6] =
+{
+	{ 700.0, 900.0, 1100.0, 1300.0, 1500.0, 1700.0 },
+	{ 1380.0, 1500.0, 1620.0, 1740.0, 1860.0, 1980.0 },
+	{ 540.0, 660.0, 780.0, 900.0, 1020.0, 1140.0 },
 };
 
 static char dtmf_positions[] = "123A" "456B" "789C" "*0#D";
 
-static char bell_mf_positions[] = "1247C-358A--69*---0B----#";
+static char *all_mf_positions[] = {
+	"1247C-358A--69*---0B----#", /* Bell */
+	"1247B-358C--69D---AE----F", /* Forward */
+	"FEDCB-A987--654---32----1", /* Reverse */
+};
 
 static int thresholds[THRESHOLD_MAX];
 
@@ -486,15 +507,20 @@
 	s->misses_to_end = DTMF_MISSES_TO_END;
 }
 
-static void ast_mf_detect_init (mf_detect_state_t *s)
+static void ast_mf_detect_init (mf_detect_state_t *s, int mode)
 {
 	int i;
+	mode--;
+	if ((mode < 0) || (mode > 2))
+		mode = 0;
+	s->mode = mode;
 	s->hits[0] = s->hits[1] = s->hits[2] = s->hits[3] = s->hits[4] = 0;
 	for (i = 0;  i < 6;  i++) {
-		goertzel_init (&s->tone_out[i], mf_tones[i], 160);
+		goertzel_init (&s->tone_out[i], mf_tones[s->mode][i], 160);
 	}
 	s->current_sample = 0;
 	s->current_hit = 0;
+	s->gsize = mf_gsize[s->mode];
 }
 
 static void ast_digit_detect_init(digit_detect_state_t *s, int mf)
@@ -505,7 +531,7 @@
 	s->digits[0] = '\0';
 
 	if (mf)
-		ast_mf_detect_init(&s->td.mf);
+		ast_mf_detect_init(&s->td.mf, mf);
 	else
 		ast_dtmf_detect_init(&s->td.dtmf);
 }
@@ -794,8 +820,8 @@
 	for (sample = 0;  sample < samples;  sample = limit) {
 		/* 80 is optimised to meet the MF specs. */
 		/* XXX So then why is MF_GSIZE defined as 120? */
-		if ((samples - sample) >= (MF_GSIZE - s->td.mf.current_sample))
-			limit = sample + (MF_GSIZE - s->td.mf.current_sample);
+		if ((samples - sample) >= (s->td.mf.gsize - s->td.mf.current_sample))
+			limit = sample + (s->td.mf.gsize - s->td.mf.current_sample);
 		else
 			limit = samples;
 		/* The following unrolled loop takes only 35% (rough estimate) of the 
@@ -812,7 +838,7 @@
 			goertzel_sample(s->td.mf.tone_out + 5, amp[j]);
 		}
 		s->td.mf.current_sample += (limit - sample);
-		if (s->td.mf.current_sample < MF_GSIZE) {
+		if (s->td.mf.current_sample < s->td.mf.gsize) {
 			continue;
 		}
 		/* We're at the end of an MF detection block.  */
@@ -866,18 +892,24 @@
 				second_best = i;
 			}
 			best = best*5 + second_best - 1;
-			hit = bell_mf_positions[best];
+			hit = all_mf_positions[s->td.mf.mode][best];
 			/* Look for two successive similar results */
-			/* The logic in the next test is:
-			   For KP we need 4 successive identical clean detects, with
-			   two blocks of something different preceeding it. For anything
-			   else we need two successive identical clean detects, with
-			   two blocks of something different preceeding it. */
-			if (hit == s->td.mf.hits[4] && hit == s->td.mf.hits[3] &&
-			   ((hit != '*' && hit != s->td.mf.hits[2] && hit != s->td.mf.hits[1])||
-			    (hit == '*' && hit == s->td.mf.hits[2] && hit != s->td.mf.hits[1] && 
-			    hit != s->td.mf.hits[0]))) {
-				store_digit(s, hit);
+			if (s->td.mf.mode) {
+				if (hit == s->td.mf.hits[4] && hit != s->td.mf.hits[3] && hit != s->td.mf.hits[2]) {
+					store_digit(s, hit);
+				}
+			} else {
+				/* The logic in the next test is:
+				   For KP we need 4 successive identical clean detects, with
+				   two blocks of something different preceeding it. For anything
+				   else we need two successive identical clean detects, with
+				   two blocks of something different preceeding it. */
+				if (hit == s->td.mf.hits[4] && hit == s->td.mf.hits[3] &&
+				   ((hit != '*' && hit != s->td.mf.hits[2] && hit != s->td.mf.hits[1])||
+				    (hit == '*' && hit == s->td.mf.hits[2] && hit != s->td.mf.hits[1] && 
+				    hit != s->td.mf.hits[0]))) {
+					store_digit(s, hit);
+				}
 			}
 		}
 
@@ -895,12 +927,12 @@
 
 		/* If we had a hit in this block, include it into mute fragment */
 		if (squelch && hit) {
-			if (mute.end < sample - MF_GSIZE) {
+			if (mute.end < sample - s->td.mf.gsize) {
 				/* There is a gap between fragments */
 				mute_fragment(dsp, &mute);
-				mute.start = (sample > MF_GSIZE) ? (sample - MF_GSIZE) : 0;
-			}
-			mute.end = limit + DTMF_GSIZE;
+				mute.start = (sample > s->td.mf.gsize) ? (sample - s->td.mf.gsize) : 0;
+			}
+			mute.end = limit + s->td.mf.gsize;
 		}
 
 		/* Reinitialise the detector for the next block */
@@ -1336,7 +1368,7 @@
 	}
 
 	if ((dsp->features & DSP_FEATURE_DIGIT_DETECT)) {
-		if ((dsp->digitmode & DSP_DIGITMODE_MF))
+		if ((dsp->digitmode & DSP_DIGITMODE_MASK))
 			digit = mf_detect(dsp, &dsp->digit_state, shortdata, len, (dsp->digitmode & DSP_DIGITMODE_NOQUELCH) == 0, (dsp->digitmode & DSP_DIGITMODE_RELAXDTMF));
 		else
 			digit = dtmf_detect(dsp, &dsp->digit_state, shortdata, len, (dsp->digitmode & DSP_DIGITMODE_NOQUELCH) == 0, (dsp->digitmode & DSP_DIGITMODE_RELAXDTMF));
@@ -1462,7 +1494,7 @@
 		dsp->digitmode = DSP_DIGITMODE_DTMF;
 		dsp->faxmode = DSP_FAXMODE_DETECT_CNG;
 		/* Initialize digit detector */
-		ast_digit_detect_init(&dsp->digit_state, dsp->digitmode & DSP_DIGITMODE_MF);
+		ast_digit_detect_init(&dsp->digit_state, dsp->digitmode & DSP_DIGITMODE_MASK);
 		/* Initialize initial DSP progress detect parameters */
 		ast_dsp_prog_reset(dsp);
 		/* Initialize fax detector */
@@ -1517,7 +1549,7 @@
 	int i;
 	
 	dsp->dtmf_began = 0;
-	if (dsp->digitmode & DSP_DIGITMODE_MF) {
+	if (dsp->digitmode & DSP_DIGITMODE_MASK) {
 		mf_detect_state_t *s = &dsp->digit_state.td.mf;
 		/* Reinitialise the detector for the next block */
 		for (i = 0;  i < 6;  i++) {
@@ -1561,11 +1593,11 @@
 	int new;
 	int old;
 	
-	old = dsp->digitmode & (DSP_DIGITMODE_DTMF | DSP_DIGITMODE_MF | DSP_DIGITMODE_MUTECONF | DSP_DIGITMODE_MUTEMAX);
-	new = digitmode & (DSP_DIGITMODE_DTMF | DSP_DIGITMODE_MF | DSP_DIGITMODE_MUTECONF | DSP_DIGITMODE_MUTEMAX);
+	old = dsp->digitmode & (DSP_DIGITMODE_DTMF | DSP_DIGITMODE_MASK | DSP_DIGITMODE_MUTECONF | DSP_DIGITMODE_MUTEMAX);
+	new = digitmode & (DSP_DIGITMODE_DTMF | DSP_DIGITMODE_MASK | DSP_DIGITMODE_MUTECONF | DSP_DIGITMODE_MUTEMAX);
 	if (old != new) {
 		/* Must initialize structures if switching from MF to DTMF or vice-versa */
-		ast_digit_detect_init(&dsp->digit_state, new & DSP_DIGITMODE_MF);
+		ast_digit_detect_init(&dsp->digit_state, new & DSP_DIGITMODE_MASK);
 	}
 	dsp->digitmode = digitmode;
 	return 0;




More information about the svn-commits mailing list