[dahdi-commits] tzafrir: linux/trunk r10461 - in /linux/trunk: ./ drivers/dahdi/
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Wed Feb 22 06:11:03 CST 2012
Author: tzafrir
Date: Wed Feb 22 06:10:59 2012
New Revision: 10461
URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=10461
Log:
sysfs: add 'lineconfig' attribute to span
This patch exposes the span 'lineconfig' via sysfs: textual representation
of the framing and coding of the span.
This is needed in order for the Dahdi perl classes (in tools) to get
the inforamtion for e.g. dahdi_genconf to work without the guesswork of
parsing /proc/dahdi .
Signed-off-by: Oron Peled <oron.peled at xorcom.com>
Acked-by: Tzafrir Cohen <tzafrir.cohen at xorcom.com>
Acked-by: Shaun Ruffell <sruffell at digium.com>
Modified:
linux/trunk/README
linux/trunk/drivers/dahdi/dahdi-sysfs.c
Modified: linux/trunk/README
URL: http://svnview.digium.com/svn/dahdi/linux/trunk/README?view=diff&rev=10461&r1=10460&r2=10461
==============================================================================
--- linux/trunk/README (original)
+++ linux/trunk/README Wed Feb 22 06:10:59 2012
@@ -802,6 +802,12 @@
===== /sys/bus/dahdi_spans/devices/span-N/lbo
LBO setting for the channel.
+===== /sys/bus/dahdi_spans/devices/span-N/lineconfig
+The framing and coding of the span, for a digital span. Textual
+represenation:
+
+<B8ZS|AMI|HDB3>/<D4|ESF|CCS>[/CRC4]
+
===== /sys/bus/dahdi_spans/devices/span-N/local_spanno
The number of the span within the DAHDI device.
Modified: linux/trunk/drivers/dahdi/dahdi-sysfs.c
URL: http://svnview.digium.com/svn/dahdi/linux/trunk/drivers/dahdi/dahdi-sysfs.c?view=diff&rev=10461&r1=10460&r2=10461
==============================================================================
--- linux/trunk/drivers/dahdi/dahdi-sysfs.c (original)
+++ linux/trunk/drivers/dahdi/dahdi-sysfs.c Wed Feb 22 06:10:59 2012
@@ -259,6 +259,35 @@
return sprintf(buf, "%d\n", span->channels);
}
+static BUS_ATTR_READER(lineconfig_show, dev, buf)
+{
+ struct dahdi_span *span;
+ int len = 0;
+
+ span = dev_to_span(dev);
+ if (span->lineconfig) {
+ /* framing first */
+ if (span->lineconfig & DAHDI_CONFIG_B8ZS)
+ len += sprintf(buf + len, "B8ZS/");
+ else if (span->lineconfig & DAHDI_CONFIG_AMI)
+ len += sprintf(buf + len, "AMI/");
+ else if (span->lineconfig & DAHDI_CONFIG_HDB3)
+ len += sprintf(buf + len, "HDB3/");
+ /* then coding */
+ if (span->lineconfig & DAHDI_CONFIG_ESF)
+ len += sprintf(buf + len, "ESF");
+ else if (span->lineconfig & DAHDI_CONFIG_D4)
+ len += sprintf(buf + len, "D4");
+ else if (span->lineconfig & DAHDI_CONFIG_CCS)
+ len += sprintf(buf + len, "CCS");
+ /* E1's can enable CRC checking */
+ if (span->lineconfig & DAHDI_CONFIG_CRC4)
+ len += sprintf(buf + len, "/CRC4");
+ }
+ len += sprintf(buf + len, "\n");
+ return len;
+}
+
static struct device_attribute span_dev_attrs[] = {
__ATTR_RO(name),
__ATTR_RO(desc),
@@ -271,6 +300,7 @@
__ATTR_RO(is_sync_master),
__ATTR_RO(basechan),
__ATTR_RO(channels),
+ __ATTR_RO(lineconfig),
__ATTR_NULL,
};
More information about the dahdi-commits
mailing list