[dahdi-commits] tzafrir: branch tools/tzafrir/sysfs r8219 - in /tools/team/tzafrir/sysfs: ./ ...
SVN commits to the DAHDI project
dahdi-commits at lists.digium.com
Tue Mar 2 14:10:15 CST 2010
Author: tzafrir
Date: Tue Mar 2 14:10:11 2010
New Revision: 8219
URL: http://svnview.digium.com/svn/dahdi?view=rev&rev=8219
Log:
Merged revisions 8215 via svnmerge from
https://origsvn.digium.com/svn/dahdi/tools/trunk
........
r8215 | tzafrir | 2010-03-02 20:07:37 +0200 (Tue, 02 Mar 2010) | 11 lines
DAHDI-perl: allow setting base of system files with DAHDI_VIRT_TOP
If the user set DAHDI_VIRT_TOP in the environment, consider it as a path
under which to look for ProcFS and SysFS files. This allows running the
DAHDI-perl tools on filesystem dumps generated by
build_tools/dump_sys_state .
To reduce the number of dependencies between various modules, the 'xpd'
member of a Dahdi::Span is removed. Dahdi::Xpp::xpd_of_span() can be
used if needed.
........
Modified:
tools/team/tzafrir/sysfs/ (props changed)
tools/team/tzafrir/sysfs/xpp/lsdahdi
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi.pm
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Hardware/PCI.pm
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Hardware/USB.pm
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Utils.pm
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Xpp.pm
tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Xpp/Xbus.pm
Propchange: tools/team/tzafrir/sysfs/
------------------------------------------------------------------------------
automerge = YES
Propchange: tools/team/tzafrir/sysfs/
------------------------------------------------------------------------------
--- svnmerge-integrated (original)
+++ svnmerge-integrated Tue Mar 2 14:10:11 2010
@@ -1,1 +1,1 @@
-/tools/trunk:1-8213
+/tools/trunk:1-8218
Modified: tools/team/tzafrir/sysfs/xpp/lsdahdi
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/lsdahdi?view=diff&rev=8219&r1=8218&r2=8219
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/lsdahdi (original)
+++ tools/team/tzafrir/sysfs/xpp/lsdahdi Tue Mar 2 14:10:11 2010
@@ -22,7 +22,7 @@
foreach my $span (Dahdi::spans()) {
my $spanno = $span->num;
- my $xpd = $span->xpd;
+ my $xpd = Dahdi::Xpp::xpd_of_span($span);
my @lines;
my $index = 0;
Modified: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi.pm
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi.pm?view=diff&rev=8219&r1=8218&r2=8219
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi.pm Tue Mar 2 14:10:11 2010
@@ -32,8 +32,12 @@
}
=cut
-my $proc_base = "/proc/dahdi";
-my $sysfs_base = '/sys/class/dahdi_span';
+our $virt_base;
+our $proc_dahdi_base;
+our $proc_xpp_base;
+our $proc_usb_base;
+our $sys_base;
+our $sysfs_span_base;
=head1 spans()
@@ -44,14 +48,14 @@
sub spans() {
my @spans;
- if ( -d $sysfs_base) {
- foreach my $zfile (glob "$sysfs_base/span-*") {
+ if ( -d $sysfs_span_base) {
+ foreach my $zfile (glob "$sysfs_span_base/span-*") {
my $span = Dahdi::Span->new($zfile);
push(@spans, $span);
}
- } elsif ( -d $proc_base ) {
- foreach my $zfile (glob "$proc_base/*") {
- $zfile =~ s:$proc_base/::;
+ } elsif ( -d $proc_dahdi_base ) {
+ foreach my $zfile (glob "$proc_dahdi_base/*") {
+ $zfile =~ s:$proc_dahdi_base/::;
next unless ($zfile =~ /^\d+$/);
my $span = Dahdi::Span->new_procfs($zfile);
push(@spans, $span);
@@ -59,7 +63,6 @@
} else {
return ();
}
- @spans = sort { $a->num <=> $b->num } @spans;
return @spans;
}
@@ -74,6 +77,13 @@
return $span;
}
+=head1 ENVIRONMENT
+
+If C<DAHDI_VIRT_TOP> is set in the environment, it will be considered
+as a path to a directory that holds a dump (copy) of all the required
+files from /proc and /sys . You can generate that directory using the
+script C<build_tools/dump_sys_state> .
+
=head1 SEE ALSO
Span objects: L<Dahdi::Span>.
Modified: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Hardware/PCI.pm
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Hardware/PCI.pm?view=diff&rev=8219&r1=8218&r2=8219
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Hardware/PCI.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Hardware/PCI.pm Tue Mar 2 14:10:11 2010
@@ -170,7 +170,7 @@
sub scan_devices($) {
my @devices;
- while(</sys/bus/pci/devices/*>) {
+ while(<$Dahdi::sys_base/bus/pci/devices/*>) {
m,([^/]+)$,,;
my $name = $1;
my $l = readlink $_ || die;
Modified: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Hardware/USB.pm
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Hardware/USB.pm?view=diff&rev=8219&r1=8218&r2=8219
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Hardware/USB.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Hardware/USB.pm Tue Mar 2 14:10:11 2010
@@ -135,7 +135,7 @@
my $pack = shift || die;
my @devices = ();
- while (</sys/bus/usb/devices/*-*>) {
+ while (<$Dahdi::sys_base/bus/usb/devices/*-*>) {
next unless -r "$_/idVendor"; # endpoints
# Older kernels, e.g. 2.6.9, don't have the attribute
@@ -165,7 +165,7 @@
sub scan_devices($) {
my $pack = shift || die;
- my $usb_device_list = "/proc/bus/usb/devices";
+ my $usb_device_list = "$Dahdi::proc_usb_base/devices";
return $pack->scan_devices_sysfs() unless (-r $usb_device_list);
my @devices;
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=8219&r1=8218&r2=8219
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Span.pm Tue Mar 2 14:10:11 2010
@@ -10,7 +10,6 @@
use strict;
use Dahdi::Utils;
use Dahdi::Chans;
-use Dahdi::Xpp::Xpd;
=head1 NAME
@@ -112,8 +111,6 @@
"signalling" is set, look for "SIGNALLING".
=cut
-
-my $proc_base = "/proc/dahdi";
sub chans($) {
my $span = shift;
@@ -174,18 +171,6 @@
$self->{TYPE} = "${proto}_$self->{TERMTYPE}";
}
-sub _get_span_xpdinfo($) {
- my $self = shift;
- $self->{TYPE} = "UNKNOWN";
- my @xpds = Dahdi::Xpp::Xpd::xpds_by_spanno;
- my $num = $self->{NUM};
- my $xpd = $xpds[$num];
- if(defined $xpd) {
- die "Spanno mismatch: $xpd->spanno, $num" unless $xpd->spanno == $num;
- $self->{XPD} = $xpd;
- }
-}
-
sub _get_dev_attr($$) {
my $self = shift;
my $attr = shift;
@@ -212,7 +197,6 @@
my $self = { NUM => $num, DEV_DIR => $dev_dir };
bless $self, $pack;
- $self->_get_span_xpdinfo();
$self->{IS_DIGITAL} = $self->_get_dev_attr('is_digital');
$self->{IS_DAHDI_SYNC_MASTER} = $self->_get_dev_attr('is_sync_master');
$self->{NAME} = $self->_get_dev_attr('name');
@@ -245,7 +229,8 @@
my $num = shift or die "Missing a span number parameter\n";
my $self = { NUM => $num };
bless $self, $pack;
- open(F, "$proc_base/$num") or die "Failed to open '$proc_base/$num\n";
+ open(F, "$Dahdi::proc_dahdi_base/$num") or
+ die "Failed to open '$Dahdi::proc_dahdi_base/$num\n";
my $head = <F>;
chomp $head;
$self->{IS_DIGITAL} = 0;
Modified: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Utils.pm
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Utils.pm?view=diff&rev=8219&r1=8218&r2=8219
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Utils.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Utils.pm Tue Mar 2 14:10:11 2010
@@ -21,6 +21,21 @@
#print STDERR "get: $key ($val)\n";
return $val;
}
+}
+
+# Initialize ProcFS and SysFS pathes, in case the user set
+# DAHDI_VIRT_TOP
+BEGIN {
+ if (exists $ENV{DAHDI_VIRT_TOP}) {
+ $Dahdi::virt_base = $ENV{DAHDI_VIRT_TOP};
+ } else {
+ $Dahdi::virt_base = '';
+ }
+ $Dahdi::proc_dahdi_base = "$Dahdi::virt_base/proc/dahdi";
+ $Dahdi::proc_xpp_base = "$Dahdi::virt_base/proc/xpp";
+ $Dahdi::proc_usb_base = "$Dahdi::virt_base/proc/bus/usb";
+ $Dahdi::sys_base = "$Dahdi::virt_base/sys";
+ $Dahdi::sysfs_span_base = "$Dahdi::sys_base/class/dahdi_span";
}
sub xpp_dump($) {
Modified: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Xpp.pm
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Xpp.pm?view=diff&rev=8219&r1=8218&r2=8219
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Xpp.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Xpp.pm Tue Mar 2 14:10:11 2010
@@ -34,10 +34,16 @@
#
my @xbuses;
-my $proc_base = "/proc/xpp";
-our $sysfs_astribanks = "/sys/bus/astribanks/devices";
-our $sysfs_xpds = "/sys/bus/xpds/devices";
-our $sysfs_ab_driver = "/sys/bus/astribanks/drivers/xppdrv";
+our $sysfs_astribanks;
+our $sysfs_xpds;
+our $sysfs_ab_driver;
+
+BEGIN {
+ my $virt_base = $Dahdi::virt_base;
+ $sysfs_astribanks = "$virt_base/sys/bus/astribanks/devices";
+ $sysfs_xpds = "$virt_base/sys/bus/xpds/devices";
+ $sysfs_ab_driver = "$virt_base/sys/bus/astribanks/drivers/xppdrv";
+}
sub scan($) {
my $pack = shift || die;
@@ -253,6 +259,7 @@
my $result;
my $newapi = 0;
+ my $proc_base = $Dahdi::proc_xpp_base;
my $file = "$proc_base/sync";
return '' unless -f $file;
# First query
Modified: tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Xpp/Xbus.pm
URL: http://svnview.digium.com/svn/dahdi/tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Xpp/Xbus.pm?view=diff&rev=8219&r1=8218&r2=8219
==============================================================================
--- tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Xpp/Xbus.pm (original)
+++ tools/team/tzafrir/sysfs/xpp/perl_modules/Dahdi/Xpp/Xbus.pm Tue Mar 2 14:10:11 2010
@@ -12,8 +12,6 @@
use Dahdi::Hardware;
use Dahdi::Xpp::Xpd;
-my $proc_base = "/proc/xpp";
-
sub xpds($) {
my $xbus = shift;
return @{$xbus->{XPDS}};
@@ -54,7 +52,7 @@
foreach my $attr (@attr) {
my $file = sprintf "$Dahdi::Xpp::sysfs_astribanks/xbus-%02d/$attr", $busnum;
unless(-f $file) {
- my $procfile = sprintf "/proc/xpp/XBUS-%02d/$attr", $busnum;
+ my $procfile = sprintf "$Dahdi::proc_xpp_base/XBUS-%02d/$attr", $busnum;
warn "$0: warning - OLD DRIVER: missing '$file'. Fall back to '$procfile'\n"
unless $file_warned{$attr}++;
$file = $procfile;
@@ -113,7 +111,7 @@
sub read_xpdnames_old($) {
my $xbus_num = shift || die;
- my $pat = sprintf "/proc/xpp/XBUS-%02d/XPD-[0-9][0-9]", $xbus_num;
+ my $pat = sprintf "$Dahdi::proc_xpp_base/XBUS-%02d/XPD-[0-9][0-9]", $xbus_num;
my @xpdnames;
#print STDERR "read_xpdnames_old($xbus_num): $pat\n";
@@ -175,7 +173,7 @@
}
foreach my $xpdstr (@xpdnames) {
my ($busnum, $unit, $subunit) = split(/:/, $xpdstr);
- my $procdir = "/proc/xpp/XBUS-$busnum/XPD-$unit$subunit";
+ my $procdir = "$Dahdi::proc_xpp_base/XBUS-$busnum/XPD-$unit$subunit";
my $xpd = Dahdi::Xpp::Xpd->new($self, $unit, $subunit, $procdir, "$xbus_dir/$xpdstr");
push(@xpds, $xpd);
}
More information about the dahdi-commits
mailing list