[dahdi-commits] sruffell: linux/trunk r9995 - /linux/trunk/drivers/dahdi/dahdi-base.c

SVN commits to the DAHDI project dahdi-commits at lists.digium.com
Tue Jun 28 16:29:24 CDT 2011


Author: sruffell
Date: Tue Jun 28 16:29:20 2011
New Revision: 9995

URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=9995
Log:
dahdi: Always attach hwec to a channel if available.

In previous releases of DAHDI if dahdi_cfg attached a software echocan
to a channel and a hardware echocan was available, the hardware echocan
would be used instead of the software echocan.

Since the 2.4 branch was created a new feature was merged into
dahdi-linux where it was possible to mix software echocan and hardware
echocan on a channel. This required using "hwec" as the echocan in the
/etc/dahdi/system.conf file so that what was specified in the
configuration file is what was actually used.

This has resulted in users upgrading to the trunk of dahdi without
updating their /etc/dahdi/system.conf file and just suddenly not using
any hardware echocans any longer.

The capability to mix software and hardware echocans on a span will be
revisted when running dahdi_cfg on any preexisting configuration files
doesn't just silently turn off hardware echocan.

Signed-off-by: Shaun Ruffell <sruffell at digium.com>

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=9995&r1=9994&r2=9995
==============================================================================
--- linux/trunk/drivers/dahdi/dahdi-base.c (original)
+++ linux/trunk/drivers/dahdi/dahdi-base.c Tue Jun 28 16:29:20 2011
@@ -4828,6 +4828,21 @@
 	return 0;
 }
 
+/**
+ * dahdi_is_hwec_available - Is hardware echocan available on a channel?
+ * @chan: The channel to check
+ *
+ * Returns true if there is a hardware echocan available for the attached
+ * channel, or false otherwise.
+ *
+ */
+static bool dahdi_is_hwec_available(const struct dahdi_chan *chan)
+{
+	if (!hwec_factory.get_name(chan))
+		return false;
+	return true;
+}
+
 static int dahdi_ioctl_attach_echocan(unsigned long data)
 {
 	unsigned long flags;
@@ -4842,7 +4857,15 @@
 	if (!chan)
 		return -EINVAL;
 
-	ae.echocan[sizeof(ae.echocan) - 1] = 0;
+	if (dahdi_is_hwec_available(chan)) {
+		/* If there is a hardware echocan available we'll always use
+		 * it instead of any configured software echocan. This matches
+		 * the behavior in dahdi 2.4.1.2 and earlier releases. */
+		strlcpy(ae.echocan, hwec_def_name, sizeof(ae.echocan));
+	} else {
+		ae.echocan[sizeof(ae.echocan) - 1] = 0;
+	}
+
 	if (ae.echocan[0]) {
 		new = find_echocan(ae.echocan);
 		if (!new)




More information about the dahdi-commits mailing list