From be3f8750d635d2a008d919aa46f219996926a502 Mon Sep 17 00:00:00 2001 From: Thierry Vignaud Date: Tue, 30 Nov 2004 15:27:24 +0000 Subject: (floppies) do not try to load floppy if there's no floppy drive (#8211) a side effect is that now we'll still see the floppy drive even if some buggy code triggered $@ earlier --- perl-install/detect_devices.pm | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) (limited to 'perl-install') diff --git a/perl-install/detect_devices.pm b/perl-install/detect_devices.pm index c8189d3d2..85e4195b0 100644 --- a/perl-install/detect_devices.pm +++ b/perl-install/detect_devices.pm @@ -52,12 +52,19 @@ sub zips() { sub floppies() { require modules; - eval { modules::load("floppy") } if $::isInstall; - my @fds = $@ ? () : map { - my $info = (!dev_is_devfs() || -e "/dev/fd$_") && c::floppy_info(devices::make("fd$_")); - if_($info && $info ne '(null)', { device => "fd$_", devfs_device => "floppy/$_", media_type => 'fd', info => $info }); - } qw(0 1); - + my @fds; + my @dmis = dmidecode(); + # do not try to load floppy if there's no floppy drive: + if (!@dmis || find { $_->{'Internal Reference Designator'} eq 'FLOPPY' && $_->{name} eq 'Port Connector' } @dmis) { + eval { modules::load("floppy") if $::isInstall }; + if (!$@) { + @fds = map { + my $info = (!dev_is_devfs() || -e "/dev/fd$_") && c::floppy_info(devices::make("fd$_")); + if_($info && $info ne '(null)', { device => "fd$_", devfs_device => "floppy/$_", media_type => 'fd', info => $info }); + } qw(0 1); + } + } + my @ide = ls120s() and eval { modules::load("ide-floppy") }; eval { modules::load("usb-storage") } if usbStorage(); -- cgit v1.2.1