aboutsummaryrefslogtreecommitdiffstats
path: root/channels/chan_modem.c
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-06-22 14:17:07 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-06-22 14:17:07 +0000
commit7ceaf8171a8991f78e19f492420ce3a32c84ca1b (patch)
tree0f8f3befce3534579fe0c2c713c628c247d66624 /channels/chan_modem.c
parentabda2d4bdfba825faf0f79feb5c3ab66c3f2c679 (diff)
Make DTMF mode configurable on ISDN
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@3271 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels/chan_modem.c')
-rwxr-xr-xchannels/chan_modem.c39
1 files changed, 39 insertions, 0 deletions
diff --git a/channels/chan_modem.c b/channels/chan_modem.c
index 59018c09c..c2f7e6187 100755
--- a/channels/chan_modem.c
+++ b/channels/chan_modem.c
@@ -63,6 +63,13 @@ static char msn[AST_MAX_EXTENSION]="";
/* Default Listen */
static char incomingmsn[AST_MAX_EXTENSION]="";
+/* Default DTMF-detection mode (i4l/asterisk) */
+static int dtmfmode = MODEM_DTMF_AST;
+/* Default DTMF-generation mode (i4l (outband) / asterisk (inband) */
+static int dtmfmodegen = MODEM_DTMF_AST;
+
+struct ast_dsp *dsp = NULL;
+
/* Default valid outgoing MSN */
static char outgoingmsn[AST_MAX_EXTENSION]="";
@@ -711,6 +718,8 @@ static struct ast_modem_pvt *mkif(char *iface)
strncpy(tmp->language, language, sizeof(tmp->language)-1);
strncpy(tmp->msn, msn, sizeof(tmp->msn)-1);
strncpy(tmp->incomingmsn, incomingmsn, sizeof(tmp->incomingmsn)-1);
+ tmp->dtmfmode = dtmfmode;
+ tmp->dtmfmodegen = dtmfmodegen;
snprintf(tmp->outgoingmsn, sizeof(tmp->outgoingmsn), ",%s,", outgoingmsn);
strncpy(tmp->dev, iface, sizeof(tmp->dev)-1);
/* Maybe in the future we want to allow variable
@@ -972,6 +981,36 @@ int load_module()
strncpy(msn, v->value, sizeof(msn)-1);
} else if (!strcasecmp(v->name, "incomingmsn")) {
strncpy(incomingmsn, v->value, sizeof(incomingmsn)-1);
+ } else if (!strcasecmp(v->name, "dtmfmode")) {
+ char tmp[80];
+ char *alt;
+ strncpy(tmp, v->value, sizeof(tmp) - 1);
+ alt = strchr(tmp, '/');
+ if (!strcasecmp(tmp, "none"))
+ dtmfmode=MODEM_DTMF_NONE;
+ else if (!strcasecmp(tmp, "asterisk"))
+ dtmfmode = MODEM_DTMF_AST;
+ else if (!strcasecmp(tmp, "i4l"))
+ dtmfmode = MODEM_DTMF_I4L;
+ else {
+ ast_log(LOG_WARNING, "Unknown dtmf detection mode '%s', using 'asterisk'\n", v->value);
+ dtmfmode = MODEM_DTMF_AST;
+ }
+ if (alt) {
+ if (!strcasecmp(alt, "none"))
+ dtmfmodegen=MODEM_DTMF_NONE;
+ else if (!strcasecmp(alt, "asterisk"))
+ dtmfmodegen = MODEM_DTMF_AST;
+ else if (!strcasecmp(alt, "i4l"))
+ dtmfmodegen = MODEM_DTMF_I4L;
+ else if (!strcasecmp(alt, "both"))
+ dtmfmodegen = MODEM_DTMF_I4L | MODEM_DTMF_AST;
+ else {
+ ast_log(LOG_WARNING, "Unknown dtmf generation mode '%s', using 'asterisk'\n", v->value);
+ dtmfmodegen = MODEM_DTMF_AST;
+ }
+ } else
+ dtmfmodegen = dtmfmode;
} else if (!strcasecmp(v->name, "outgoingmsn")) {
strncpy(outgoingmsn, v->value, sizeof(outgoingmsn)-1);
} else if (!strcasecmp(v->name, "language")) {