[dahdi-commits] tzafrir: branch tools/tzafrir/sysfs r8442 - in /tools/team/tzafrir/sysfs/xpp:...
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Sun Mar 28 16:24:54 CDT 2010
Author: tzafrir
Date: Sun Mar 28 16:24:50 2010
New Revision: 8442
URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=8442
Log:
dahdi pools: group devices of several spans
Make it possible to group DAHDI device files of several spans in a
simple and configurable way through a 'pool' file.
/etc/dahdi/pool is a mapping of "span names" (location / hardware_id) to
logical group: each line is a set of of such logical names.
Generate dahdi-channels.conf with named spans for spans that are in
such a pool.
Added:
tools/team/tzafrir/sysfs/xpp/dahdi_pools (with props)
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Pool.pm (with props)
Modified:
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Chans.pm
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Config/Gen/Chandahdi.pm
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm
Added: tools/team/tzafrir/sysfs/xpp/dahdi_pools
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/dahdi_pools?view=auto&rev=8442
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/dahdi_pools (added)
+++ tools/team/tzafrir/sysfs/xpp/dahdi_pools Sun Mar 28 16:24:50 2010
@@ -1,0 +1,123 @@
+#! /usr/bin/perl -w
+#
+# Written by Oron Peled <oron at actcom.co.il>
+# Copyright (C) 2010, Xorcom
+# This program is free software; you can redistribute and/or
+# modify it under the same terms as Perl itself.
+#
+# $Id$
+#
+use strict;
+use File::Basename;
+BEGIN { my $dir = dirname($0); unshift(@INC, "$dir", "$dir/perl_modules"); }
+use Dahdi::Pool;
+
+my $poolbase = "/dev/dahdi/pool";
+
+sub make_path($) {
+ my $dir = shift || die;
+ system("mkdir -p -- '$dir'");
+ die "$0: Failed creating '$dir' (status $?)" if $?;
+}
+
+sub remove_tree($) {
+ my $dir = shift || die;
+ system("rm -rf -- '$dir'");
+ die "$0: Failed removing '$dir' (status $?)" if $?;
+}
+
+sub process_pool($) {
+ my $pool = shift || die;
+ my $poolname = $pool->{NAME};
+ my $destdir = "$poolbase/$poolname";
+ make_path "$destdir";
+ foreach (@{$pool->{ENTRIES}}) {
+ my $device = $_->{DEVICE};
+ my $dest = $_->{DEST};
+ symlink($device, $dest) || die "$0: Failed symlink($device, $dest): $!\n";
+ #print "symlink($device, $dest)\n";
+ }
+}
+
+my @pools = Dahdi::Pool->get_pools;
+remove_tree($poolbase);
+foreach my $pool (@pools) {
+ process_pool($pool);
+}
+
+__END__
+
+=head1 NAME
+
+dahdi_pool - maintain pools of DAHDI spans
+
+=head1 SYNOPSIS
+
+dahdi_pool
+
+=head1 DESCRIPTION
+
+dahdi_pool Creates and updates pools of DAHDI spans. Such a pool is a
+directory under C</dev/dahdi/pool> with symlinks to all the channels of one
+or more spans listed as plain numbers. On each invocation it deletes the
+symlinks under C</dev/dahdi/pool> and recreates them.
+
+Pools are configured through C</etc/dahdi/pool>. This file has:
+
+ # comments and blank lines are ignored
+ # format is:
+ # <name of pool> <directory> [<directory> ...]
+
+The name of each pool is the name of a subdirecotry under
+C</dev/dahdi/pool> to create. It should probably avoid any special
+characters.
+
+Following in the same line are names of directories under
+/etc/dahdi/devices in which to look for device nodes.
+
+The udev rules create symlinks from the subdirectories of
+C<dev/dahdi/devices> to the device files C</dev/dahdi/NNN>. Those may be
+created for the location and also (if it is not empty) for the
+hardware_id field of the span.
+
+For example, on a system with two Astribank 32FXS we would get under
+C</dev/dahdi/devices> the subdirectories
+C<@usb-0000:00:1d_7-3>, C<@usb-0000:00:1d_7-4> (locations), C<usb:12345678>.
+and C<usb:11223344> (hardware_ids). Under each of those we have the
+subdirectories C<00>, C<10>, C<20> and C<30>.
+
+Several optional pools would be:
+
+ astbank1 usb:12345678
+ astbank2 usb:11223344
+
+Alternatively:
+
+ astbank1 usb:12345678/00 usb:12345678/10 usb:12345678/10 usb:12345678/30
+ astbank2 usb:11223344/00 usb:11223344/10 usb:11223344/10 usb:11223344/30
+
+Or, put both in the same pool (and let's use location now)
+
+ all usb:12345678 usb:11223344
+
+
+Note that running dahdi_pool several times at boot time should be safe.
+
+=head1 FILES
+
+=over
+
+=item /etc/dahdi/pool
+
+List of pools. See description above.
+
+=item /dev/dahdi/devices
+
+"Physical" device symlinks that may be included in pools.
+
+=item /dev/dahdi/pool
+
+Location of generated device pools.
+
+=back
+
Propchange: tools/team/tzafrir/sysfs/xpp/dahdi_pools
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: tools/team/tzafrir/sysfs/xpp/dahdi_pools
------------------------------------------------------------------------------
svn:executable = *
Propchange: tools/team/tzafrir/sysfs/xpp/dahdi_pools
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: tools/team/tzafrir/sysfs/xpp/dahdi_pools
------------------------------------------------------------------------------
svn:mime-type = text/plain
Modified: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Chans.pm
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Chans.pm?view=diff&rev=8442&r1=8441&r2=8442
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Chans.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Chans.pm Sun Mar 28 16:24:50 2010
@@ -9,6 +9,7 @@
#
use strict;
use Dahdi::Utils;
+use Dahdi::Pool;
=head1 NAME
@@ -112,8 +113,16 @@
};
bless $self, $pack;
$self->{NUM} = $self->_get_dev_attr('channo');
+ $self->{DEV} = $self->_get_dev_attr('dev');
$self->{INDEX} = $self->_get_dev_attr('chanpos');
$self->{FQN} = $self->_get_dev_attr('name'); # TODO: correct?
+ my $poolentry = Dahdi::Pool->dev2poolentry($self->{DEV});
+ if(defined $poolentry) {
+ $self->{POOLPOS} = $poolentry->{NUM};
+ $span->{SUBDIR} = $poolentry->{SUBDIR} unless defined $span->{SUBDIR};
+ my $pool = $poolentry->{POOL};
+ $span->{POOLNAME} = $pool->{NAME} unless defined $span->{POOLNAME};
+ }
$self->{ALARMS} = [];
my $alarms = $self->_get_dev_attr('alarms');
Modified: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Config/Gen/Chandahdi.pm
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Config/Gen/Chandahdi.pm?view=diff&rev=8442&r1=8441&r2=8442
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Config/Gen/Chandahdi.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Config/Gen/Chandahdi.pm Sun Mar 28 16:24:50 2010
@@ -36,6 +36,11 @@
print "$arg =\n";
}
}
+}
+
+sub has_pool($) {
+ my $span = shift || die;
+ return defined $span->subdir && $span->subdir;
}
sub gen_openr2($$$) {
@@ -152,6 +157,7 @@
sub gen_channel($$) {
my $self = shift || die;
my $chan = shift || die;
+ my $relative_numbers = has_pool($chan->span);
my $gconfig = $self->{GCONFIG};
my $type = $chan->type;
my $num = $chan->num;
@@ -160,15 +166,22 @@
my $sig = $gconfig->{'chan_dahdi_signalling'}{$type};
my $context = $gconfig->{'context'}{$type};
my $group = $gconfig->{'group'}{$type};
- my $callerid;
my $immediate;
return if $type eq 'EMPTY';
die "missing default_chan_dahdi_signalling for chan #$num type $type" unless $sig;
die "missing context for chan #$num type $type" unless $context;
- $callerid = ($type eq 'FXO')
- ? 'asreceived'
- : sprintf "\"Channel %d\" <%04d>", $num, $exten;
+ my $caller_id;
+ my $pos;
+ if($relative_numbers) {
+ $pos = $chan->poolpos;
+ my $pool = $chan->span->poolname();
+ $caller_id = sprintf "\"Channel %s-%d\" <%04d>", $pool, $num, $exten;
+ } else {
+ $pos = $num;
+ $caller_id = sprintf "\"Channel %d\" <%04d>", $num, $exten;
+ }
+ $caller_id = ($type eq 'FXO') ? 'asreceived' : $caller_id;
if($type eq 'IN') {
$immediate = 'yes';
}
@@ -179,16 +192,16 @@
$signalling = " " . $signalling if $signalling;
my $info = $chan->info;
$info = " " . $info if $info;
- printf ";;; line=\"%d %s%s%s\"\n", $num, $chan->fqn, $signalling, $info;
+ printf ";;; line=\"%d (%d) %s%s%s\"\n", $pos, $num, $chan->fqn, $signalling, $info;
printf "signalling=$sig\n";
- printf "callerid=$callerid\n";
+ printf "callerid=$caller_id\n";
printf "mailbox=%04d\n", $exten unless $type eq 'FXO';
if(defined $group) {
printf "group=$group\n";
}
printf "context=$context\n";
printf "immediate=$immediate\n" if defined $immediate;
- printf "channel => %d\n", $num;
+ printf "channel => %d\n", $pos;
# Reset following values to default
printf "callerid=\n";
printf "mailbox=\n" unless $type eq 'FXO';
@@ -227,6 +240,11 @@
HEAD
foreach my $span (@spans) {
printf "; Span %d: %s %s\n", $span->num, $span->name, $span->description;
+ my $subdir = undef;
+ if(has_pool($span)) {
+ $subdir = $span->subdir;
+ printf "subdir = %s\n", $subdir;
+ }
if($span->is_digital) {
if($span->is_pri) {
if($gconfig->{'pri_connection_type'} eq 'R2') {
@@ -253,6 +271,7 @@
$self->gen_channel($chan);
}
}
+ print "subdir=\n" if defined $subdir;
print "\n";
}
close F;
Added: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Pool.pm
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Pool.pm?view=auto&rev=8442
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Pool.pm (added)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Pool.pm Sun Mar 28 16:24:50 2010
@@ -1,0 +1,134 @@
+package Dahdi::Pool;
+#
+# Written by Oron Peled <oron at actcom.co.il>
+# Copyright (C) 2010, Xorcom
+# This program is free software; you can redistribute and/or
+# modify it under the same terms as Perl itself.
+#
+# $Id$
+#
+use strict;
+use File::Find;
+
+=head1 NAME
+
+Dahdi::Spans - Perl interface to a Dahdi pool of spans
+
+A pool of spans is a directory under C</dev/dahdi/pool> with symlinks to
+the real device files.
+
+Dahdi::Pool objects are normally created in the initial scan of
+C<Dahdi::spans()>.
+
+A C<Dahdi::Pool> object is essentially a container of "pool-entries".
+Each of those represents a symlink to a device.
+
+=head1 get_pools()
+
+Returns the global hash of pools. Use it to search for a specific pool
+by name.
+
+=cut
+
+my $cfgfile = "/etc/dahdi/chan_pools";
+my $poolbase = "/dev/dahdi/pool";
+my %pool_dirs;
+my %devices;
+my %pools;
+
+my @devfiles;
+
+sub wanted {
+ return unless /^\d+$/ && -l;
+ unshift(@devfiles, $File::Find::name);
+}
+
+sub chan_order {
+ my $a_dir = $a;
+ my $b_dir = $b;
+ $a_dir =~ s/(\d+)$//;
+ my $a_num = $1;
+ $b_dir =~ s/(\d+)$//;
+ my $b_num = $1;
+ return $a_dir cmp $b_dir if $a_dir ne $b_dir;
+ return $a_num <=> $b_num;
+}
+
+sub new($$) {
+ my $class = shift || die;
+ my $poolname = shift || die;
+ my $self = {
+ NAME => $poolname,
+ ENTRIES => [],
+ };
+ bless $self, $class;
+ my $dirs = $pool_dirs{$poolname};
+ my @dirs = map { "/dev/dahdi/devices/$_" } @{$dirs};
+ my @all_devfiles;
+ foreach my $d (@dirs) {
+ undef @devfiles;
+ find(\&wanted, $d);
+ my @devfiles = sort chan_order @devfiles;
+ #print "$d:\n", join("\n", @devfiles), "\n";
+ push(@all_devfiles, @devfiles);
+ }
+ my $destdir = "$poolbase/$poolname";
+ my $curr = 1;
+ foreach (@all_devfiles) {
+ warn "Not a chardev" unless -c $_;
+ my $rdev = (stat($_))[6];
+ my $dest = "$destdir/$curr";
+ #symlink($_, $dest) || die "$0: Failed symlink($_, $dest): $!\n";
+ my $minor = $rdev & 0xFF;
+ my $major = $rdev >> 8;
+ my $devt = "$major:$minor";
+ die "$0: Duplicate '$devt' (from '$_')" if exists $devices{$devt};
+ $devices{$devt} = {
+ DEVICE => $_,
+ SUBDIR => "pool/$poolname",
+ NUM => $curr,
+ POOLSTR => "pool/$poolname/$curr",
+ DEST => $dest,
+ POOL => $self,
+ };
+ $self->{ENTRIES}[$curr - 1] = $devices{$devt};
+ #print "$_: $devt\n";
+ $curr++;
+ }
+ return $self;
+}
+
+sub dev2poolentry($) {
+ my $class = shift || die;
+ my $devt = shift || die;
+ my $dev = $devices{$devt};
+ return $dev;
+}
+
+sub get_pools() {
+ my $class = shift || die;
+ return values %pools;
+}
+
+open(F, $cfgfile) || exit 0;
+while(<F>) {
+ chomp;
+ s/#.*//;
+ next unless /\S/;
+ my ($poolname, @dirs) = split;
+ die "$cfgfile:$.: Bad pool name '$poolname'\n"
+ if $poolname =~ m/[\/\.]/;
+ die "$cfgfile:$.: Pool '$poolname' without components\n"
+ unless @dirs;
+ die "$cfgfile:$.: Doubly defined pool '$poolname'\n"
+ if exists $pool_dirs{$poolname};
+ $pool_dirs{$poolname} = \@dirs;
+}
+close F;
+
+foreach my $poolname (keys %pool_dirs) {
+ my $p = Dahdi::Pool->new($poolname);
+ $pools{$poolname} = $p;
+}
+
+1;
Propchange: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Pool.pm
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Pool.pm
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Pool.pm
------------------------------------------------------------------------------
svn:mime-type = text/plain
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=8442&r1=8441&r2=8442
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm Sun Mar 28 16:24:50 2010
@@ -217,6 +217,8 @@
$self->{MANUFACTURER} = $self->_get_dev_attr('manufacturer');
# FIXME: the following is a number, rather than a readable value:
$self->{ALARMS} = $self->_get_dev_attr('alarms');
+ $self->{HARDWARE_ID} = $self->_get_dev_attr('hardware_id');
+ $self->{HARDWARE_PORT} = $self->_get_dev_attr('hardware_port');
$self->{CHANS} = [];
my @channels;
More information about the dahdi-commits
mailing list