[dahdi-commits] kpfleming: branch linux/kpfleming/echocan_work r6366 - in /linux/team/kpflemi...
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Tue Apr 14 14:38:08 CDT 2009
Author: kpfleming
Date: Tue Apr 14 14:38:05 2009
New Revision: 6366
URL: http://svn.digium.com/svn-view/dahdi?view=rev&rev=6366
Log:
add an ioctl for explicitly placing the echocan into FAX mode
change the echocan mode change messages to be able to handle non-tone-detection events that cause changes
Modified:
linux/team/kpfleming/echocan_work/drivers/dahdi/dahdi-base.c
linux/team/kpfleming/echocan_work/include/dahdi/user.h
Modified: linux/team/kpfleming/echocan_work/drivers/dahdi/dahdi-base.c
URL: http://svn.digium.com/svn-view/dahdi/linux/team/kpfleming/echocan_work/drivers/dahdi/dahdi-base.c?view=diff&rev=6366&r1=6365&r2=6366
==============================================================================
--- linux/team/kpfleming/echocan_work/drivers/dahdi/dahdi-base.c (original)
+++ linux/team/kpfleming/echocan_work/drivers/dahdi/dahdi-base.c Tue Apr 14 14:38:05 2009
@@ -4977,6 +4977,26 @@
return ret;
}
+static void set_echocan_fax_mode(struct dahdi_chan *chan, unsigned int channo, const char *reason)
+{
+ if (chan->ec_state->features.NLP_toggle) {
+ module_printk(KERN_NOTICE, "Disabled echo canceller NLP because of %s on channel %d\n", reason, channo);
+ dahdi_qevent_nolock(chan, DAHDI_EVENT_EC_NLP_DISABLED);
+ chan->ec_state->ops->echocan_NLP_toggle(chan->ec_state, 0);
+ } else {
+ module_printk(KERN_NOTICE, "Disabled echo canceller because of %s on channel %d\n", reason, channo);
+ dahdi_qevent_nolock(chan, DAHDI_EVENT_EC_DISABLED);
+ chan->echocancel = 0;
+ chan->echostate = ECHO_STATE_IDLE;
+ chan->echolastupdate = 0;
+ chan->echotimer = 0;
+ chan->ec_state->ops->echocan_free(chan->ec_state);
+ chan->ec_state = NULL;
+ release_echocan(chan->ec_current);
+ chan->ec_current = NULL;
+ }
+}
+
static int dahdi_chan_ioctl(struct inode *inode, struct file *file, unsigned int cmd, unsigned long data, int unit)
{
struct dahdi_chan *chan = chans[unit];
@@ -5208,6 +5228,13 @@
chan->echotimer = j;
} else
return -EINVAL;
+ break;
+ case DAHDI_ECHOCANCEL_FAX_MODE:
+ if (!chan->ec_state) {
+ return -EINVAL;
+ }
+ set_echocan_fax_mode(chan, chan->channo, "ioctl");
+ rv = 0;
break;
case DAHDI_SETTXBITS:
if (chan->sig != DAHDI_SIG_CAS)
@@ -5732,26 +5759,6 @@
#endif
}
-static void set_echocan_fax_mode(struct dahdi_chan *chan, unsigned int channo, const char *direction)
-{
- if (chan->ec_state->features.NLP_toggle) {
- module_printk(KERN_NOTICE, "Disabled echo canceller NLP because of tone (%s) on channel %d\n", direction, channo);
- dahdi_qevent_nolock(chan, DAHDI_EVENT_EC_NLP_DISABLED);
- chan->ec_state->ops->echocan_NLP_toggle(chan->ec_state, 0);
- } else {
- module_printk(KERN_NOTICE, "Disabled echo canceller because of tone (%s) on channel %d\n", direction, channo);
- dahdi_qevent_nolock(chan, DAHDI_EVENT_EC_DISABLED);
- chan->echocancel = 0;
- chan->echostate = ECHO_STATE_IDLE;
- chan->echolastupdate = 0;
- chan->echotimer = 0;
- chan->ec_state->ops->echocan_free(chan->ec_state);
- chan->ec_state = NULL;
- release_echocan(chan->ec_current);
- chan->ec_current = NULL;
- }
-}
-
static inline void __dahdi_process_getaudio_chunk(struct dahdi_chan *ss, unsigned char *txb)
{
/* We transmit data from our master channel */
@@ -5768,7 +5775,7 @@
if (ms->ec_state && ms->ec_state->status.NLP_enabled && !ms->ec_state->features.CED_tx_detect) {
for (x = 0; x < DAHDI_CHUNKSIZE; x++) {
if (echo_can_disable_detector_update(&ms->ec_state->txecdis, getlin[x])) {
- set_echocan_fax_mode(ms, ss->channo, "tx");
+ set_echocan_fax_mode(ms, ss->channo, "CED tx detected");
dahdi_qevent_nolock(ms, DAHDI_EVENT_TX_CED_DETECTED);
break;
}
@@ -6567,7 +6574,7 @@
dahdi_qevent_nolock(chan, DAHDI_EVENT_TX_CED_DETECTED);
if (chan->ec_state) {
if (chan->ec_state->status.NLP_enabled) {
- set_echocan_fax_mode(chan, chan->channo, "tx");
+ set_echocan_fax_mode(chan, chan->channo, "CED tx detected");
} else {
module_printk(KERN_NOTICE, "Detected CED tone (tx) on channel %d\n", chan->channo);
}
@@ -6578,7 +6585,7 @@
dahdi_qevent_nolock(chan, DAHDI_EVENT_RX_CED_DETECTED);
if (chan->ec_state) {
if (chan->ec_state->status.NLP_enabled) {
- set_echocan_fax_mode(chan, chan->channo, "rx");
+ set_echocan_fax_mode(chan, chan->channo, "CED rx detected");
} else {
module_printk(KERN_NOTICE, "Detected CED tone (rx) on channel %d\n", chan->channo);
}
@@ -6756,7 +6763,7 @@
if (ms->ec_state && ms->ec_state->status.NLP_enabled && !ms->ec_state->features.CED_rx_detect) {
for (x = 0; x < DAHDI_CHUNKSIZE; x++) {
if (echo_can_disable_detector_update(&ms->ec_state->rxecdis, putlin[x])) {
- set_echocan_fax_mode(ms, ss->channo, "rx");
+ set_echocan_fax_mode(ms, ss->channo, "CED rx detected");
dahdi_qevent_nolock(ms, DAHDI_EVENT_RX_CED_DETECTED);
break;
}
Modified: linux/team/kpfleming/echocan_work/include/dahdi/user.h
URL: http://svn.digium.com/svn-view/dahdi/linux/team/kpfleming/echocan_work/include/dahdi/user.h?view=diff&rev=6366&r1=6365&r2=6366
==============================================================================
--- linux/team/kpfleming/echocan_work/include/dahdi/user.h (original)
+++ linux/team/kpfleming/echocan_work/include/dahdi/user.h Tue Apr 14 14:38:05 2009
@@ -1017,8 +1017,11 @@
#define DAHDI_STARTUP _IOW(DAHDI_CODE, 99, int)
#define DAHDI_SHUTDOWN _IOW(DAHDI_CODE, 100, int)
-
#define DAHDI_HDLC_RATE _IOW(DAHDI_CODE, 101, int)
+
+/* Put a channel's echo canceller into 'FAX mode' if possible */
+
+#define DAHDI_ECHOCANCEL_FAX_MODE _IO(DAHDI_CODE, 102)
struct torisa_debug {
unsigned int txerrors;
More information about the dahdi-commits
mailing list