summaryrefslogtreecommitdiff
path: root/hwdb/ids-update.pl
diff options
context:
space:
mode:
authorKay Sievers <kay@vrfy.org>2015-08-26 18:37:16 +0200
committerKay Sievers <kay@vrfy.org>2015-08-26 18:38:30 +0200
commitfd5a461316d34d3070d599f4be74bd8ae4b3d00f (patch)
tree85101ebcff9e28b084630d86f07d4e162ad81ea4 /hwdb/ids-update.pl
parent1aa28c952191dbd24212df6cead54349bc185618 (diff)
hwdb: update
Diffstat (limited to 'hwdb/ids-update.pl')
-rwxr-xr-xhwdb/ids-update.pl54
1 files changed, 43 insertions, 11 deletions
diff --git a/hwdb/ids-update.pl b/hwdb/ids-update.pl
index 86d414a6ff..03dd00b38d 100755
--- a/hwdb/ids-update.pl
+++ b/hwdb/ids-update.pl
@@ -276,25 +276,30 @@ sub sdio_classes {
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 $iab_prefix;
- my %iab_prefixes = ();
+ my $prefix;
+ my %ieee_prefixes = ();
open(OUT, ">", "20-OUI.hwdb");
print(OUT "# This file is part of systemd.\n" .
"#\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");
+ "# 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, "<", "iab.txt");
+ 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) {
- $iab_prefix = $1 . $2 . $3;
- $iab_prefixes{ $iab_prefix } = 1;
+ $prefix = $1 . $2 . $3;
+ $ieee_prefixes{ $prefix } = 1;
next;
}
@@ -304,13 +309,35 @@ sub oui {
my $text = $2;
print(OUT "\n");
- print(OUT "OUI:" . $iab_prefix . $vendor . "*\n");
+ print(OUT "OUI:" . $prefix . $vendor . "*\n");
print(OUT " ID_OUI_FROM_DATABASE=" . $text . "\n");
}
}
close(IN);
- open(IN, "<", "oui.txt");
+ 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+$//;
@@ -319,8 +346,12 @@ sub oui {
my $vendor = uc $1;
my $text = $2;
- # skip the IAB prefixes
- if (! exists $iab_prefixes{ $vendor }) {
+ 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");
@@ -328,6 +359,7 @@ sub oui {
}
}
close(IN);
+
close(OUT);
}