hwdb: switch meson to use ids_parser.py (#6964)
Also drop the now-unused perl implementation (that doesn't do sorting), so it's incompatible anyway.
This commit is contained in:
parent
5991ce44dc
commit
57056020c5
|
@ -1,375 +0,0 @@
|
|||
#!/usr/bin/perl
|
||||
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
sub usb_vendor {
|
||||
my $vendor;
|
||||
|
||||
open(IN, "<", "usb.ids");
|
||||
open(OUT, ">", "20-usb-vendor-model.hwdb");
|
||||
print(OUT "# This file is part of systemd.\n" .
|
||||
"#\n" .
|
||||
"# Data imported from: http://www.linux-usb.org/usb.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 "usb:v" . $vendor . "*\n");
|
||||
print(OUT " ID_VENDOR_FROM_DATABASE=" . $text . "\n");
|
||||
next;
|
||||
}
|
||||
|
||||
$line =~ m/^\t([0-9a-f]{4})\s*(.+)$/;
|
||||
if (defined $1) {
|
||||
my $model = uc $1;
|
||||
my $text = $2;
|
||||
print(OUT "\n");
|
||||
print(OUT "usb:v" . $vendor . "p" . $model . "*\n");
|
||||
print(OUT " ID_MODEL_FROM_DATABASE=" . $text . "\n");
|
||||
}
|
||||
}
|
||||
|
||||
close(IN);
|
||||
close(OUT);
|
||||
}
|
||||
|
||||
sub usb_classes {
|
||||
my $class;
|
||||
my $subclass;
|
||||
my $protocol;
|
||||
|
||||
open(IN, "<", "usb.ids");
|
||||
open(OUT, ">", "20-usb-classes.hwdb");
|
||||
print(OUT "# This file is part of systemd.\n" .
|
||||
"#\n" .
|
||||
"# Data imported from: http://www.linux-usb.org/usb.ids\n");
|
||||
|
||||
while (my $line = <IN>) {
|
||||
$line =~ s/\s+$//;
|
||||
|
||||
$line =~ m/^C\ ([0-9a-f]{2})\s*(.+)$/;
|
||||
if (defined $1) {
|
||||
$class = uc $1;
|
||||
if ($class =~ m/^00$/) {
|
||||
next;
|
||||
}
|
||||
my $text = $2;
|
||||
print(OUT "\n");
|
||||
print(OUT "usb:v*p*d*dc" . $class . "*\n");
|
||||
print(OUT " ID_USB_CLASS_FROM_DATABASE=" . $text . "\n");
|
||||
next;
|
||||
}
|
||||
|
||||
if (not defined $class) {
|
||||
next;
|
||||
} elsif ($line =~ m/^$/) {
|
||||
last;
|
||||
}
|
||||
|
||||
$line =~ m/^\t([0-9a-f]{2})\s*(.+)$/;
|
||||
if (defined $1) {
|
||||
$subclass = uc $1;
|
||||
if ($subclass =~ m/^00$/) {
|
||||
next;
|
||||
}
|
||||
my $text = $2;
|
||||
if ($text =~ m/^(\?|None|Unused)$/) {
|
||||
next;
|
||||
}
|
||||
print(OUT "\n");
|
||||
print(OUT "usb:v*p*d*dc" . $class . "dsc" . $subclass . "*\n");
|
||||
print(OUT " ID_USB_SUBCLASS_FROM_DATABASE=" . $text . "\n");
|
||||
next;
|
||||
}
|
||||
|
||||
$line =~ m/^\t\t([0-9a-f]{2})\s*(.+)$/;
|
||||
if (defined $1) {
|
||||
$protocol = uc $1;
|
||||
my $text = $2;
|
||||
if ($text =~ m/^(\?|None|Unused)$/) {
|
||||
next;
|
||||
}
|
||||
print(OUT "\n");
|
||||
print(OUT "usb:v*p*d*dc" . $class . "dsc" . $subclass . "dp" . $protocol . "*\n");
|
||||
print(OUT " ID_USB_PROTOCOL_FROM_DATABASE=" . $text . "\n");
|
||||
}
|
||||
}
|
||||
|
||||
close(IN);
|
||||
close(OUT);
|
||||
}
|
||||
|
||||
sub pci_vendor {
|
||||
my $vendor;
|
||||
my $device;
|
||||
my $device_text;
|
||||
|
||||
open(IN, "<", "pci.ids");
|
||||
open(OUT, ">", "20-pci-vendor-model.hwdb");
|
||||
print(OUT "# This file is part of systemd.\n" .
|
||||
"#\n" .
|
||||
"# Data imported from: http://pci-ids.ucw.cz/v2.2/pci.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 "pci:v0000" . $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;
|
||||
$device_text = $2;
|
||||
print(OUT "\n");
|
||||
print(OUT "pci:v0000" . $vendor . "d0000" . $device . "*\n");
|
||||
print(OUT " ID_MODEL_FROM_DATABASE=" . $device_text . "\n");
|
||||
next;
|
||||
}
|
||||
|
||||
$line =~ m/^\t\t([0-9a-f]{4})\s*([0-9a-f]{4})\s*(.*)$/;
|
||||
if (defined $1) {
|
||||
my $sub_vendor = uc $1;
|
||||
my $sub_device = uc $2;
|
||||
my $sub_text = $3;
|
||||
$sub_text =~ s/^\Q$device_text\E\s*//;
|
||||
$sub_text =~ s/(.+)/\ ($1)/;
|
||||
print(OUT "\n");
|
||||
print(OUT "pci:v0000" . $vendor . "d0000" . $device . "sv0000" . $sub_vendor . "sd0000" . $sub_device . "*\n");
|
||||
print(OUT " ID_MODEL_FROM_DATABASE=" . $device_text . $sub_text . "\n");
|
||||
}
|
||||
}
|
||||
|
||||
close(IN);
|
||||
close(OUT);
|
||||
}
|
||||
|
||||
sub pci_classes {
|
||||
my $class;
|
||||
my $subclass;
|
||||
my $interface;
|
||||
|
||||
open(IN, "<", "pci.ids");
|
||||
open(OUT, ">", "20-pci-classes.hwdb");
|
||||
print(OUT "# This file is part of systemd.\n" .
|
||||
"#\n" .
|
||||
"# Data imported from: http://pci-ids.ucw.cz/v2.2/pci.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 "pci:v*d*sv*sd*bc" . $class . "*\n");
|
||||
print(OUT " ID_PCI_CLASS_FROM_DATABASE=" . $text . "\n");
|
||||
next;
|
||||
}
|
||||
|
||||
if (not defined $class) {
|
||||
next;
|
||||
} elsif ($line =~ m/^$/) {
|
||||
last;
|
||||
}
|
||||
|
||||
$line =~ m/^\t([0-9a-f]{2})\s*(.+)$/;
|
||||
if (defined $1) {
|
||||
$subclass = uc $1;
|
||||
my $text = $2;
|
||||
print(OUT "\n");
|
||||
print(OUT "pci:v*d*sv*sd*bc" . $class . "sc" . $subclass . "*\n");
|
||||
print(OUT " ID_PCI_SUBCLASS_FROM_DATABASE=" . $text . "\n");
|
||||
next;
|
||||
}
|
||||
|
||||
$line =~ m/^\t\t([0-9a-f]{2})\s*(.+)$/;
|
||||
if (defined $1) {
|
||||
$interface = uc $1;
|
||||
my $text = $2;
|
||||
print(OUT "\n");
|
||||
print(OUT "pci:v*d*sv*sd*bc" . $class . "sc" . $subclass . "i" . $interface . "*\n");
|
||||
print(OUT " ID_PCI_INTERFACE_FROM_DATABASE=" . $text . "\n");
|
||||
}
|
||||
}
|
||||
|
||||
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 = <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);
|
||||
}
|
||||
|
||||
# MAC Address Block Large/Medium/Small
|
||||
# Large MA-L 24/24 bit (OUI)
|
||||
# Medium MA-M 28/20 bit (OUI prefix owned by IEEE)
|
||||
# Small MA-S 36/12 bit (OUI prefix owned by IEEE)
|
||||
sub oui {
|
||||
my $prefix;
|
||||
my %ieee_prefixes = ();
|
||||
|
||||
open(OUT, ">", "20-OUI.hwdb");
|
||||
print(OUT "# This file is part of systemd.\n" .
|
||||
"#\n" .
|
||||
"# Data imported from:\n" .
|
||||
"# https://services13.ieee.org/RST/standards-ra-web/rest/assignments/download/?registry=MA-L&format=txt\n" .
|
||||
"# https://services13.ieee.org/RST/standards-ra-web/rest/assignments/download/?registry=MA-M&format=txt\n" .
|
||||
"# https://services13.ieee.org/RST/standards-ra-web/rest/assignments/download/?registry=MA-S&format=txt\n");
|
||||
|
||||
open(IN, "<", "ma-small.txt");
|
||||
while (my $line = <IN>) {
|
||||
$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) {
|
||||
$prefix = $1 . $2 . $3;
|
||||
$ieee_prefixes{ $prefix } = 1;
|
||||
next;
|
||||
}
|
||||
|
||||
$line =~ m/^([0-9A-F]{3})000-\g1FFF\s*\(base 16\)\s*(.+)$/;
|
||||
if (defined $1) {
|
||||
my $vendor = uc $1;
|
||||
my $text = $2;
|
||||
|
||||
print(OUT "\n");
|
||||
print(OUT "OUI:" . $prefix . $vendor . "*\n");
|
||||
print(OUT " ID_OUI_FROM_DATABASE=" . $text . "\n");
|
||||
}
|
||||
}
|
||||
close(IN);
|
||||
|
||||
open(IN, "<", "ma-medium.txt");
|
||||
while (my $line = <IN>) {
|
||||
$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) {
|
||||
$prefix = $1 . $2 . $3;
|
||||
$ieee_prefixes{ $prefix } = 1;
|
||||
next;
|
||||
}
|
||||
|
||||
$line =~ m/^([0-9A-F])00000-\g1FFFFF\s*\(base 16\)\s*(.+)$/;
|
||||
if (defined $1) {
|
||||
my $vendor = uc $1;
|
||||
my $text = $2;
|
||||
|
||||
print(OUT "\n");
|
||||
print(OUT "OUI:" . $prefix . $vendor . "*\n");
|
||||
print(OUT " ID_OUI_FROM_DATABASE=" . $text . "\n");
|
||||
}
|
||||
}
|
||||
|
||||
open(IN, "<", "ma-large.txt");
|
||||
while (my $line = <IN>) {
|
||||
$line =~ s/^ +//;
|
||||
$line =~ s/\s+$//;
|
||||
$line =~ m/^([0-9A-F]{6})\s*\(base 16\)\s*(.+)$/;
|
||||
if (defined $1) {
|
||||
my $vendor = uc $1;
|
||||
my $text = $2;
|
||||
|
||||
if ($text =~ m/^IEEE REGISTRATION AUTHORITY/) {
|
||||
next;
|
||||
}
|
||||
|
||||
# skip the IEEE owned prefixes
|
||||
if (! exists $ieee_prefixes{ $vendor }) {
|
||||
print(OUT "\n");
|
||||
print(OUT "OUI:" . $vendor . "*\n");
|
||||
print(OUT " ID_OUI_FROM_DATABASE=" . $text . "\n");
|
||||
}
|
||||
}
|
||||
}
|
||||
close(IN);
|
||||
|
||||
close(OUT);
|
||||
}
|
||||
|
||||
usb_vendor();
|
||||
usb_classes();
|
||||
|
||||
pci_vendor();
|
||||
pci_classes();
|
||||
|
||||
sdio_vendor();
|
||||
sdio_classes();
|
||||
|
||||
oui();
|
|
@ -11,7 +11,7 @@ if [ "$2" != "-n" ]; then
|
|||
curl -L -o pnp_id_registry.html 'http://www.uefi.org/uefi-pnp-export'
|
||||
curl -L -o acpi_id_registry.html 'http://www.uefi.org/uefi-acpi-export'
|
||||
fi
|
||||
./ids-update.pl
|
||||
./ids_parser.py
|
||||
./acpi-update.py >20-acpi-vendor.hwdb.base
|
||||
patch -p0 -o- 20-acpi-vendor.hwdb.base <20-acpi-vendor.hwdb.patch >20-acpi-vendor.hwdb
|
||||
! diff -u 20-acpi-vendor.hwdb.base 20-acpi-vendor.hwdb >20-acpi-vendor.hwdb.patch
|
||||
|
|
Loading…
Reference in a new issue