[dahdi-commits] sruffell: linux/trunk r9124 - /linux/trunk/drivers/dahdi/dahdi-base.c
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Wed Aug 11 00:21:05 CDT 2010
Author: sruffell
Date: Wed Aug 11 00:21:00 2010
New Revision: 9124
URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=9124
Log:
dahdi: Do not error when uncrossing a channel if there is no 'dacs' callback.
The previous commit was making all chan configs fail on a span that did not
have a dacs callback. Also add some documentation for 'dahdi_chan_dacs' and
make it more explicit when we're disabling cross connect.
Modified:
linux/trunk/drivers/dahdi/dahdi-base.c
Modified: linux/trunk/drivers/dahdi/dahdi-base.c
URL: http://svnview.digium.com/svn/dahdi/linux/trunk/drivers/dahdi/dahdi-base.c?view=diff&rev=9124&r1=9123&r2=9124
==============================================================================
--- linux/trunk/drivers/dahdi/dahdi-base.c (original)
+++ linux/trunk/drivers/dahdi/dahdi-base.c Wed Aug 11 00:21:00 2010
@@ -507,24 +507,38 @@
pos = (pos + 1) % 3;
memset(conf_sums_next, 0, maxconfs * sizeof(sumtype));
}
-
-static int dahdi_chan_dacs(struct dahdi_chan *chan1, struct dahdi_chan *chan2)
-{
- if (chan2) {
- if (chan1->span && chan2->span && chan1->span->ops->dacs &&
- (chan1->span->ops->dacs == chan2->span->ops->dacs)) {
- return chan1->span->ops->dacs(chan1, chan2);
+/**
+ * dahdi_chan_dacs() - Cross (or uncross) connect two channels.
+ * @dst: Channel on which to transmit the src data.
+ * @src: NULL to disable cross connect, otherwise the source of the
+ * data.
+ *
+ * This allows those boards that support it to cross connect one channel to
+ * another in hardware.
+ *
+ */
+static int dahdi_chan_dacs(struct dahdi_chan *dst, struct dahdi_chan *src)
+{
+ int ret = 0;
+ if (src) {
+ if (dst->span && src->span && dst->span->ops->dacs &&
+ (dst->span->ops->dacs == src->span->ops->dacs)) {
+ ret = dst->span->ops->dacs(dst, src);
} else {
module_printk(KERN_ERR, "Unable to cross connect '%s' "
- "with '%s'\n", chan2->name, chan1->name);
- return -ENOSYS;
+ "with '%s'\n", src->name, dst->name);
+ ret = -ENOSYS;
}
} else {
- if (chan1->span && chan1->span->ops->dacs)
- return chan1->span->ops->dacs(chan1, NULL);
- else
- return -ENOSYS;
- }
+ if (dst->span && dst->span->ops->dacs)
+ ret = dst->span->ops->dacs(dst, NULL);
+ }
+ return ret;
+}
+
+static void dahdi_disable_dacs(struct dahdi_chan *chan)
+{
+ dahdi_chan_dacs(chan, NULL);
}
static int dahdi_chan_echocan_create(struct dahdi_chan *chan,
@@ -1346,7 +1360,7 @@
memset(chan->conflast2, 0, sizeof(chan->conflast2));
if (chan->span && oldconf)
- dahdi_chan_dacs(chan, NULL);
+ dahdi_disable_dacs(chan);
if (ec_state) {
ec_state->ops->echocan_free(chan, ec_state);
@@ -2011,7 +2025,7 @@
if (chans[x]->confna) {
dahdi_check_conf(chans[x]->confna);
if (chans[x]->span)
- dahdi_chan_dacs(chans[x], NULL);
+ dahdi_disable_dacs(chans[x]);
}
chans[x]->confna = 0;
chans[x]->_confn = 0;
@@ -2613,7 +2627,7 @@
if ((chan->sig & __DAHDI_SIG_DACS) != __DAHDI_SIG_DACS) {
chan->confna = 0;
chan->confmode = 0;
- dahdi_chan_dacs(chan, NULL);
+ dahdi_disable_dacs(chan);
}
chan->_confn = 0;
memset(chan->conflast, 0, sizeof(chan->conflast));
@@ -4315,7 +4329,7 @@
res = dahdi_chan_dacs(chans[ch.chan],
chans[ch.idlebits]);
} else {
- res = dahdi_chan_dacs(chans[ch.chan], NULL);
+ dahdi_disable_dacs(chans[ch.chan]);
}
chans[ch.chan]->master = newmaster;
/* Note new slave if we are not our own master */
@@ -4988,7 +5002,7 @@
chans[stack.conf.confno]->rxgain == defgain) {
dahdi_chan_dacs(chans[i], chans[stack.conf.confno]);
} else {
- dahdi_chan_dacs(chans[i], NULL);
+ dahdi_disable_dacs(chans[i]);
}
}
/* if we are going onto a conf */
@@ -5447,7 +5461,7 @@
/* initialize conference variables */
chan->_confn = 0;
chan->confna = 0;
- dahdi_chan_dacs(chan, NULL);
+ dahdi_disable_dacs(chan);
chan->confmode = 0;
chan->confmute = 0;
memset(chan->conflast, 0, sizeof(chan->conflast));
More information about the dahdi-commits
mailing list