summaryrefslogtreecommitdiff
path: root/hwdb
diff options
context:
space:
mode:
authorMarcel Holtmann <marcel@holtmann.org>2013-12-22 11:30:57 -0800
committerMarcel Holtmann <marcel@holtmann.org>2013-12-22 11:30:57 -0800
commit56243d0936f85b2580f4c1028e1af98b96d77b72 (patch)
treecc2c8e6f573462c6b83396608f09073ec38fc7e5 /hwdb
parent23ee5a0050e5d57681ae7e8632babe9ad45ac0c0 (diff)
hwdb: Add SDIO database to ids-update.pl script
Diffstat (limited to 'hwdb')
-rwxr-xr-xhwdb/ids-update.pl70
1 files changed, 70 insertions, 0 deletions
diff --git a/hwdb/ids-update.pl b/hwdb/ids-update.pl
index 37d355638..b72c41571 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();