From b0c30bf225cc6f07dc2e97c65ddaa6478b69110a Mon Sep 17 00:00:00 2001 From: Harald Hoyer Date: Aug 19 2020 14:22:49 +0000 Subject: network: skip already enslaved interfaces (cherry picked from commit f6e3b59e5ea6f52a25631557badc7f4dfabbd7ee) Resolves: #1625042 patch_name: 0014.patch present_in_specfile: true location_in_specfile: 14 squash_commits: true --- diff --git a/modules.d/35network-legacy/ifup.sh b/modules.d/35network-legacy/ifup.sh index ea2a67f..b4f5bf1 100755 --- a/modules.d/35network-legacy/ifup.sh +++ b/modules.d/35network-legacy/ifup.sh @@ -408,7 +408,11 @@ for p in $(getargs ip=); do esac # If this option isn't directed at our interface, skip it - [ -n "$dev" ] && [ "$dev" != "$netif" ] && continue + if [ -n "$dev" ]; then + [ "$dev" != "$netif" ] && continue + else + iface_is_enslaved "$netif" && continue + fi # Store config for later use for i in ip srv gw mask hostname macaddr mtu dns1 dns2; do diff --git a/modules.d/40network/net-lib.sh b/modules.d/40network/net-lib.sh index 7b93f25..f956957 100755 --- a/modules.d/40network/net-lib.sh +++ b/modules.d/40network/net-lib.sh @@ -745,6 +745,13 @@ iface_has_link() { iface_has_carrier "$@" } +iface_is_enslaved() { + local _li + _li=$(ip -o link show dev $1) + strstr "$li" " master " || return 1 + return 0 +} + find_iface_with_link() { local iface_path="" iface="" for iface_path in /sys/class/net/*; do