diff options
author | Bill Nottingham <notting@redhat.com> | 2003-08-08 02:25:10 +0000 |
---|---|---|
committer | Bill Nottingham <notting@redhat.com> | 2003-08-08 02:25:10 +0000 |
commit | b2b39c14155d39014d40a70f7d98c6d0da0c8257 (patch) | |
tree | c44e2b1ae5c083f2d7328196f5948195a73a85de | |
parent | 36159bf2210286f3f61340c7ee6816118e81219c (diff) | |
download | initscripts-b2b39c14155d39014d40a70f7d98c6d0da0c8257.tar initscripts-b2b39c14155d39014d40a70f7d98c6d0da0c8257.tar.gz initscripts-b2b39c14155d39014d40a70f7d98c6d0da0c8257.tar.bz2 initscripts-b2b39c14155d39014d40a70f7d98c6d0da0c8257.tar.xz initscripts-b2b39c14155d39014d40a70f7d98c6d0da0c8257.zip |
fix ethernet device renaming deadlock (yay recursion!) (#101566)
-rwxr-xr-x | sysconfig/network-scripts/ifup | 3 | ||||
-rw-r--r-- | sysconfig/network-scripts/network-functions | 30 |
2 files changed, 31 insertions, 2 deletions
diff --git a/sysconfig/network-scripts/ifup b/sysconfig/network-scripts/ifup index 2a2e955c..9c6945ad 100755 --- a/sysconfig/network-scripts/ifup +++ b/sysconfig/network-scripts/ifup @@ -143,7 +143,8 @@ is_available ${REALDEVICE} if [ -n "${HWADDR}" ]; then FOUNDMACADDR=`get_hwaddr ${REALDEVICE}` if [ "${FOUNDMACADDR}" != "${HWADDR}" ]; then - /sbin/nameif "${REALDEVICE}" "${HWADDR}" || { + local curdev=`ip -o link | awk -F ':' -vIGNORECASE=1 '/$HWADDR/ { print $2 }'` + rename_device "${REALDEVICE}" "${HWADDR}" "${curdev}" || { echo $"Device ${DEVICE} has different MAC address than expected, ignoring." exit 1 } diff --git a/sysconfig/network-scripts/network-functions b/sysconfig/network-scripts/network-functions index 4bde6a63..ad106fb3 100644 --- a/sysconfig/network-scripts/network-functions +++ b/sysconfig/network-scripts/network-functions @@ -144,6 +144,31 @@ do_netreport () ) } +# rename_device() - Rename a network device to something else +# $1 - desired name +# $2 - hardware address to name +# $3 - list of devices that are already in use +# (for general calls, use the current device you're trying to +# change to $1) + +rename_device() +{ + /sbin/nameif "$1" "$2" || { + local hw2=`get_hwaddr ${1}` + local nconfig=`fgrep -il "HWADDR=$hw2" /etc/sysconfig/network-scripts/ifcfg-*` + local dev= + if [ -n "$nconfig" ]; then + dev=$(. $nconfig ; echo $DEVICE) + for device in $3 ; do + [ "$dev" = "$device" ] && unset dev + done + fi + [ -z "$dev" ] && dev=dev$RANDOM + rename_device $dev $hw2 "$3 $1" + /sbin/nameif "$1" "$2" + } +} + is_available () { LC_ALL= LANG= ip -o link | grep -q $1 @@ -154,7 +179,10 @@ is_available () return 2 fi modprobe $1 > /dev/null 2>&1 || return 1 - [ -n "$HWADDR" ] && /sbin/nameif "$1" "$HWADDR" + if [ -n "$HWADDR" ]; then + local curdev=`ip -o link | awk -F ':' -vIGNORECASE=1 '/$HWADDR/ { print $2 }'` + rename_device "$1" "$HWADDR" "$curdev" + fi LC_ALL= LANG= ip -o link | grep -q $1 return $? } |