summaryrefslogtreecommitdiffstats
path: root/perl-install/common.pm
Commit message (Expand)AuthorAgeFilesLines
* *** empty log message ***Francois Pons2000-05-221-5/+3
* *** empty log message ***Francois Pons2000-05-191-3/+25
* Small i18n fixesPablo Saratxaga2000-04-301-1/+1
* no_commentPascal Rigaux2000-04-251-1/+1
* no_commentPascal Rigaux2000-04-171-1/+7
* no_commentPascal Rigaux2000-04-141-1/+12
* no_commentPascal Rigaux2000-04-121-1/+2
* no_commentPascal Rigaux2000-03-301-1/+23
* *** empty log message ***Francois Pons2000-03-171-5/+1
* no_commentPascal Rigaux2000-03-071-2/+2
* no_commentPascal Rigaux2000-03-051-1/+2
* no_commentPascal Rigaux2000-02-211-2/+2
* no_commentPascal Rigaux2000-01-171-1/+1
* no_commentPascal Rigaux2000-01-161-1/+8
* no_commentPascal Rigaux2000-01-161-1/+2
* no_commentPascal Rigaux2000-01-061-1/+1
* no_commentPascal Rigaux1999-12-241-1/+6
* no_commentPascal Rigaux1999-12-221-1/+1
* no_commentPascal Rigaux1999-12-191-1/+1
* no_commentPascal Rigaux1999-12-171-11/+21
* allow use of locale names wider than two char (needed for chinese)Pablo Saratxaga1999-12-021-1/+2
* no_commentPascal Rigaux1999-12-011-3/+3
* no_commentPascal Rigaux1999-11-281-1/+1
* *** empty log message ***Francois Pons1999-11-241-5/+2
* *** empty log message ***Francois Pons1999-11-191-1/+1
* changed the order of serchaing variables for translate()Pablo Saratxaga1999-11-171-1/+1
* no_commentPascal Rigaux1999-11-121-1/+7
* *** empty log message ***Francois Pons1999-11-091-1/+4
* no_commentPascal Rigaux1999-11-091-1/+2
* no_commentPascal Rigaux1999-11-091-2/+5
* no_commentPascal Rigaux1999-11-081-1/+1
* no_commentPascal Rigaux1999-11-081-2/+2
* no_commentPascal Rigaux1999-11-061-12/+25
* *** empty log message ***Francois Pons1999-11-061-5/+9
* no_commentPascal Rigaux1999-11-021-1/+14
* no_commentPascal Rigaux1999-10-291-3/+18
* no_commentPascal Rigaux1999-10-251-5/+8
* no_commentPascal Rigaux1999-10-201-1/+17
* *** empty log message ***Francois Pons1999-10-141-1/+1
* no_commentPascal Rigaux1999-10-131-1/+2
* *** empty log message ***Francois Pons1999-10-111-0/+1
* no_commentPascal Rigaux1999-10-101-1/+2
* no_commentPascal Rigaux1999-10-081-5/+9
* no_commentPascal Rigaux1999-10-081-1/+15
* *** empty log message ***Francois Pons1999-09-281-1/+2
* no_commentPascal Rigaux1999-09-271-1/+0
* no_commentPascal Rigaux1999-09-241-4/+6
* no_commentPascal Rigaux1999-09-231-6/+18
* no_commentPascal Rigaux1999-09-201-6/+11
* no_commentPascal Rigaux1999-09-201-1/+1
##################### # handles dependencies sub load_raw { my ($lm, $h_options) = @_; my $l; # try to detect built-in modules by looking at /sys/module # unfortunately it does not work for all modules eg : # - networks protocols like af_packet # - filesystems foreach my $mod (@$lm) { $mod =~ s/-/_/g; if (-d "/sys/module/$mod") { log::l("$mod already loaded"); } elsif ($mod =~ /af_packet/) { if (-f "/proc/net/packet") { log::l("$mod already loaded"); } else { push @$l, $mod; } } elsif (cat_("/proc/filesystems") =~ /$mod/) { log::l("$mod already loaded"); } elsif ($mod =~ /serial/) { # hack ... must find who tries to load the module serial } else { push @$l, $mod; } } if ($::testing || $::local_install) { log::l("i would load module $_ ($h_options->{$_})") foreach @$l; } elsif ($::isInstall) { load_raw_install($l, $h_options); } else { run_program::run('/sbin/modprobe', $_, split(' ', $h_options->{$_})) or !run_program::run('/sbin/modprobe', '-n', $_) #- ignore missing modules or die "insmod'ing module $_ failed" foreach @$l; } if (any { /^(mousedev|printer)$/ } @$l) { sleep 2; } elsif (member('usb_storage', @$l)) { #- usb_storage is only modprobed when we know there is some scsi devices #- so trying hard to wait for devices to be detected run_program::run('udevadm', 'settle'); } } sub load_with_options { my ($l, $h_options) = @_; my @l = map { if_(member($_, 'plip', @parallel_zip_modules), 'parport_pc'), if_($_ eq 'vfat', 'nls_cp437', 'nls_iso8859_1'), if_($_ eq 'btrfs', 'crc32c', 'crc32c-intel'), dependencies_closure(cond_mapping_24_26($_)); } @$l; @l = filter_out_loaded_modules(@l) or return; my %options = map { cond_mapping_24_26($_) => $h_options->{$_} } keys %$h_options; load_raw(\@l, \%options); } sub load { my (@l) = @_; load_with_options(\@l, {}); } # eg: load_and_configure($modules_conf, 'bt878', [ bttv => 'no_overlay=1' ]) sub load_and_configure { my ($conf, $module, $o_options) = @_; my @l = filter_out_loaded_modules(dependencies_closure(cond_mapping_24_26($module))); load_raw(\@l, { cond_mapping_24_26($module) => $o_options }); if (member($module, @parallel_zip_modules) && ! -d "/proc/sys/dev/parport/parport0/devices/$module") { log::l("$module loaded but is not useful, removing"); unload($module); return; } $conf->set_options($module, $o_options) if $o_options; when_load($conf, $module); } sub unload { if ($::testing) { log::l("rmmod $_") foreach @_; } else { run_program::run("rmmod", $_) foreach @_; } } sub load_category { my ($conf, $category, $o_wait_message) = @_; my @try_modules = ( if_($category =~ /scsi/, if_(detect_devices::usbStorage(), 'usb_storage'), ), arch() =~ /ppc/ ? ( if_($category =~ /scsi/, if_(detect_devices::has_mesh(), 'mesh'), if_(detect_devices::has_53c94(), 'mac53c94'), ), if_($category =~ /net/, 'bmac', 'gmac', 'mace', 'airport'), ) : (), ); my @l = ( (map { my $other = { ahci => 'ata_piix', ata_piix => 'ahci' }->{$_->{driver}}; $_->{try} = 1 if $other; ($_, if_($other, { %$_, driver => $other })); } detect_devices::probe_category($category)), (map { { driver => $_, description => $_, try => 1 } } @try_modules), ); foreach (@l) { $o_wait_message->($_->{description}, $_->{driver}) if $o_wait_message; eval { load_and_configure($conf, $_->{driver}, $_->{options}) }; $_->{error} = $@; $_->{try} = 1 if member($_->{driver}, 'hptraid', 'ohci1394'); #- do not warn when this fails } eval { load_and_configure($conf, 'ide_generic') } if $category eq 'disk/ide'; grep { !($_->{error} && $_->{try}) } @l; } sub load_parallel_zip { my ($conf) = @_; arch() !~ /ppc/ or return; grep { eval { load_and_configure($conf, $_); 1 }; } @parallel_zip_modules; } #-############################################################################### #- modules.conf functions #-############################################################################### sub write_preload_conf { my ($conf) = @_; my @l; my $is_laptop = detect_devices::isLaptop(); my $manufacturer = detect_devices::dmidecode_category('System')->{Manufacturer}; push @l, 'scsi_hostadapter' if $conf->get_probeall('scsi_hostadapter'); push @l, detect_devices::probe_name('Module'); push @l, 'nvram' if $is_laptop; push @l, map { $_->{driver} } detect_devices::probe_category($_) foreach qw(multimedia/dvb multimedia/tv various/agpgart various/laptop input/joystick various/crypto disk/card_reader); push @l, 'padlock-aes', 'padlock-sha' if cat_("/proc/cpuinfo") =~ /rng_en/; push @l, 'evdev' if detect_devices::hasTouchpad(); push @l, 'evdev' if any { $_->{HWHEEL} } detect_devices::getInputDevices(); push @l, 'hdaps' if $is_laptop && $manufacturer eq 'LENOVO'; append_to_modules_loaded_at_startup("$::prefix/etc/modprobe.preload", @l); } sub append_to_modules_loaded_at_startup_for_all_kernels { append_to_modules_loaded_at_startup($_, @_) foreach "$::prefix/etc/modprobe.preload"; } sub append_to_modules_loaded_at_startup { my ($file, @l) = @_; my $l = join '|', map { '^\s*' . $_ . '\s*$' } @l; log::l("to put in $file ", join(", ", @l)); substInFile { $_ = '' if $l && /$l/; $_ .= join '', map { "$_\n" } @l if eof; } $file; } sub set_preload_modules { my ($service, @modules) = @_; my $preload_file = "$::prefix/etc/modprobe.preload.d/$service"; if (@modules) { output_p($preload_file, join("\n", @modules, '')); } else { unlink($preload_file); } eval { load(@modules) } if @modules && !$::isInstall; } #-############################################################################### #- internal functions #-############################################################################### sub loaded_modules() { map { /(\S+)/ } cat_("/proc/modules"); } sub filter_out_loaded_modules { my (@l) = @_; difference2([ uniq(@l) ], [ map { my $s = $_; $s =~ s/_/-/g; $s, $_ } loaded_modules() ]); } sub read_already_loaded { my ($conf) = @_; when_load($conf, $_) foreach reverse loaded_modules(); } sub when_load { my ($conf, $name) = @_; if (my $category = module2category($name)) { when_load_category($conf, $name, $category); } if (my @above = $conf->get_above($name)) { load(@above); #- eg: for snd-pcm-oss set by set_sound_slot() } } sub when_load_category { my ($conf, $name, $category) = @_; if ($category =~ m,disk/ide,) { $conf->add_probeall('ide-controller', $name); eval { load('ide_gd_mod') }; } elsif ($category =~ m,disk/(scsi|hardware_raid|sata|firewire),) { $conf->add_probeall('scsi_hostadapter', $name); eval { load('sd_mod') }; } elsif ($category eq 'bus/usb') { $conf->add_probeall('usb-interface', $name); -f '/sys/kernel/debug/usb/devices' or eval { require fs::mount; fs::mount::sys_kernel_debug(''); #- ensure keyboard is working, the kernel must do the job the BIOS was doing sleep 4; load("usbhid") if detect_devices::usbKeyboards(); }; } elsif ($category eq 'bus/firewire') { $conf->set_alias('ieee1394-controller', $name); } elsif ($category =~ /sound/) { my $sound_alias = find { /^sound-slot-[0-9]+$/ && $conf->get_alias($_) eq $name } $conf->modules; $sound_alias ||= 'sound-slot-0'; $conf->set_sound_slot($sound_alias, $name); } elsif ($category =~ m!disk/card_reader!) { my @modules = ('mmc_block', if_($name =~ /tifm_7xx1/, 'tifm_sd')); $conf->set_above($name, join(' ', @modules)); } } #-############################################################################### #- isInstall functions #-############################################################################### sub module_extension() { ".ko" } sub extract_modules { my ($dir, @modules) = @_; map { my $modname = $_; my $path = list_modules::modname2path($modname); my $f = $modname . module_extension(); if (-e $path) { system("gzip -dc $path > $dir/$f 2>/dev/null") == 0 or system("xz -d < $path > $dir/$f") == 0 or unlink "$dir/$f"; } else { log::l("warning: unable to get module filename for $modname (path: $path)"); } "$dir/$f"; } @modules; } sub load_raw_install { my ($l, $options) = @_; extract_modules('/tmp', @$l); my @failed = grep { my $m = '/tmp/' . $_ . module_extension(); if (-e $m) { my $stdout; my $rc = run_program::run('/sbin/insmod', '2>', \$stdout, $m, split(' ', $options->{$_})); log::l(chomp_($stdout)) if $stdout; # if whether we succeeded or module is already loaded: if ($rc || $stdout =~ /: -1 File exists/) { unlink $m; ''; } } else { log::l("missing module $_"); 'error'; } } @$l; die "insmod'ing module " . join(", ", @failed) . " failed" if @failed; } 1;