[dahdi-commits] tzafrir: branch tools/tzafrir/sysfs r8749 - in /tools/team/tzafrir/sysfs: ./ ...
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Thu Jun 3 18:05:41 CDT 2010
Author: tzafrir
Date: Thu Jun 3 18:05:38 2010
New Revision: 8749
URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=8749
Log:
dahdi aliases now point directly to hardware names
* Organize span names in hierarchy under their hardware names:
/dev/dahdi/span-names/<hardware_id>/<span_id>
* New dahdi_aliases can:
- create
- delete
- showconf (from config file)
- active (from /dev/dahdi/span-aliases)
* dahdi_aliases (create), is called from /usr/share/dahdi/symlink_spans
if /dev/dahdi/span-aliases does not exist.
Added:
tools/team/tzafrir/sysfs/dahdi_aliases (with props)
Modified:
tools/team/tzafrir/sysfs/dahdi_cfg.c
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm
tools/team/tzafrir/sysfs/xpp/symlink_span
Added: tools/team/tzafrir/sysfs/dahdi_aliases
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/dahdi_aliases?view=auto&rev=8749
==============================================================================
--- tools/team/tzafrir/sysfs/dahdi_aliases (added)
+++ tools/team/tzafrir/sysfs/dahdi_aliases Thu Jun 3 18:05:38 2010
@@ -1,0 +1,68 @@
+#! /bin/sh
+
+# dahdi_aliases: maintain DAHDI span aliases symlinks
+
+# Written by Oron Peled <oron at actcom.co.il>
+# Copyright (C) 2010, Xorcom
+#
+# All rights reserved.
+#
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the Free Software
+# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+
+usage() {
+ echo >&2 "Usage: $0 {create|delete|active|showconf}"
+ exit 1
+}
+
+dahdiconfdir=${dahdiconfdir:-/etc/dahdi}
+dahdiconfdir=/root/xortel
+ALIASES_FILE="$dahdiconfdir/hardware_aliases"
+
+SPAN_NAMES="/dev/dahdi/span-names"
+SPAN_ALIASES="/dev/dahdi/span-aliases"
+
+clean_aliases() {
+ sed < "$ALIASES_FILE" \
+ -e 's/^#.*//' \
+ -e 's/[ ]*$//' \
+ -e '/^$/d' \
+ -e 's/[ ]\+/\t/'
+}
+
+case "$1" in
+create)
+ mkdir -p "$SPAN_ALIASES"
+ clean_aliases | while read hw_alias hw_id
+ do
+ ln -s "$SPAN_NAMES/$hw_id" "$SPAN_ALIASES/$hw_alias"
+ done
+ ;;
+delete)
+ rm -rf "$SPAN_ALIASES"
+ ;;
+active)
+ ls "$SPAN_ALIASES" | while read name
+ do
+ l=`readlink "$SPAN_ALIASES/$name" | sed "s,$SPAN_NAMES/*,,"`
+ printf "%s\t%s\n" "$name" "$l"
+ done
+ ;;
+showconf)
+ clean_aliases
+ ;;
+*)
+ usage
+ ;;
+esac
Propchange: tools/team/tzafrir/sysfs/dahdi_aliases
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: tools/team/tzafrir/sysfs/dahdi_aliases
------------------------------------------------------------------------------
svn:executable = *
Propchange: tools/team/tzafrir/sysfs/dahdi_aliases
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: tools/team/tzafrir/sysfs/dahdi_aliases
------------------------------------------------------------------------------
svn:mime-type = text/plain
Modified: tools/team/tzafrir/sysfs/dahdi_cfg.c
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/dahdi_cfg.c?view=diff&rev=8749&r1=8748&r2=8749
==============================================================================
--- tools/team/tzafrir/sysfs/dahdi_cfg.c (original)
+++ tools/team/tzafrir/sysfs/dahdi_cfg.c Thu Jun 3 18:05:38 2010
@@ -563,7 +563,7 @@
argstr = pname + 1;
str_replace(prefix, '!', '/');
pname = prefix;
- if (access(pname, R_OK | X_OK) < 0) {
+ if (access(pname, F_OK) < 0) {
error("Missing '%s'\n", pname);
return -1;
}
Modified: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm?view=diff&rev=8749&r1=8748&r2=8749
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm Thu Jun 3 18:05:38 2010
@@ -311,7 +311,7 @@
my $hardware_id = $span->hardware_id;
my $location = $span->location;
my $name_base = '/dev/dahdi/span-aliases';
- my @names = glob "$name_base/*";
+ my @names = glob "$name_base/*/*";
$span->{ALIAS} = '';
foreach my $n (@names) {
next unless -l $n;
Modified: tools/team/tzafrir/sysfs/xpp/symlink_span
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/symlink_span?view=diff&rev=8749&r1=8748&r2=8749
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/symlink_span (original)
+++ tools/team/tzafrir/sysfs/xpp/symlink_span Thu Jun 3 18:05:38 2010
@@ -52,63 +52,48 @@
done
dahdiconfdir=${dahdiconfdir:-/etc/dahdi}
+export dahdiconfdir
+dahdiconfdir=/tmp/xortel/dahdi
initfile="$dahdiconfdir/init.conf"
[ -r "$initfile" ] && . "$initfile"
-SPANNAMES="/dev/dahdi/span-names"
-SPANALIASES="/dev/dahdi/span-aliases"
+SPAN_NAMES="/dev/dahdi/span-names"
+SPAN_ALIASES="/dev/dahdi/span-aliases"
LINK_DEST="/dev/dahdi/spans/${SPAN_NUM}"
-ALIASES_FILE="$dahdiconfdir/hardware_aliases"
-
-span_alias() {
- if [ -r "$ALIASES_FILE" ]; then
- awk -v span="$1" '$2 ~ span { print $1 }' "$ALIASES_FILE" 2> /dev/null
- fi
-}
create_links() {
- mkdir -p "$SPANNAMES"
- mkdir -p "$SPANALIASES"
+ mkdir -p "$SPAN_NAMES"
if [ "$SPAN_ID" = '' ]; then
echo >&2 "$0($ACTION): Missing span_id attribute for '$DEVPATH'"
exit 1
fi
SPAN_ID=`sysfs_attr_clean "$SPAN_ID"`
- ALIAS=''
if [ "$HARDWARE_ID" != '' ]; then
HARDWARE_ID=`sysfs_attr_clean "$HARDWARE_ID"`
- LINK="${SPANNAMES}/${HARDWARE_ID}($SPAN_ID)"
+ LINK="${SPAN_NAMES}/${HARDWARE_ID}/$SPAN_ID"
#echo "ln -s '$LINK_DEST' '$LINK'" 1>&2
+ mkdir -p "${SPAN_NAMES}/${HARDWARE_ID}"
rm -f "$LINK"
ln -s "$LINK_DEST" "$LINK"
- ALIAS=`span_alias "$HARDWARE_ID"`
else
echo >&2 "$0($ACTION): Missing hardware_id attribute for '$DEVPATH'"
fi
if [ "$LOCATION" != '' ]; then
LOCATION=`sysfs_attr_clean "$LOCATION"`
- LINK="${SPANNAMES}/@${LOCATION}($SPAN_ID)"
+ LINK="${SPAN_NAMES}/@${LOCATION}/$SPAN_ID"
#echo "ln -s '$LINK_DEST' '$LINK'" 1>&2
+ mkdir -p "${SPAN_NAMES}/@${LOCATION}"
rm -f "$LINK"
ln -s "$LINK_DEST" "$LINK"
- if [ "$ALIAS" = '' ]; then
- ALIAS=`span_alias "$LOCATION"`
- fi
else
echo >&2 "$0($ACTION): Missing location attribute for '$DEVPATH'"
- fi
- if [ "$ALIAS" != '' ]; then
- ALIAS="${SPANALIASES}/$ALIAS($SPAN_ID)"
- echo "$0($ACTION): alias: '$ALIAS'" 1>&2
- rm -f "$ALIAS"
- ln -s "$LINK_DEST" "$ALIAS"
fi
}
remove_links() {
- for i in "$SPANNAMES/"* "$SPANALIASES/"*
+ for i in "$SPAN_NAMES/"*
do
if [ -L "$i" ]; then
LINK_DEST=`readlink "$i"`
@@ -119,14 +104,16 @@
fi
fi
done
- #echo "$0($ACTION): Try to remove '$SPANNAMES'"
- rmdir "$SPANNAMES" 1>&2
- rmdir "$SPANALIASES" 1>&2
+ #echo "$0($ACTION): Try to remove '$SPAN_NAMES'"
+ rmdir "$SPAN_NAMES" 1>&2
}
case "$ACTION" in
add)
create_links 2>&1 | $LOGGER
+ if [ ! -d "$SPAN_ALIASES" ]; then
+ "$dir/dahdi_aliases" create
+ fi
;;
remove)
remove_links 2>&1 | $LOGGER
More information about the dahdi-commits
mailing list