From 887c41ee6d59af5bc84dbf6be480ab7829171e8a Mon Sep 17 00:00:00 2001 From: Olivier Blin Date: Thu, 28 Feb 2008 16:20:13 +0000 Subject: support new modules location (#38207) by reusing some DrakX code (and duplicating a bit of install::commands) --- rescue/tree/sbin/modprobe | 64 +++++++++-------------------------------------- 1 file changed, 12 insertions(+), 52 deletions(-) (limited to 'rescue/tree') diff --git a/rescue/tree/sbin/modprobe b/rescue/tree/sbin/modprobe index b8d6aecb2..a9cd91a89 100755 --- a/rescue/tree/sbin/modprobe +++ b/rescue/tree/sbin/modprobe @@ -1,56 +1,16 @@ #!/usr/bin/perl -sub cat_ { local *F; open F, $_[0] or $_[1] ? die "cat of file $_[0] failed: $!\n" : return; my @l = ; wantarray ? @l : join '', @l } - -sub read_already_loaded() { - foreach (cat_("/proc/modules")) { - my ($name) = split; - $conf{$name}{loaded} = 1; - } -} - -sub load_deps($) { - my ($file) = @_; - - local *F; - open F, $file or warn "error opening $file: $!\n", return 0; - foreach () { - my ($f, $deps) = split ':'; - push @{$deps{$f}}, split ' ', $deps; - } +use lib qw(/usr/lib/libDrakX); +use list_modules; +use modules; + +# based on install::commands +sub modprobe { + !@_ || $_[0] =~ /^-?-h/ and die "usage: modprobe []\n"; + my $name = shift; + list_modules::load_default_moddeps(); + modules::load_with_options([ $name ], { $name => join(' ', @_) }); } -my $module_extension = cat_('/proc/version') =~ /^Linux version 2.4/ ? '.o' : '.ko'; - -my %mappings = ("usb-ohci" => "ohci-hcd", - "usb-uhci" => "uhci-hcd", - "uhci" => "uhci-hcd", - "printer" => "usblp", - "bcm4400" => "b44", - "3c559" => "3c359", - "3c90x" => "3c59x", - "dc395x_trm" => "dc395x", - "audigy" => "snd-emu10k1"); - -sub load { - my ($name, @options) = @_; - $name =~ s/\.k?o$//; - - $name = $mappings{$name} || $name; #- 2.4 -> 2.6 compat mappings - - $conf{$name}{loaded} and return; - eval { load($_, 'prereq') } foreach @{$deps{$name}}; - - system("gzip -dc /modules/$name$module_extension.gz > /tmp/$name$module_extension"); - -r "/tmp/$name$module_extension" or die "can't find module $name\n"; - system("/sbin/insmod /tmp/$name$module_extension"); - my $retval = $?; - system("rm /tmp/$name$module_extension"); - $retval and die("insmod $name failed"); -} - -!@ARGV || $ARGV[0] =~ /^-?-h/ and die "usage: modprobe []\n"; - -read_already_loaded(); -load_deps("/modules/modules.dep"); -load(@ARGV); +$::isInstall = 1; +modprobe(@ARGV); -- cgit v1.2.1