X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=hwdb%2Fids-update.pl;h=b72c415711f7a10011af7814727a8bd8ef9456bc;hp=869c49b861a8d377361021239004f93762397987;hb=85feb8e4d9b0ef65c338e1a1a16665d0cb8d544a;hpb=5fe25affc01fb003a3a66937458a25640a6075ce diff --git a/hwdb/ids-update.pl b/hwdb/ids-update.pl index 869c49b86..b72c41571 100755 --- a/hwdb/ids-update.pl +++ b/hwdb/ids-update.pl @@ -7,10 +7,10 @@ sub usb_vendor { my $vendor; open(IN, "<", "usb.ids"); - open(OUT, ">", "20-usb-vendor-product.hwdb"); + open(OUT, ">", "20-usb-vendor-model.hwdb"); print(OUT "# This file is part of systemd.\n" . "#\n" . - "# Data imported and updated from: http://www.linux-usb.org/usb.ids\n"); + "# Data imported from: http://www.linux-usb.org/usb.ids\n"); while (my $line = ) { $line =~ s/\s+$//; @@ -26,16 +26,16 @@ sub usb_vendor { $line =~ m/^\t([0-9a-f]{4})\s*(.+)$/; if (defined $1) { - my $product = uc $1; + my $model = uc $1; my $text = $2; print(OUT "\n"); - print(OUT "usb:v" . $vendor . "p" . $product . "*\n"); - print(OUT " ID_PRODUCT_FROM_DATABASE=" . $text . "\n"); + print(OUT "usb:v" . $vendor . "p" . $model . "*\n"); + print(OUT " ID_MODEL_FROM_DATABASE=" . $text . "\n"); } } - close(INP); - close(OUTP); + close(IN); + close(OUT); } sub usb_classes { @@ -47,7 +47,7 @@ sub usb_classes { open(OUT, ">", "20-usb-classes.hwdb"); print(OUT "# This file is part of systemd.\n" . "#\n" . - "# Data imported and updated from: http://www.linux-usb.org/usb.ids\n"); + "# Data imported from: http://www.linux-usb.org/usb.ids\n"); while (my $line = ) { $line =~ s/\s+$//; @@ -100,20 +100,19 @@ sub usb_classes { } } - close(INP); - close(OUTP); + close(IN); + close(OUT); } sub pci_vendor { my $vendor; my $device; - open(IN, "<", "usb.ids"); open(IN, "<", "pci.ids"); - open(OUT, ">", "20-pci-vendor-product.hwdb"); + open(OUT, ">", "20-pci-vendor-model.hwdb"); print(OUT "# This file is part of systemd.\n" . "#\n" . - "# Data imported and updated from: http://pci-ids.ucw.cz/v2.2/pci.ids\n"); + "# Data imported from: http://pci-ids.ucw.cz/v2.2/pci.ids\n"); while (my $line = ) { $line =~ s/\s+$//; @@ -134,7 +133,7 @@ sub pci_vendor { my $text = $2; print(OUT "\n"); print(OUT "pci:v0000" . $vendor . "d0000" . $device . "*\n"); - print(OUT " ID_PRODUCT_FROM_DATABASE=" . $text . "\n"); + print(OUT " ID_MODEL_FROM_DATABASE=" . $text . "\n"); next; } @@ -145,12 +144,12 @@ sub pci_vendor { my $text = $3; print(OUT "\n"); print(OUT "pci:v0000" . $vendor . "d0000" . $device . "sv0000" . $sub_vendor . "sd0000" . $sub_device . "*\n"); - print(OUT " ID_PRODUCT_FROM_DATABASE=" . $text . "\n"); + print(OUT " ID_MODEL_FROM_DATABASE=" . $text . "\n"); } } - close(INP); - close(OUTP); + close(IN); + close(OUT); } sub pci_classes { @@ -162,7 +161,7 @@ sub pci_classes { open(OUT, ">", "20-pci-classes.hwdb"); print(OUT "# This file is part of systemd.\n" . "#\n" . - "# Data imported and updated from: http://pci-ids.ucw.cz/v2.2/pci.ids\n"); + "# Data imported from: http://pci-ids.ucw.cz/v2.2/pci.ids\n"); while (my $line = ) { $line =~ s/\s+$//; @@ -203,8 +202,75 @@ sub pci_classes { } } - close(INP); - close(OUTP); + close(IN); + close(OUT); +} + +sub sdio_vendor { + my $vendor; + my $device; + + open(IN, "<", "sdio.ids"); + open(OUT, ">", "20-sdio-vendor-model.hwdb"); + print(OUT "# This file is part of systemd.\n" . + "#\n" . + "# Data imported from: hwdb/sdio.ids\n"); + + while (my $line = ) { + $line =~ s/\s+$//; + $line =~ m/^([0-9a-f]{4})\s*(.+)$/; + + if (defined $1) { + $vendor = uc $1; + my $text = $2; + print(OUT "\n"); + print(OUT "sdio:c*v" . $vendor . "*\n"); + print(OUT " ID_VENDOR_FROM_DATABASE=" . $text . "\n"); + next; + } + + $line =~ m/^\t([0-9a-f]{4})\s*(.+)$/; + if (defined $1) { + $device = uc $1; + my $text = $2; + print(OUT "\n"); + print(OUT "sdio:c*v" . $vendor . "d" . $device . "*\n"); + print(OUT " ID_MODEL_FROM_DATABASE=" . $text . "\n"); + next; + } + } + + close(IN); + close(OUT); +} + +sub sdio_classes { + my $class; + my $subclass; + my $interface; + + open(IN, "<", "sdio.ids"); + open(OUT, ">", "20-sdio-classes.hwdb"); + print(OUT "# This file is part of systemd.\n" . + "#\n" . + "# Data imported from: hwdb/sdio.ids\n"); + + while (my $line = ) { + $line =~ s/\s+$//; + + $line =~ m/^C\ ([0-9a-f]{2})\s*(.+)$/; + if (defined $1) { + $class = uc $1; + my $text = $2; + print(OUT "\n"); + print(OUT "sdio:c" . $class . "v*d*\n"); + print(OUT " ID_SDIO_CLASS_FROM_DATABASE=" . $text . "\n"); + next; + } + } + + close(IN); + close(OUT); } sub oui { @@ -214,11 +280,13 @@ sub oui { open(OUT, ">", "20-OUI.hwdb"); print(OUT "# This file is part of systemd.\n" . "#\n" . - "# Data imported and updated from: http://standards.ieee.org/develop/regauth/iab/iab.txt\n" . - "# Data imported and updated from: http://standards.ieee.org/develop/regauth/oui/oui.txt\n"); + "# Data imported from:\n" . + "# http://standards.ieee.org/develop/regauth/oui/oui.txt\n" . + "# http://standards.ieee.org/develop/regauth/iab/iab.txt\n"); open(IN, "<", "iab.txt"); while (my $line = ) { + $line =~ s/^ +//; $line =~ s/\s+$//; $line =~ m/^([0-9A-F]{2})-([0-9A-F]{2})-([0-9A-F]{2})\s*\(hex\)\s*.+$/; if (defined $1) { @@ -237,10 +305,11 @@ sub oui { print(OUT " ID_OUI_FROM_DATABASE=" . $text . "\n"); } } - close(INP); + close(IN); open(IN, "<", "oui.txt"); while (my $line = ) { + $line =~ s/^ +//; $line =~ s/\s+$//; $line =~ m/^([0-9A-F]{6})\s*\(base 16\)\s*(.+)$/; if (defined $1) { @@ -255,8 +324,8 @@ sub oui { } } } - close(INP); - close(OUTP); + close(IN); + close(OUT); } usb_vendor(); @@ -265,4 +334,7 @@ usb_classes(); pci_vendor(); pci_classes(); +sdio_vendor(); +sdio_classes(); + oui();