[dahdi-commits] tzafrir: branch tools/tzafrir/sysfs r8440 - /tools/team/tzafrir/sysfs/xpp/per...
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Sun Mar 28 06:47:56 CDT 2010
Author: tzafrir
Date: Sun Mar 28 06:47:48 2010
New Revision: 8440
URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=8440
Log:
Adapt to slight SysFS info. Though it got better
* The name of the DAHDI chan SysFS node changed. Fix parsing.
* Signalling and alarm are no longer numbers. Just use them as strings.
* Print all the information original lsdahdi printed.
* Bring back the optional span->xpd().
Modified:
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Chans.pm
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm
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=8440&r1=8439&r2=8440
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Chans.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Chans.pm Sun Mar 28 06:47:48 2010
@@ -103,28 +103,24 @@
my $pack = shift or die "Wasn't called as a class method\n";
my $span = shift or die "Missing a span parameter\n";
my $dev_dir = shift or die "Missing SysFS path parameter\n";
- my $index = $1;
- if ($dev_dir !~ /:(\d)+$/) {
+ if ($dev_dir !~ /!(\d)+$/) {
die "Malformed SysFS device name $dev_dir\n";
}
my $self = {
'SPAN' => $span,
'DEV_DIR' => $dev_dir,
- 'INDEX' => $index,
};
bless $self, $pack;
$self->{NUM} = $self->_get_dev_attr('channo');
+ $self->{INDEX} = $self->_get_dev_attr('chanpos');
$self->{FQN} = $self->_get_dev_attr('name'); # TODO: correct?
- # FIXME: resolve numbers to string
$self->{ALARMS} = [];
- my $alarms = $self->_get_dev_attr('chan_alarms');
+ my $alarms = $self->_get_dev_attr('alarms');
if ($alarms) {$self->{ALARMS} = [$alarms]}
- $self->{SIGNALLING} = hex($self->_get_dev_attr('sig'));
+ $self->{SIGNALLING} = $self->_get_dev_attr('sig');
$self->{SIGCAP} = hex($self->_get_dev_attr('sigcap'));
- # INFO?
- # BATTERY
# TODO: Where do I get __DAHDI_SIG_FXS and __DAHDI_SIG_FXO from?
my $maybe_fxs = $self->{SIGCAP} & (1 << 12);
@@ -136,7 +132,8 @@
} else {
}
- $self->{INFO} = 'FIXME INFO';
+ $self->{INFO} .= ($self->_get_dev_attr('chanmute')) ? '(no pcm)' : '';
+ $self->{INFO} .= ($self->_get_dev_attr('in_use')) ? '(in use)' : '';
return $self;
}
@@ -287,7 +284,7 @@
# It's an XPD (FXO)
my @lines = @{$xpd->lines};
- my $line = $lines[$index];
+ my $line = $lines[$index - 1];
return $line->battery;
}
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=8440&r1=8439&r2=8440
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm Sun Mar 28 06:47:48 2010
@@ -10,6 +10,7 @@
use strict;
use Dahdi::Utils;
use Dahdi::Chans;
+use Dahdi::Xpp::Xpd;
=head1 NAME
@@ -196,6 +197,12 @@
defined($num) or die "can't figure span number from $dev_dir\n";
my $self = { NUM => $num, DEV_DIR => $dev_dir };
bless $self, $pack;
+ my @xpds = Dahdi::Xpp::Xpd::xpds_by_spanno;
+ my $xpd = $xpds[$num];
+ if(defined $xpd) {
+ die "Spanno mismatch: $xpd->spanno, $num" unless $xpd->spanno == $num;
+ $self->{XPD} = $xpd;
+ }
$self->{IS_DIGITAL} = $self->_get_dev_attr('is_digital');
$self->{IS_DAHDI_SYNC_MASTER} = $self->_get_dev_attr('is_sync_master');
@@ -213,7 +220,7 @@
$self->{CHANS} = [];
my @channels;
- foreach my $chan_dev_dir (glob("$dev_dir/$num_str:[0-9][0-9]")) {
+ foreach my $chan_dev_dir (glob("$dev_dir/dahdi:dahdi![0-9]*")) {
my $chan = Dahdi::Chans->new($self, $chan_dev_dir);
push(@channels, $chan);
}
More information about the dahdi-commits
mailing list