diff options
author | Marcel Holtmann <marcel@holtmann.org> | 2013-12-22 11:30:57 -0800 |
---|---|---|
committer | Marcel Holtmann <marcel@holtmann.org> | 2013-12-22 11:30:57 -0800 |
commit | 56243d0936f85b2580f4c1028e1af98b96d77b72 (patch) | |
tree | cc2c8e6f573462c6b83396608f09073ec38fc7e5 /hwdb/ids-update.pl | |
parent | 23ee5a0050e5d57681ae7e8632babe9ad45ac0c0 (diff) |
hwdb: Add SDIO database to ids-update.pl script
Diffstat (limited to 'hwdb/ids-update.pl')
-rwxr-xr-x | hwdb/ids-update.pl | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/hwdb/ids-update.pl b/hwdb/ids-update.pl index 37d3556382..b72c415711 100755 --- a/hwdb/ids-update.pl +++ b/hwdb/ids-update.pl @@ -206,6 +206,73 @@ sub pci_classes { 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 = <IN>) { + $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 = <IN>) { + $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 { my $iab_prefix; my %iab_prefixes = (); @@ -267,4 +334,7 @@ usb_classes(); pci_vendor(); pci_classes(); +sdio_vendor(); +sdio_classes(); + oui(); |