diff options
Diffstat (limited to 'perl-install/harddrake/data.pm')
| -rw-r--r-- | perl-install/harddrake/data.pm | 588 | 
1 files changed, 524 insertions, 64 deletions
| diff --git a/perl-install/harddrake/data.pm b/perl-install/harddrake/data.pm index 691dafa34..8d4d4de21 100644 --- a/perl-install/harddrake/data.pm +++ b/perl-install/harddrake/data.pm @@ -3,26 +3,36 @@ package harddrake::data;  use strict;  use detect_devices;  use common; +use modules;  our @ISA = qw(Exporter);  our @EXPORT_OK = qw(version tree);  our ($version, $sbindir, $bindir) = ("10", "/usr/sbin", "/usr/bin"); -my @devices = detect_devices::probeall(); +my @devices = (detect_devices::probeall(), detect_devices::getSCSI()); + +foreach my $dev (@devices) { +    # normalize device IDs for devices that came from mouse.pm: +    next if !defined $dev->{Synaptics}; +    foreach my $field (qw(vendor id subvendor subid)) { +        next if !defined $dev->{$field}; +        $dev->{$field} = hex($dev->{$field}); +    } +}  # Update me each time you handle one more devices class (aka configurator)  sub unknown() { -    grep { $_->{media_type} !~ /BRIDGE|class\|Mouse|DISPLAY|Hub|MEMORY_RAM|MULTIMEDIA_(VIDEO|AUDIO|OTHER)|NETWORK|Printer|SERIAL_(USB|SMBUS)|STORAGE_(IDE|OTHER|SCSI)|tape/ +    grep { $_->{media_type} !~ /BRIDGE|class\|Mouse|DISPLAY|Hub|MEMORY_RAM|MULTIMEDIA_(VIDEO|AUDIO|OTHER)|NETWORK|Printer|SERIAL_(USB|SMBUS)|STORAGE_(IDE|OTHER|RAID|SCSI)|SYSTEM_(OTHER|SDHCI)|tape|UPS/  	       && !member($_->{driver}, qw(cpia_usb cyber2000fb forcedeth ibmcam megaraid mod_quickcam nvnet ohci1394 ov511 ov518_decomp scanner ultracam usbvideo usbvision)) -	       && $_->{driver} !~ /^ISDN|Mouse:USB|Removable:zip|class\|Mouse|www.linmodems.org/ +	       && $_->{driver} !~ /^ISDN|Mouse:USB|Removable:zip|class\|Mouse|sata|www.linmodems.org|kbd|mouse|sysrq|usbhid/  	       && $_->{type} ne 'network' -	       && $_->{description} !~ /Alcatel|ADSL Modem/ +	       && $_->{description} !~ /Alcatel|ADSL Modem/;  	   } @devices;  }  my @alrd_dected;  sub f {  -    my @devs = grep { !member(pciusb_id($_), @alrd_dected) } @_; +    my @devs = grep { !member(pciusb_id($_), @alrd_dected) } grep { $_ } @_;      push @alrd_dected, map { pciusb_id($_) } @devs;      @devs;  } @@ -34,75 +44,523 @@ sub f {  # FIXME: add translated items -sub is_removable { $_[0] =~ /FLOPPY|ZIP|DVDROM|CDROM|BURNER/ } +sub is_removable { member($_[0], qw(FLOPPY ZIP DVDROM CDROM BURNER)) } +sub is_auto_configurable_media { !detect_devices::isKeyUsb($_[0]) }  sub set_removable_configurator {      my ($class, $device) = @_; -    return "/usr/sbin/diskdrake --removable=$device->{device}" if is_removable($class); -} - -sub set_removable_remover { -    my ($class, $device) = @_; -    return "/usr/sbin/drakupdate_fstab --no-flag --del $device->{device}" if is_removable($class); -} +    is_removable($class) ? "/usr/sbin/diskdrake --removable=$device->{device}" : undef; + } +my $modules_conf = modules::any_conf->read;  # Format is (HW class ID, l18n class name, icon, config tool , is_to_be_detected_on_boot)  our @tree =      ( -     [ "FLOPPY", , N("Floppy"), "floppy.png", "", \&detect_devices::floppies, 1 ], -     [ "ZIP", , N("Zip"), "floppy.png", "", \&detect_devices::zips, 1 ], -     [ "HARDDISK", , N("Disk"), "harddisk.png", "$sbindir/diskdrake", \&detect_devices::hds, 1 ], -     [ "CDROM", , N("CDROM"), "cd.png", "", sub { grep { !(detect_devices::isBurner($_) || detect_devices::isDvdDrive($_)) } &detect_devices::cdroms }, 1 ], -     [ "BURNER", , N("CD/DVD burners"), "cd.png", "", \&detect_devices::burners, 1 ], -     [ "DVDROM", , N("DVD-ROM"), "cd.png", "", sub { grep { ! detect_devices::isBurner($_) } detect_devices::dvdroms() }, 1 ], -     [ "TAPE", , N("Tape"), "tape.png", "", \&detect_devices::tapes, 0 ], -     [ "VIDEO", , N("Videocard"), "video.png", "$sbindir/XFdrake",  sub { f(grep { $_->{driver} =~ /^(Card|Server):/ || $_->{media_type} =~ /DISPLAY_VGA/ } @devices) }, 1 ], -     [ "TV", , N("Tvcard"), "tv.png", "/usr/bin/XawTV", sub { f(grep { $_->{media_type} =~ /MULTIMEDIA_VIDEO/ && $_->{bus} eq 'PCI' || $_->{driver} eq 'usbvision' } @devices) }, 0 ],      -     [ "MULTIMEDIA_OTHER", , N("Other MultiMedia devices"), "multimedia.png", "", sub { f(grep { $_->{media_type} =~ /MULTIMEDIA_OTHER/ } @devices) }, 0 ], -     [ "AUDIO", , N("Soundcard"), "sound.png", "$sbindir/draksound", sub { f(grep { $_->{media_type} =~ /MULTIMEDIA_AUDIO/ } @devices) }, 1 ], -     [ "WEBCAM", , N("Webcam"), "webcam.png", "", sub {  -           f(grep { $_->{media_type} =~ /MULTIMEDIA_VIDEO/ && $_->{bus} ne 'PCI' ||  -                      member($_->{driver}, qw(cpia_usb cyber2000fb ibmcam mod_quickcam ov511 ov518_decomp pwc ultracam usbvideo)) } @devices) }, -       0 ], -     [ "CPU", , N("Processors"), "cpu.png", "", sub { detect_devices::getCPUs() }, 0 ], -     [ "ISDN", , N("ISDN adapters"), "modem.png", "$sbindir/drakconnect", sub { require network::isdn; my $isdn = network::isdn::isdn_detect_backend(); -                                                                                if_(!is_empty_hash_ref($isdn), f(@$isdn)) }, 0 ], -     [ "ETHERNET", , N("Ethernetcard"), "hw_network.png", "$sbindir/drakconnect", sub { -         #- generic NIC detection for USB seems broken (class, subclass,  -         #- protocol report are not accurate) so I'll need to verify against -         #- known drivers :-( -         require list_modules; -         my @usbnet = (list_modules::category2modules('network/usb'), "nvnet"); # rought hack for nforce2's nvet -          -         f(grep { $_->{media_type} && $_->{media_type} =~ /^NETWORK/ || member($_->{driver}, @usbnet) || $_->{type} && $_->{type} eq 'network' } @devices) }, 1 ], -     [ "MODEM", , N("Modem"), "modem.png", "$sbindir/drakconnect", sub { detect_devices::getModem() }, 0 ], -     [ "ADSL", , N("ADSL adapters"), "modem.png", "$sbindir/drakconnect", sub {  -           require network::adsl; my $a = network::adsl::adsl_detect(); $a ? f(grep { $_ } values %$a) : () }, 0 ], -     [ "BRIDGE", , N("Bridges and system controllers"), "memory.png", "", sub { f(grep { $_->{media_type} =~ /BRIDGE|MEMORY_RAM/ && $_->{driver} ne 'nvnet' } @devices) }, 0 ], -     [ "PRINTER", , N("Printer"), "hw_printer.png", "$sbindir/printerdrake", sub {  -         require printer::detect; printer::detect::local_detect() }, 0 ], -     [ "MOUSE", , N("Mouse"), "hw_mouse.png", "$sbindir/mousedrake", sub {  -         require mouse; -         require modules; -         modules::mergein_conf('/etc/modules.conf') if -r '/etc/modules.conf'; -         &mouse::detect() }, 1 ], -     [ "JOYSTICK", , N("Joystick"), "joystick.png", "", sub {}, 0 ], - -     [ "ATA_STORAGE", , N("(E)IDE/ATA controllers"), "ide_hd.png", "", sub { f(grep { $_->{media_type} =~ /STORAGE_(IDE|OTHER)/ -                                                                                        || $_->{driver} eq '3w-xxxx' } @devices) }, 0 ], -     [ "FIREWIRE_CONTROLLER", , N("Firewire controllers"), "usb.png", "", sub { f(grep { $_->{driver} =~ /ohci1394/ } @devices) }, 1 ], -     [ "SCSI_CONTROLLER", , N("SCSI controllers"), "scsi.png", "", sub { f(grep { $_->{media_type} =~ /STORAGE_SCSI/ || $_->{driver} eq 'megaraid' } @devices) }, 0 ], -     [ "USB_CONTROLLER", , N("USB controllers"), "usb.png", "", sub { f(grep { $_->{media_type} =~ /SERIAL_USB|Hub/ } @devices) }, 0 ], -     [ "SMB_CONTROLLER", , N("SMBus controllers"), "usb.png", "", sub { f(grep { $_->{media_type} =~ /SERIAL_SMBUS/ } @devices) }, 0 ], -     [ "SCANNER", , N("Scanner"), "scanner.png", "$sbindir/scannerdrake", sub {  -         require scanner; f(scanner::detect()) }, 0 ], -     [ "UNKNOWN", , N("Unknown/Others"), "unknown.png", "", sub { f(unknown()) }, 0 ] -     ); +     { +      class => "SATA_STORAGE", +      string => N("SATA controllers"), +      icon => "ide_hd.png", +      configurator => "", +      detector => sub { f(grep { $_->{driver} !~ /^pata/ } detect_devices::probe_category('disk/sata')), +                          f(grep { $_->{description} =~ /AHCI/ } @devices) }, +      checked_on_boot => 1, +     }, + +     { +      class => "RAID_STORAGE", +      string => N("RAID controllers"), +      icon => "ide_hd.png", +      configurator => "", +      detector => sub { f(detect_devices::probe_category('disk/hardware_raid')), +                          f(grep { $_->{media_type} =~ /STORAGE_RAID/ } @devices) }, +      checked_on_boot => 1, +     }, + +     { +      class => "ATA_STORAGE", +      string => N("(E)IDE/ATA controllers"), +      icon => "ide_hd.png", +      configurator => "", +      detector => sub { f(detect_devices::probe_category('disk/ide')), +                          f(grep { $_->{driver} =~ /^pata/ && $_->{media_type} =~ /IDE|STORAGE_SATA/ } @devices), +                              f(grep { $_->{media_type} =~ /STORAGE_(IDE|OTHER)/ } @devices) }, +      checked_on_boot => 1, +     }, + +     { +      class => "CARD_READER", +      string => N("Card readers"), +      icon => "ide_hd.png", +      configurator => "", +      detector => sub { f(detect_devices::probe_category('disk/card_reader')) }, +      checked_on_boot => 1, +     }, + +     { +      class => "FIREWIRE_CONTROLLER", +      string => N("Firewire controllers"), +      icon => "usb.png", +      configurator => "", +      detector => sub { f(grep { $_->{driver} =~ /firewire_ohci|ohci1394/ } @devices) }, +      checked_on_boot => 1, +     }, + +     { +      class => "PCMCIA_CONTROLLER", +      string => N("PCMCIA controllers"), +      icon => "hw-pcmcia.png", +      configurator => "", +      detector => sub { f(detect_devices::pcmcia_controller_probe()) }, +      checked_on_boot => 1, +     }, + +     { +      class => "SCSI_CONTROLLER", +      string => N("SCSI controllers"), +      icon => "scsi.png", +      configurator => "", +      detector => sub { f(detect_devices::probe_category('disk/scsi'), grep { $_->{media_type} =~ /STORAGE_SCSI/ } @devices) }, +      checked_on_boot => 1, +     }, + +     { +      class => "USB_CONTROLLER", +      string => N("USB controllers"), +      icon => "usb.png", +      configurator => "", +      detector => sub { f(grep { $_->{media_type} eq 'SERIAL_USB' } @devices) }, +      checked_on_boot => 1, +     }, + +     { +      class => "USB_HUB", +      string => N("USB ports"), +      icon => "hw-usb.png", +      configurator => "", +      detector => sub { f(grep { $_->{media_type} =~ /Hub/ } @devices) }, +      checked_on_boot => 0, +     }, + +     { +      class => "SMB_CONTROLLER", +      string => N("SMBus controllers"), +      icon => "hw-smbus.png", +      configurator => "", +      detector => sub { f(grep { $_->{media_type} =~ /SERIAL_SMBUS/ } @devices) }, +      checked_on_boot => 0, +     }, + +     { +      class => "BRIDGE", +      string => N("Bridges and system controllers"), +      icon => "memory.png", +      configurator => "", +      detector => sub { f(grep { $_->{media_type} =~ /BRIDGE|MEMORY_RAM|SYSTEM_(OTHER|SDHCI)|MEMORY_OTHER|SYSTEM_PIC|COMMUNICATION_OTHER/ +                                 || $_->{description} =~ /Parallel Port Adapter/; +			 } @devices) }, +      checked_on_boot => 0, +     }, + + +     { +      class => "FLOPPY", +      string => N("Floppy"), +      icon => "floppy.png", +      configurator => "", +      detector => \&detect_devices::floppies, +      checked_on_boot => 1, +      automatic => 1, +     }, + +     { +      class => "ZIP", +      string => N("Zip"), +      icon => "floppy.png", +      configurator => "", +      detector => sub { +	  my ($options) = @_; +	  if ($options->{PARALLEL_ZIP_DETECTION}) { +	      modules::load_parallel_zip($modules_conf) and $modules_conf->write; +	  } +	  detect_devices::zips(); +      }, +      checked_on_boot => 1, +      automatic => 1, +     }, + +     { +      class => "HARDDISK", +      string => N("Hard Disk"), +      icon => "harddisk.png", +      configurator => "$sbindir/diskdrake", +      detector => sub { f(detect_devices::hds()) }, +      checked_on_boot => 0, +      automatic => 1, +     }, + +     { +      class => "USB_STORAGE", +      string => N("USB Mass Storage Devices"), +      icon => "usb.png", +      configurator => "", +      detector => sub { f(grep { member($_->{driver}, qw(usb_storage ub Removable:memory_card)) } @devices) }, +      checked_on_boot => 0, +     }, + +     { +      class => "CDROM", +      string => N("CDROM"), +      icon => "cd.png", +      configurator => "", +      detector => sub { f(grep { !(detect_devices::isBurner($_) || detect_devices::isDvdDrive($_)) } &detect_devices::cdroms) }, +      checked_on_boot => 1, +      automatic => 1, +     }, + +     { +      class => "BURNER", +      string => N("CD/DVD burners"), +      icon => "cd.png", +      configurator => "", +      detector => sub { f(detect_devices::burners()) }, +      checked_on_boot => 1, +      automatic => 1, +     }, + +     { +      class => "DVDROM", +      string => N("DVD-ROM"), +      icon => "cd.png", +      configurator => "", +      detector => sub { f(grep { ! detect_devices::isBurner($_) } detect_devices::dvdroms()) }, +      checked_on_boot => 1, +      automatic => 1, +     }, + +     { +      class => "TAPE", +      string => N("Tape"), +      icon => "tape.png", +      configurator => "", +      detector => \&detect_devices::tapes, +      checked_on_boot => 0, +     }, + +     # AGP devices must be detected prior to video cards because some DRM drivers doesn't like be loaded +     # after agpgart thus order in /etc/modprobe.preload is important (modules.pm should enforce such sorting): +     { +      class => "AGP", +      string => N("AGP controllers"), +      icon => "memory.png", +      configurator => "", +      detector => sub { f(detect_devices::probe_category('various/agpgart')) }, +      checked_on_boot => 1, +     }, + +     { +      class => "VIDEO", +      string => N("Videocard"), +      icon => "video.png", +      configurator => "$sbindir/XFdrake", +      detector =>  sub { f(grep { $_->{driver} =~ /^(Card|Server):/ || $_->{media_type} =~ /DISPLAY_VGA/ } @devices) }, +      checked_on_boot => 1, +     }, + +     { +      class => "DVB", +      string => N("DVB card"), +      icon => "tv.png", +      detector => sub { f(detect_devices::probe_category('multimedia/dvb')) }, +      checked_on_boot => 1, +     }, + +     { +      class => "TV", +      string => N("Tvcard"), +      icon => "tv.png", +      configurator => "/usr/sbin/drakxtv", +      detector => sub { f(detect_devices::probe_category('multimedia/tv')), +                          f(grep { $_->{media_type} =~ /MULTIMEDIA_VIDEO/ && $_->{bus} eq 'PCI' } @devices) }, +      checked_on_boot => 1, +     }, +      +     { +      class => "MULTIMEDIA_OTHER", +      string => N("Other MultiMedia devices"), +      icon => "multimedia.png", +      configurator => "", +      detector => sub { f(grep { $_->{media_type} =~ /MULTIMEDIA_OTHER/ } @devices) }, +      checked_on_boot => 0, +     }, + +     { +      class => "AUDIO", +      string => N("Soundcard"), +      icon => "sound.png", +      configurator => "$sbindir/draksound", +      detector => sub {  +          require list_modules; +          my @modules = list_modules::category2modules('multimedia/sound'); +          f(grep { $_->{media_type} =~ /MULTIMEDIA_AUDIO|PROCESSOR_CO/ || member($_->{driver}, @modules) +                || $_->{description} =~ /^\|?HDA |PC Speaker/ } @devices); +      }, +      checked_on_boot => 1, +     }, + +     { +      class => "WEBCAM", +      string => N("Webcam"), +      icon => "webcam.png", +      configurator => "", +      detector => sub {  +          require list_modules; +          my @modules = (list_modules::category2modules('multimedia/webcam'), 'Removable:camera'); +          f(grep { $_->{media_type} =~ /MULTIMEDIA_VIDEO|Video\|Video Control|Imaging|Camera/ && $_->{bus} ne 'PCI' +                     || member($_->{driver}, @modules) || $_->{driver} =~ /^gpsca/ } @devices); +      }, +      # managed by hotplug: +      checked_on_boot => 0, +     }, + +     { +      class => "CPU", +      string => N("Processors"), +      icon => "cpu.png", +      configurator => "", +      detector => sub { detect_devices::getCPUs() }, +      # maybe should we install schedutils? +      checked_on_boot => 1, +     }, + +     { +      class => "ISDN", +      string => N("ISDN adapters"), +      icon => "modem.png", +      configurator => "$sbindir/drakconnect", +      detector => sub { require network::connection::isdn; my $isdn = network::connection::isdn::detect_backend($modules_conf); if_(@$isdn, f(@$isdn)) }, +      # we do not check these b/c this need user interaction (auth, ...): +      checked_on_boot => 0, +     }, + + +     { +      class => "USB_AUDIO", +      string => N("USB sound devices"), +      icon => "sound.png", +      configurator => "", +      detector => sub { f(detect_devices::probe_category('multimedia/usb_sound')) }, +      checked_on_boot => 0, +     }, + +     { +      class => "RADIO", +      string => N("Radio cards"), +      icon => "tv.png", +      configurator => "", +      detector => sub { f(detect_devices::probe_category('multimedia/radio')) }, +      checked_on_boot => 0, +     }, + +     { +      class => "ATM", +      string => N("ATM network cards"), +      icon => "hw_network.png", +      configurator => "", +      detector => sub { f(detect_devices::probe_category('network/atm')) }, +      checked_on_boot => 0, +     }, + +     { +      class => "WAN", +      string => N("WAN network cards"), +      icon => "hw_network.png", +      configurator => "", +      detector => sub { f(detect_devices::probe_category('network/wan')) }, +      checked_on_boot => 0, +     }, + +     { +      class => "BLUETOOTH", +      string => N("Bluetooth devices"), +      icon => "hw_network.png", +      configurator => "", +      detector => sub { f(detect_devices::probe_category('bus/bluetooth')), f(grep { $_->{description} =~ /Bluetooth Dongle/ } @devices) }, +      checked_on_boot => 1, +     }, + +     { +      class => "ETHERNET", +      string => N("Ethernetcard"), +      icon => "hw_network.png", +      configurator => "$sbindir/drakconnect", +      detector => sub { +          require list_modules; +          my @net_modules = list_modules::category2modules(list_modules::ethernet_categories()); +          f(grep { +              $_->{media_type} && $_->{media_type} =~ /^NETWORK/ +                || $_->{type} && $_->{type} eq 'network' +                  || member($_->{driver}, @net_modules) +                    || $_->{description} =~ /WLAN/; +          } @devices); +      }, +      checked_on_boot => 1, +     }, + +     { +      class => "MODEM", +      string => N("Modem"), +      icon => "modem.png", +      configurator => "$sbindir/drakconnect", +      detector => sub { f(detect_devices::getModem($modules_conf)), f(grep { $_->{description} =~ /SoftModem/ } @devices) }, +      # we do not check these b/c this need user interaction (auth, ...): +      checked_on_boot => 0, +     }, + +     { +      class => "ADSL", +      string => N("ADSL adapters"), +      icon => "modem.png", +      configurator => "$sbindir/drakconnect", +      detector => sub { f(detect_devices::get_xdsl_usb_devices()), +			  f(grep { $_->{description} =~ /Cohiba 3887 rev0/ } @devices); +		      }, +      # we do not check these b/c this need user interaction (auth, ...): +      checked_on_boot => 0, +     }, + +     { +      class => "MEMORY", +      string => N("Memory"), +      icon => "hw-memory.png", +      configurator => "", +      detector => sub { grep { member($_->{name}, 'Cache', 'Memory Module') || $_->{name} eq 'Memory Device' && $_->{Size} ne 'No Module Installed'  } detect_devices::dmidecode() }, +      checked_on_boot => 0, +     }, + +     { +      class => "PRINTER", +      string => N("Printer"), +      icon => "hw_printer.png", +      configurator => "$sbindir/printerdrake", +      detector => sub {}, +      # we do not check these b/c this need user interaction (auth, ...): +      checked_on_boot => 0, +     }, + + + +     { +      class => "GAMEPORT", +      string =>  +      #-PO: these are joysticks controllers: +      N("Game port controllers"), +      icon => "joystick.png", +      configurator => "", +      detector => sub { f(detect_devices::probe_category('multimedia/gameport')) }, +      checked_on_boot => 0, +     }, + +     { +      class => "JOYSTICK", +      string => N("Joystick"), +      icon => "joystick.png", +      configurator => "", +      detector => sub { f(detect_devices::probe_category('input/joystick')), f(grep { $_->{description} =~ /Joystick/i } @devices) }, +      checked_on_boot => 0, +     }, + + +     { +      class => "KEYBOARD", +      string => N("Keyboard"), +      icon => "hw-keyboard.png", +      configurator => "$sbindir/keyboarddrake", +      detector => sub { +          f(grep { $_->{description} =~ /Keyboard/i || $_->{media_type} =~ /Keyboard/i || +                     # USB devices are filtered out since we already catch them through probeall(): +                     $_->{bus} ne 'usb' && $_->{driver} =~ /^event|kbd|^usbhid/ && $_->{description} !~ /PC Speaker/; +                 } @devices); +      }, +      checked_on_boot => 0, +     }, + +     { +      class => "MISC_INPUT", +      string => N("Tablet and touchscreen"), +      icon => "hw_mouse.png", +      detector => sub { f(detect_devices::probe_category('input/tablet'), detect_devices::probe_category('input/touchscreen')) }, +      configurator => "$sbindir/mousedrake", +      checked_on_boot => 0, +     }, + +     { +      class => "MOUSE", +      string => N("Mouse"), +      icon => "hw_mouse.png", +      configurator => "$sbindir/mousedrake", +      detector => sub { +          f(grep { $_->{driver} =~ /^Mouse:|^Tablet:|^mouse/ || $_->{media_type} =~ /class\|Mouse/ || +                     # USB devices are filtered out since we already catch them through probeall(): +                     $_->{bus} ne 'usb' && $_->{Handlers}{mouse}; +                 } @devices); +      }, +      checked_on_boot => 1, +      automatic => 1, +     }, +      +     { +      class => "BIOMETRIC", +      string => N("Biometry"), +      icon => "ups.png", +      detector => sub { f(grep { $_->{description} =~ /fingerprint|biometric/i } @devices) }, +      checked_on_boot => 0, +     }, + +     { +      class => "UPS", +      string => N("UPS"), +      icon => "ups.png", +      configurator => "$sbindir/drakups", +      detector => sub { f(detect_devices::getUPS()) }, +      checked_on_boot => 0, +     }, +      +     { +      class => "SCANNER", +      string => N("Scanner"), +      icon => "scanner.png", +      configurator => "$sbindir/scannerdrake", +      detector => sub {  +         require scanner; f(map { $_->{val}{drakx_device} } f(scanner::detect())); +      }, +      checked_on_boot => 0, +     }, +      +     { +      class => "UNKNOWN", +      string => N("Unknown/Others"), +      icon => "unknown.png", +      configurator => "", +      detector => sub { f(unknown()) }, +      checked_on_boot => 0, +     }, + +    );  sub pciusb_id {      my ($dev) = @_; -    join(':', map { $dev->{$_} } qw(bus pci_bus pci_device vendor id subvendor subid description)); +    my %alt = ( +               bus => 'usb_bus', +               description => 'usb_description', +               id => 'usb_id', +               pci_bus => 'usb_pci_bus', +               pci_device => 'usb_pci_device', +               vendor => 'usb_vendor', +               ); +    my @fields = ('bus', if_($dev->{bus} =~ /pci/, qw(pci_bus pci_device)), qw(vendor id subvendor subid), +                  if_($dev->{bus} !~ /usb/i, 'description')); +    join(':', map { uc($dev->{$alt{$_}} || $dev->{$_}) } @fields);  } @@ -112,7 +570,9 @@ sub custom_id {      defined($device->{device}) ? $device->{device} :          (defined($device->{processor}) ?            N("cpu # ") . $device->{processor} . ": " . $device->{'model name'} : -         (defined($device->{description}) ? $device->{description} : $str)); +         $device->{"Socket Designation"} ? +         "$device->{name} (" . $device->{"Socket Designation"} . ")" : +         $device->{name} || $device->{description} || $device->{Vendor} || $str);  }  1; | 
