forked from pool/udev-persistent-ifnames
Accepting request 308347 from home:jengelh:branches:Base:System
it's not really SLE-only, so I opted to name it udev-persistent-ifnames instead of udev-branding-SLE OBS-URL: https://build.opensuse.org/request/show/308347 OBS-URL: https://build.opensuse.org/package/show/Base:System/udev-persistent-ifnames?expand=0&rev=1
This commit is contained in:
commit
d585771c9a
23
.gitattributes
vendored
Normal file
23
.gitattributes
vendored
Normal file
@ -0,0 +1,23 @@
|
||||
## Default LFS
|
||||
*.7z filter=lfs diff=lfs merge=lfs -text
|
||||
*.bsp filter=lfs diff=lfs merge=lfs -text
|
||||
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
||||
*.gem filter=lfs diff=lfs merge=lfs -text
|
||||
*.gz filter=lfs diff=lfs merge=lfs -text
|
||||
*.jar filter=lfs diff=lfs merge=lfs -text
|
||||
*.lz filter=lfs diff=lfs merge=lfs -text
|
||||
*.lzma filter=lfs diff=lfs merge=lfs -text
|
||||
*.obscpio filter=lfs diff=lfs merge=lfs -text
|
||||
*.oxt filter=lfs diff=lfs merge=lfs -text
|
||||
*.pdf filter=lfs diff=lfs merge=lfs -text
|
||||
*.png filter=lfs diff=lfs merge=lfs -text
|
||||
*.rpm filter=lfs diff=lfs merge=lfs -text
|
||||
*.tbz filter=lfs diff=lfs merge=lfs -text
|
||||
*.tbz2 filter=lfs diff=lfs merge=lfs -text
|
||||
*.tgz filter=lfs diff=lfs merge=lfs -text
|
||||
*.ttf filter=lfs diff=lfs merge=lfs -text
|
||||
*.txz filter=lfs diff=lfs merge=lfs -text
|
||||
*.whl filter=lfs diff=lfs merge=lfs -text
|
||||
*.xz filter=lfs diff=lfs merge=lfs -text
|
||||
*.zip filter=lfs diff=lfs merge=lfs -text
|
||||
*.zst filter=lfs diff=lfs merge=lfs -text
|
1
.gitignore
vendored
Normal file
1
.gitignore
vendored
Normal file
@ -0,0 +1 @@
|
||||
.osc
|
107
75-persistent-net-generator.rules
Normal file
107
75-persistent-net-generator.rules
Normal file
@ -0,0 +1,107 @@
|
||||
# do not edit this file, it will be overwritten on update
|
||||
|
||||
# these rules generate rules for persistent network device naming
|
||||
#
|
||||
# variables used to communicate:
|
||||
# MATCHADDR MAC address used for the match
|
||||
# MATCHID bus_id used for the match
|
||||
# MATCHDRV driver name used for the match
|
||||
# MATCHIFTYPE interface type match
|
||||
# COMMENT comment to add to the generated rule
|
||||
# INTERFACE_NAME requested name supplied by external tool
|
||||
# INTERFACE_NEW new interface name returned by rule writer
|
||||
|
||||
ACTION!="add", GOTO="persistent_net_generator_end"
|
||||
SUBSYSTEM!="net", GOTO="persistent_net_generator_end"
|
||||
|
||||
# ignore the interface if a name has already been set
|
||||
NAME=="?*", GOTO="persistent_net_generator_end"
|
||||
|
||||
# device name whitelist
|
||||
KERNEL!="eth*|ath*|wlan*[0-9]|msh*|ra*|sta*|ctc*|lcs*|hsi*", GOTO="persistent_net_generator_end"
|
||||
|
||||
IMPORT{cmdline}="net.ifnames"
|
||||
ENV{net.ifnames}=="1", GOTO="persistent_net_generator_end"
|
||||
|
||||
# ignore Xen virtual interfaces
|
||||
SUBSYSTEMS=="xen", GOTO="persistent_net_generator_end"
|
||||
|
||||
# read MAC address
|
||||
ENV{MATCHADDR}="$attr{address}"
|
||||
|
||||
# match interface type
|
||||
ENV{MATCHIFTYPE}="$attr{type}"
|
||||
|
||||
# ignore KVM virtual interfaces
|
||||
ENV{MATCHADDR}=="52:54:00:*", GOTO="persistent_net_generator_end"
|
||||
# ignore VMWare virtual interfaces
|
||||
ENV{MATCHADDR}=="00:0c:29:*|00:50:56:*", GOTO="persistent_net_generator_end"
|
||||
# ignore Hyper-V virtual interfaces
|
||||
ENV{MATCHADDR}=="00:15:5d:*", GOTO="persistent_net_generator_end"
|
||||
|
||||
# These vendors are known to violate the local MAC address assignment scheme
|
||||
# Interlan, DEC (UNIBUS or QBUS), Apollo, Cisco, Racal-Datacom
|
||||
ENV{MATCHADDR}=="02:07:01:*", GOTO="globally_administered_whitelist"
|
||||
# 3Com
|
||||
ENV{MATCHADDR}=="02:60:60:*", GOTO="globally_administered_whitelist"
|
||||
# 3Com IBM PC; Imagen; Valid; Cisco; Apple
|
||||
ENV{MATCHADDR}=="02:60:8c:*", GOTO="globally_administered_whitelist"
|
||||
# Intel
|
||||
ENV{MATCHADDR}=="02:a0:c9:*", GOTO="globally_administered_whitelist"
|
||||
# Olivetti
|
||||
ENV{MATCHADDR}=="02:aa:3c:*", GOTO="globally_administered_whitelist"
|
||||
# CMC Masscomp; Silicon Graphics; Prime EXL
|
||||
ENV{MATCHADDR}=="02:cf:1f:*", GOTO="globally_administered_whitelist"
|
||||
# Prominet Corporation Gigabit Ethernet Switch
|
||||
ENV{MATCHADDR}=="02:e0:3b:*", GOTO="globally_administered_whitelist"
|
||||
# BTI (Bus-Tech, Inc.) IBM Mainframes
|
||||
ENV{MATCHADDR}=="02:e6:d3:*", GOTO="globally_administered_whitelist"
|
||||
# Realtek
|
||||
ENV{MATCHADDR}=="52:54:00:*", GOTO="globally_administered_whitelist"
|
||||
# Novell 2000
|
||||
ENV{MATCHADDR}=="52:54:4c:*", GOTO="globally_administered_whitelist"
|
||||
# Realtec
|
||||
ENV{MATCHADDR}=="52:54:ab:*", GOTO="globally_administered_whitelist"
|
||||
# Kingston Technologies
|
||||
ENV{MATCHADDR}=="e2:0c:0f:*", GOTO="globally_administered_whitelist"
|
||||
# Xensource
|
||||
ENV{MATCHADDR}=="00:16:3e:*", GOTO="globally_administered_whitelist"
|
||||
|
||||
# match interface dev_id
|
||||
# HACK: for s390x, if layer2 == 0, dont use dev_id
|
||||
ENV{LAYER2}="1", TEST=="device/layer2", ENV{LAYER2}="$attr{device/layer2}"
|
||||
ENV{LAYER2}!="0", ATTR{dev_id}=="?*", ENV{MATCHDEVID}="$attr{dev_id}"
|
||||
|
||||
# do not use "locally administered" MAC address
|
||||
ENV{MATCHADDR}=="?[2367abef]:*", ENV{MATCHADDR}=""
|
||||
|
||||
# do not use empty address
|
||||
ENV{MATCHADDR}=="00:00:00:00:00:00", ENV{MATCHADDR}=""
|
||||
|
||||
LABEL="globally_administered_whitelist"
|
||||
|
||||
# build comment line for generated rule:
|
||||
SUBSYSTEMS=="pci", ENV{COMMENT}="PCI device $attr{vendor}:$attr{device} ($driver)"
|
||||
SUBSYSTEMS=="usb", ATTRS{idVendor}=="?*", ENV{COMMENT}="USB device 0x$attr{idVendor}:0x$attr{idProduct} ($driver)"
|
||||
SUBSYSTEMS=="pcmcia", ENV{COMMENT}="PCMCIA device $attr{card_id}:$attr{manf_id} ($driver)"
|
||||
SUBSYSTEMS=="ieee1394", ENV{COMMENT}="Firewire device $attr{host_id})"
|
||||
|
||||
# ibmveth likes to use "locally administered" MAC addresses
|
||||
DRIVERS=="ibmveth", ENV{MATCHADDR}="$attr{address}", ENV{COMMENT}="ibmveth ($id)"
|
||||
|
||||
# S/390 uses id matches only, do not use MAC address match
|
||||
SUBSYSTEMS=="ccwgroup", ENV{COMMENT}="S/390 $driver device at $id", ENV{MATCHID}="$id", ENV{MATCHDRV}="$driver", ENV{MATCHADDR}=""
|
||||
|
||||
# see if we got enough data to create a rule
|
||||
ENV{MATCHADDR}=="", ENV{MATCHID}=="", ENV{INTERFACE_NAME}=="", GOTO="persistent_net_generator_end"
|
||||
|
||||
# default comment
|
||||
ENV{COMMENT}=="", ENV{COMMENT}="net device ($attr{driver})"
|
||||
|
||||
# write rule
|
||||
DRIVERS=="?*", IMPORT{program}="write_net_rules"
|
||||
|
||||
# rename interface if needed
|
||||
ENV{INTERFACE_NEW}=="?*", NAME="$env{INTERFACE_NEW}"
|
||||
|
||||
LABEL="persistent_net_generator_end"
|
19
76-net-sriov-names.rules
Normal file
19
76-net-sriov-names.rules
Normal file
@ -0,0 +1,19 @@
|
||||
# do not edit this file, it will be overwritten on update
|
||||
#
|
||||
# rename SRIOV virtual function interfaces
|
||||
|
||||
ACTION=="remove", GOTO="net-sriov-names_end"
|
||||
SUBSYSTEM!="net", GOTO="net-sriov-names_end"
|
||||
KERNEL!="eth*", GOTO="net-sriov-names_end"
|
||||
NAME=="?*", GOTO="net-sriov-names_end"
|
||||
|
||||
IMPORT{cmdline}="net.ifnames"
|
||||
ENV{net.ifnames}=="1", GOTO="net-sriov-names_end"
|
||||
|
||||
SUBSYSTEM=="net", SUBSYSTEMS=="pci", ACTION=="add", NAME=="?*", ENV{INTERFACE_NEW}="$name"
|
||||
SUBSYSTEM=="net", SUBSYSTEMS=="pci", ACTION=="add", IMPORT{program}="net-set-sriov-names"
|
||||
|
||||
# rename interface if needed
|
||||
ENV{INTERFACE_NEW}=="?*", NAME="$env{INTERFACE_NEW}"
|
||||
|
||||
LABEL="net-sriov-names_end"
|
79
net-set-sriov-names
Normal file
79
net-set-sriov-names
Normal file
@ -0,0 +1,79 @@
|
||||
#!/bin/bash -e
|
||||
#
|
||||
# This script is run to rename virtual interfaces
|
||||
#
|
||||
|
||||
if [ -n "$UDEV_LOG" ]; then
|
||||
if [ "$UDEV_LOG" -ge 7 ]; then
|
||||
set -x
|
||||
fi
|
||||
fi
|
||||
|
||||
# according to dev_new_index(), ifindex is within [1, INT_MAX]
|
||||
int_max=$(/usr/bin/getconf INT_MAX)
|
||||
ifindex_before() {
|
||||
a=$1
|
||||
b=$2
|
||||
|
||||
((0 < (b - a) && (b - a) < int_max / 2 ||
|
||||
-1 * int_max < (b - a) && (b - a) < -1 * int_max / 2))
|
||||
}
|
||||
|
||||
rename_interface() {
|
||||
local src_net=$1
|
||||
local dest_net=$2
|
||||
local err=0
|
||||
|
||||
/sbin/ip link set dev $src_net down
|
||||
/sbin/ip link set dev $src_net name $dest_net
|
||||
}
|
||||
|
||||
if [ -z "$INTERFACE" ]; then
|
||||
echo "missing \$INTERFACE" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if [ -e "/sys/class/net/$INTERFACE/device/physfn" ]; then
|
||||
pf=$(ls -1 "/sys/class/net/$INTERFACE/device/physfn/net")
|
||||
if [ $(echo "$pf" | wc -l) -ne 1 ]; then
|
||||
echo "too many pf's" >&2
|
||||
exit 1
|
||||
fi
|
||||
read vfindex < "/sys/class/net/$INTERFACE/ifindex"
|
||||
read pfindex < "/sys/class/net/$pf/ifindex"
|
||||
if ifindex_before $pfindex $vfindex; then
|
||||
bus_info=$(basename $(readlink "/sys/class/net/$INTERFACE/device"))
|
||||
for virtfn in "/sys/class/net/$pf/device/"virtfn*; do
|
||||
if [ "$(basename $(readlink "$virtfn"))" = "$bus_info" ]; then
|
||||
vfnum=$(basename "$virtfn")
|
||||
vfnum=${vfnum#virtfn}
|
||||
echo "INTERFACE_NEW=$pf.vf$vfnum"
|
||||
exit 0
|
||||
fi
|
||||
done
|
||||
fi
|
||||
fi
|
||||
|
||||
read pfindex < "/sys/class/net/$INTERFACE/ifindex"
|
||||
shopt -s nullglob
|
||||
for virtfn in "/sys/class/net/$INTERFACE/device/"virtfn*; do
|
||||
vf=$(ls -1 "$virtfn/net")
|
||||
if [ $(echo "$vf" | wc -l) -ne 1 ]; then
|
||||
echo "too many vf's" >&2
|
||||
exit 1
|
||||
fi
|
||||
read vfindex < "/sys/class/net/$vf/ifindex"
|
||||
if ifindex_before $vfindex $pfindex; then
|
||||
vfnum=$(basename "$virtfn")
|
||||
vfnum=${vfnum#virtfn}
|
||||
if [ "$INTERFACE_NEW" ]; then
|
||||
new_name=$INTERFACE_NEW
|
||||
else
|
||||
new_name=$INTERFACE
|
||||
fi
|
||||
new_name="$new_name.vf$vfnum"
|
||||
if [ "$vf" != "$new_name" ]; then
|
||||
rename_interface "$vf" "$new_name"
|
||||
fi
|
||||
fi
|
||||
done
|
113
rule_generator.functions
Normal file
113
rule_generator.functions
Normal file
@ -0,0 +1,113 @@
|
||||
# functions used by the udev rule generator
|
||||
|
||||
# Copyright (C) 2006 Marco d'Itri <md@Linux.IT>
|
||||
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 2 of the License, or
|
||||
# (at your option) any later version.
|
||||
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
PATH='/usr/bin:/bin:/usr/sbin:/sbin'
|
||||
|
||||
# Read a single line from file $1 in the $DEVPATH directory.
|
||||
# The function must not return an error even if the file does not exist.
|
||||
sysread() {
|
||||
local file="$1"
|
||||
[ -e "/sys$DEVPATH/$file" ] || return 0
|
||||
local value
|
||||
read value < "/sys$DEVPATH/$file" || return 0
|
||||
echo "$value"
|
||||
}
|
||||
|
||||
sysreadlink() {
|
||||
local file="$1"
|
||||
[ -e "/sys$DEVPATH/$file" ] || return 0
|
||||
readlink -f /sys$DEVPATH/$file 2> /dev/null || true
|
||||
}
|
||||
|
||||
# Return true if a directory is writeable.
|
||||
writeable() {
|
||||
if ln -s test-link $1/.is-writeable 2> /dev/null; then
|
||||
rm -f $1/.is-writeable
|
||||
return 0
|
||||
else
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
# Create a lock file for the current rules file.
|
||||
lock_rules_file() {
|
||||
RUNDIR="/run/udev"
|
||||
[ -e "$RUNDIR" ] || return 0
|
||||
|
||||
RULES_LOCK="$RUNDIR/.lock-${RULES_FILE##*/}"
|
||||
|
||||
retry=30
|
||||
while ! mkdir $RULES_LOCK 2> /dev/null; do
|
||||
if [ $retry -eq 0 ]; then
|
||||
echo "Cannot lock $RULES_FILE!" >&2
|
||||
exit 2
|
||||
fi
|
||||
sleep 1
|
||||
retry=$(($retry - 1))
|
||||
done
|
||||
}
|
||||
|
||||
unlock_rules_file() {
|
||||
[ "$RULES_LOCK" ] || return 0
|
||||
rmdir $RULES_LOCK || true
|
||||
}
|
||||
|
||||
# Choose the real rules file if it is writeable or a temporary file if not.
|
||||
# Both files should be checked later when looking for existing rules.
|
||||
choose_rules_file() {
|
||||
RUNDIR="/run/udev"
|
||||
local tmp_rules_file="$RUNDIR/tmp-rules--${RULES_FILE##*/}"
|
||||
[ -e "$RULES_FILE" -o -e "$tmp_rules_file" ] || PRINT_HEADER=1
|
||||
|
||||
if writeable ${RULES_FILE%/*}; then
|
||||
RO_RULES_FILE='/dev/null'
|
||||
else
|
||||
RO_RULES_FILE=$RULES_FILE
|
||||
RULES_FILE=$tmp_rules_file
|
||||
fi
|
||||
}
|
||||
|
||||
# Return the name of the first free device.
|
||||
raw_find_next_available() {
|
||||
local links="$1"
|
||||
|
||||
local basename=${links%%[ 0-9]*}
|
||||
local max=-1
|
||||
for name in $links; do
|
||||
local num=${name#$basename}
|
||||
[ "$num" ] || num=0
|
||||
[ $num -gt $max ] && max=$num
|
||||
done
|
||||
|
||||
local max=$(($max + 1))
|
||||
# "name0" actually is just "name"
|
||||
[ $max -eq 0 ] && return
|
||||
echo "$max"
|
||||
}
|
||||
|
||||
# Find all rules matching a key (with action) and a pattern.
|
||||
find_all_rules() {
|
||||
local key="$1"
|
||||
local linkre="$2"
|
||||
local match="$3"
|
||||
|
||||
local search='.*[[:space:],]'"$key"'"('"$linkre"')".*'
|
||||
echo $(sed -n -r -e 's/^#.*//' -e "${match}s/${search}/\1/p" \
|
||||
$RO_RULES_FILE \
|
||||
$([ -e $RULES_FILE ] && echo $RULES_FILE) \
|
||||
2>/dev/null)
|
||||
}
|
5
udev-persistent-ifnames.changes
Normal file
5
udev-persistent-ifnames.changes
Normal file
@ -0,0 +1,5 @@
|
||||
-------------------------------------------------------------------
|
||||
Mon May 18 18:27:59 UTC 2015 - jengelh@inai.de
|
||||
|
||||
- Split off network device naming preferences into separate package
|
||||
[bnc#931165]
|
66
udev-persistent-ifnames.spec
Normal file
66
udev-persistent-ifnames.spec
Normal file
@ -0,0 +1,66 @@
|
||||
#
|
||||
# spec file for package udev-persistent-ifnames
|
||||
#
|
||||
# Copyright (c) 2015 SUSE LINUX GmbH, Nuernberg, Germany.
|
||||
#
|
||||
# All modifications and additions to the file contributed by third parties
|
||||
# remain the property of their copyright owners, unless otherwise agreed
|
||||
# upon. The license for this file, and modifications and additions to the
|
||||
# file, is the same license as for the pristine package itself (unless the
|
||||
# license for the pristine package is not an Open Source License, in which
|
||||
# case the license is the MIT License). An "Open Source License" is a
|
||||
# license that conforms to the Open Source Definition (Version 1.9)
|
||||
# published by the Open Source Initiative.
|
||||
|
||||
# Please submit bugfixes or comments via http://bugs.opensuse.org/
|
||||
#
|
||||
|
||||
|
||||
Name: udev-persistent-ifnames
|
||||
Version: 0
|
||||
Release: 0
|
||||
Summary: Persistent classic network interface naming scheme
|
||||
License: GPL-2.0
|
||||
Group: System/Base
|
||||
|
||||
Source: 75-persistent-net-generator.rules
|
||||
Source2: 76-net-sriov-names.rules
|
||||
Source3: rule_generator.functions
|
||||
Source4: write_net_rules
|
||||
Source5: net-set-sriov-names
|
||||
BuildArch: noarch
|
||||
BuildRoot: %_tmppath/%name-%version-build
|
||||
|
||||
%description
|
||||
This package, when installed, disables the default "Predictable
|
||||
Network Interface Naming" scheme[PNIN] in udev, and switches it to a
|
||||
first-loaded-first-named, reboot-persistent scheme.
|
||||
|
||||
[PNIN] http://freedesktop.org/wiki/Software/systemd/PredictableNetworkInterfaceNames/
|
||||
|
||||
Differences from PNIN:
|
||||
* Re-enumeration when the L2 address changes.
|
||||
* Interface names are not - and cannot be - derived from another property
|
||||
like PCI bus address.
|
||||
|
||||
%install
|
||||
b="%buildroot"
|
||||
mkdir -p "$b/%_sysconfdir/udev/rules.d"
|
||||
# We _absolutely do_ want to have this symlink in /etc, such that
|
||||
# `systemd-delta` will show that something is not the same as upstream.
|
||||
ln -s /dev/null "$b/%_sysconfdir/udev/rules.d/80-net-setup-link.rules"
|
||||
mkdir -p "$b/%_prefix/lib/udev/rules.d"
|
||||
install -pm0644 \
|
||||
"%_sourcedir"/*.rules \
|
||||
"$b/%_prefix/lib/udev/rules.d/"
|
||||
install -pm0755 \
|
||||
"%_sourcedir"/{net-set-sriov-names,rule_generator.functions} \
|
||||
"%_sourcedir"/write_net_rules \
|
||||
"$b/%_prefix/lib/udev/"
|
||||
|
||||
%files
|
||||
%defattr(-,root,root)
|
||||
%_sysconfdir/udev/
|
||||
%_prefix/lib/udev/
|
||||
|
||||
%changelog
|
153
write_net_rules
Normal file
153
write_net_rules
Normal file
@ -0,0 +1,153 @@
|
||||
#!/bin/sh -e
|
||||
|
||||
# This script is run to create persistent network device naming rules
|
||||
# based on properties of the device.
|
||||
# If the interface needs to be renamed, INTERFACE_NEW=<name> will be printed
|
||||
# on stdout to allow udev to IMPORT it.
|
||||
|
||||
# variables used to communicate:
|
||||
# MATCHADDR MAC address used for the match
|
||||
# MATCHID bus_id used for the match
|
||||
# MATCHDEVID dev_id used for the match
|
||||
# MATCHDRV driver name used for the match
|
||||
# MATCHIFTYPE interface type match
|
||||
# COMMENT comment to add to the generated rule
|
||||
# INTERFACE_NAME requested name supplied by external tool
|
||||
# INTERFACE_NEW new interface name returned by rule writer
|
||||
|
||||
# Copyright (C) 2006 Marco d'Itri <md@Linux.IT>
|
||||
# Copyright (C) 2007 Kay Sievers <kay.sievers@vrfy.org>
|
||||
#
|
||||
# This program is free software: you can redistribute it and/or modify
|
||||
# it under the terms of the GNU General Public License as published by
|
||||
# the Free Software Foundation, either version 2 of the License, or
|
||||
# (at your option) any later version.
|
||||
#
|
||||
# This program is distributed in the hope that it will be useful,
|
||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
# GNU General Public License for more details.
|
||||
#
|
||||
# You should have received a copy of the GNU General Public License
|
||||
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
# debug, if UDEV_LOG=<debug>
|
||||
if [ -n "$UDEV_LOG" ]; then
|
||||
if [ "$UDEV_LOG" -ge 7 ]; then
|
||||
set -x
|
||||
fi
|
||||
fi
|
||||
|
||||
RULES_FILE='/etc/udev/rules.d/70-persistent-net.rules'
|
||||
|
||||
. /usr/lib/udev/rule_generator.functions
|
||||
|
||||
interface_name_taken() {
|
||||
local value="$(find_all_rules 'NAME=' $INTERFACE)"
|
||||
if [ "$value" ]; then
|
||||
return 0
|
||||
else
|
||||
return 1
|
||||
fi
|
||||
}
|
||||
|
||||
find_next_available() {
|
||||
raw_find_next_available "$(find_all_rules 'NAME=' "$1")"
|
||||
}
|
||||
|
||||
write_rule() {
|
||||
local match="$1"
|
||||
local name="$2"
|
||||
local comment="$3"
|
||||
|
||||
{
|
||||
if [ "$PRINT_HEADER" ]; then
|
||||
PRINT_HEADER=
|
||||
echo "# This file was automatically generated by the $0"
|
||||
echo "# program, run by the persistent-net-generator.rules rules file."
|
||||
echo "#"
|
||||
echo "# You can modify it, as long as you keep each rule on a single"
|
||||
echo "# line, and change only the value of the NAME= key."
|
||||
fi
|
||||
|
||||
echo ""
|
||||
[ "$comment" ] && echo "# $comment"
|
||||
echo "SUBSYSTEM==\"net\", ACTION==\"add\"$match, NAME=\"$name\""
|
||||
} >> $RULES_FILE
|
||||
}
|
||||
|
||||
if [ -z "$INTERFACE" ]; then
|
||||
echo "missing \$INTERFACE" >&2
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Prevent concurrent processes from modifying the file at the same time.
|
||||
lock_rules_file
|
||||
|
||||
# Check if the rules file is writeable.
|
||||
choose_rules_file
|
||||
|
||||
# the DRIVERS key is needed to not match bridges and VLAN sub-interfaces
|
||||
if [ "$MATCHADDR" ]; then
|
||||
# Check if MACADDR doesn't exist already in the generated rules
|
||||
MAC="$(/usr/bin/grep -w -o -C1 -m1 "$MATCHADDR" "$RULES_FILE" 2>/dev/null || true)"
|
||||
if [ "$MAC" = "$MATCHADDR" ]; then
|
||||
unlock_rules_file
|
||||
exit 0
|
||||
fi
|
||||
match="$match, DRIVERS==\"?*\", ATTR{address}==\"$MATCHADDR\""
|
||||
fi
|
||||
|
||||
if [ "$MATCHDRV" ]; then
|
||||
match="$match, DRIVERS==\"$MATCHDRV\""
|
||||
fi
|
||||
|
||||
if [ "$MATCHDEVID" ]; then
|
||||
match="$match, ATTR{dev_id}==\"$MATCHDEVID\""
|
||||
fi
|
||||
|
||||
if [ "$MATCHID" ]; then
|
||||
# Check if KERNEL doesn't exist already in the generated rules
|
||||
KERNEL="$(find_all_rules 'KERNELS==' "$MATCHID")"
|
||||
if [ "$KERNEL" = "$MATCHID" ]; then
|
||||
unlock_rules_file
|
||||
exit 0
|
||||
fi
|
||||
match="$match, KERNELS==\"$MATCHID\""
|
||||
fi
|
||||
|
||||
if [ "$MATCHIFTYPE" ]; then
|
||||
match="$match, ATTR{type}==\"$MATCHIFTYPE\""
|
||||
fi
|
||||
|
||||
if [ -z "$match" ]; then
|
||||
echo "missing valid match" >&2
|
||||
unlock_rules_file
|
||||
exit 1
|
||||
fi
|
||||
|
||||
basename=${INTERFACE%%[0-9]*}
|
||||
match="$match, KERNEL==\"$basename*\""
|
||||
|
||||
if [ "$INTERFACE_NAME" ]; then
|
||||
# external tools may request a custom name
|
||||
COMMENT="$COMMENT (custom name provided by external tool)"
|
||||
if [ "$INTERFACE_NAME" != "$INTERFACE" ]; then
|
||||
INTERFACE=$INTERFACE_NAME;
|
||||
echo "INTERFACE_NEW=$INTERFACE"
|
||||
fi
|
||||
else
|
||||
# if a rule using the current name already exists, find a new name
|
||||
if interface_name_taken; then
|
||||
INTERFACE="$basename$(find_next_available "$basename[0-9]*")"
|
||||
# prevent INTERFACE from being "eth" instead of "eth0"
|
||||
[ "$INTERFACE" = "${INTERFACE%%[ \[\]0-9]*}" ] && INTERFACE=${INTERFACE}0
|
||||
echo "INTERFACE_NEW=$INTERFACE"
|
||||
fi
|
||||
fi
|
||||
|
||||
write_rule "$match" "$INTERFACE" "$COMMENT"
|
||||
|
||||
unlock_rules_file
|
||||
|
||||
exit 0
|
Loading…
x
Reference in New Issue
Block a user