more probing from raspberry pi side
[x300-pci] / gpio.pl
diff --git a/gpio.pl b/gpio.pl
index ed000c9..f72f61d 100755 (executable)
--- a/gpio.pl
+++ b/gpio.pl
@@ -2,16 +2,18 @@
 use warnings;
 use strict;
 
+package gpio;
+
 use Data::Dump qw(dump);
 
 my @last;
+my $mode;
 
-while(1) {
+sub pins {
 
 my @pcf = `gpio -x pcf8591:120:0x48 readall`;
 my @gpio = `gpio -g readall`;
 my $i = 0;
-my $mode;
 
 foreach (@gpio) {
        chomp;
@@ -24,34 +26,39 @@ foreach (@gpio) {
        s/([ \d]{2})(...GPIO.)../$1$2$1/;
        s/(GPIO.)..(...)(\s*\d+)/$1$3$2$3/;
 
-       my $line = $_ . ( shift @pcf || '');
+       my $line = substr($_,0,29) . substr($_,39);
+       $line .= shift @pcf || '';
+
        chomp $line;
        my @l = split(/\|/, $line);
-       if ( $#l > 10 ) {
+       my @o = split(/\|/, $last[$i] || '');
+       $last[$i] = $line;
+       $i++;
+
+       if ( $#l >= 9 ) {
                no warnings;
                $mode->{ $l[1]  } = [ $l[4] + 0, $l[2], $l[3] ];
-               $mode->{ $l[11] } = [ $l[8] + 0, $l[10], $l[9] ];
-               $mode->{ $l[13] } = [ $l[14], $l[15] ] if $l[15];
+               $mode->{ $l[9]  } = [ $l[6] + 0, $l[8], $l[7] ];
+               $mode->{ $l[11] } = [ $l[12], $l[13] ] if $l[13];
                #warn "## l = ",dump(@l);
        }
        
 
        if ( $last[$i] && $line ne $last[$i] ) {
-               my @o = split(/\|/, $last[$i]);
                foreach my $i ( 0 .. $#l ) {
                        $l[$i] = "\e[33;7;1m$l[$i]\e[0m" if $l[$i] ne $o[$i];
                }
-               print join('|', @l), "|\n";
-       } else {
-               print "$line\n";
+               $line = join('|', @l) . "|";
        }
-       $last[$i] = $line;
-       $i++;
+
+       print "$line\n";
 
 }
 
 #warn "# mode = ", dump($mode);
 
+} #/gpio
+
 sub pin2dir {
        my $pin = shift;
        my ($p) = grep { /$pin/ } keys %$mode;
@@ -60,20 +67,28 @@ warn dump($p);
        warn "# pin2dir $pin = $dir\n";
        return $dir;
 }
-       
-
-my $cmd = <STDIN>;
-chomp $cmd;
-if ( $cmd =~ m/^(\d+)$/ ) {
-       my $pin = $1;
-       system "gpio -g mode $pin out" unless pin2dir($pin) =~ m/OUT/i;
 
-       my $v = `gpio -g read $pin`;
-       warn "# pin $pin ", $v;
-       $v ^= 1;
-       system "gpio -g write $pin $v";
+sub cmd {
+       my $cmd = shift;
+       chomp $cmd;
+       if ( $cmd =~ m/^(\d+)$/ ) {
+               my $pin = $1;
+               system "gpio -g mode $pin out" unless pin2dir($pin) =~ m/OUT/i;
+
+               my $v = `gpio -g read $pin`;
+               warn "# pin $pin ", $v;
+               $v ^= 1;
+               system "gpio -g write $pin $v";
+       }
 }
 
+package main;
+
+return 1 if caller; # used as module
 
-} #/while
+while(1) {
+       gpio::pins();
+       my $cmd = <STDIN>;
+       gpio::cmd($cmd);
+}