summaryrefslogtreecommitdiff
path: root/v4l/scripts/rmmod.pl
diff options
context:
space:
mode:
Diffstat (limited to 'v4l/scripts/rmmod.pl')
-rwxr-xr-xv4l/scripts/rmmod.pl66
1 files changed, 19 insertions, 47 deletions
diff --git a/v4l/scripts/rmmod.pl b/v4l/scripts/rmmod.pl
index 48bc7ac1f..ed79cbe1e 100755
--- a/v4l/scripts/rmmod.pl
+++ b/v4l/scripts/rmmod.pl
@@ -27,24 +27,18 @@ my %debug = ( "tuner" => "tuner_debug=1",
"dvb-usb-dibusb-common" => "debug=0x03",
);
-my @obsolete;
sub getobsolete()
{
- open OBSOLETE, "<obsolete.txt";
+ my @obsolete;
+ open OBSOLETE, '<obsolete.txt' or die "Unable to open obsolete.txt: $!";
while (<OBSOLETE>) {
- if (m/^\s*\#/) {
- next;
- }
- s/\s*\#.*$//;
- s/\n$//;
- s|^.*/||;
- if (!$_) {
- next;
- }
- push @obsolete,$_;
+ next if (/^\s*#/ || /^\s*$/);
+ chomp;
+ m|^.*/([^/]+)$| and push @obsolete, $1;
}
close OBSOLETE;
+ return @obsolete;
}
sub findprog($)
@@ -172,37 +166,18 @@ sub insmod ($)
}
}
-sub rmmod ()
-{
- getobsolete();
- my $rmmod = findprog('rmmod');
- while (my $key=pop @modlist) {
- my $dep=$key;
- $dep=~s/[\-]/_/g;
- if (exists ($loaded{$dep})) {
- print "$rmmod $dep\n";
- system "$rmmod $dep\n";
- }
- }
-}
-
-sub rm_obsolete ()
+sub rmmod(@)
{
- getobsolete();
- my @obsolete2;
-
my $rmmod = findprog('rmmod');
- while (my $key=pop @obsolete) {
- my $dep=$key;
- $dep=~s/[\-]/_/g;
- if (exists ($loaded{$dep})) {
- print "$rmmod $dep\n";
- if (system "$rmmod $dep\n") {
- push @obsolete2,$key;
- }
+ my @not;
+ foreach (reverse @_) {
+ s/-/_/g;
+ if (exists ($loaded{$_})) {
+ print "$rmmod $_\n";
+ unshift @not, $_ if (system "$rmmod $_");
}
}
- @obsolete=@obsolete2;
+ return @not;
}
sub prepare_cmd()
@@ -223,18 +198,15 @@ if ($mode eq "load") {
if ($mode eq "unload") {
prepare_cmd;
parse_loaded;
- rmmod;
- if (length(@obsolete)) {
- rm_obsolete;
- rmmod;
- rm_obsolete;
+ my @notunloaded = rmmod(@modlist, getobsolete());
+ @notunloaded = rmmod(@notunloaded) if (@notunloaded);
+ if (@notunloaded) {
+ print "Couldn't unload: ", join(' ', @notunloaded), "\n";
}
} elsif ($mode eq "reload") {
prepare_cmd;
parse_loaded;
- my @modlist2=@modlist;
- rmmod;
- @modlist=@modlist2;
+ rmmod(@modlist);
insmod(0);
} elsif ($mode eq "debug") {
prepare_cmd;