From: Michael Prokop Date: Tue, 9 Mar 2021 17:28:27 +0000 (+0100) Subject: Merge remote-tracking branch 'upstream/master' X-Git-Tag: debian/1%20210208+grml.1~1 X-Git-Url: http://git.grml.org/?p=live-boot-grml.git;a=commitdiff_plain;h=322e57a4a7c972702e93038df009c045286bffbd;hp=275828e2d9d9c2b83eae94544e4d43d2027702e0 Merge remote-tracking branch 'upstream/master' Syncing with Debian's live-boot as of commit 6cee205c9b6c7eb9c48bf66bfdd75ab04e38308c (tag: debian/1%20210208, upstream/master) --- diff --git a/components/9990-select-eth-device.sh b/components/9990-select-eth-device.sh index c8f36b0..b660a3d 100755 --- a/components/9990-select-eth-device.sh +++ b/components/9990-select-eth-device.sh @@ -1,5 +1,30 @@ #!/bin/sh +Wait_for_carrier () +{ + # $1 = network device + echo -n "Waiting for link to come up on $1... " + ip link set $1 up + for step in $(seq 1 15) + do + carrier=$(cat /sys/class/net/$1/carrier \ + 2>/dev/null) + case "${carrier}" in + 1) + echo -e "\nLink is up" + return + ;; + *) + # Counter + echo -n "$step " + ;; + esac + sleep 1 + done + echo -e "\nError - carrier not detected on $1." + ip link set $1 down +} + Select_eth_device () { # Boot type in initramfs's config @@ -46,6 +71,7 @@ Select_eth_device () then # only one interface : no choice echo "DEVICE=$l_interfaces" >> /conf/param.conf + Wait_for_carrier $l_interfaces return fi @@ -57,6 +83,7 @@ Select_eth_device () NETDEV="${ARGUMENT#live-netdev=}" echo "DEVICE=$NETDEV" >> /conf/param.conf echo "Found live-netdev parameter, forcing to to use network device $NETDEV." + Wait_for_carrier $NETDEV return ;; esac @@ -75,6 +102,7 @@ Select_eth_device () # ATTR{carrier} is not set if this is not done echo -n " $interface ?" ipconfig -c none -d $interface -t 1 >/dev/null 2>&1 + sleep 1 done echo '' @@ -83,6 +111,7 @@ Select_eth_device () do for interface in $l_interfaces do + ip link set $interface up carrier=$(cat /sys/class/net/$interface/carrier \ 2>/dev/null) # link detected @@ -92,6 +121,7 @@ Select_eth_device () echo "Connected $interface found" # inform initrd's init script : found_eth_dev="$found_eth_dev $interface" + found_eth_dev="$(echo $found_eth_dev | sed -e "s/^[[:space:]]*//g")" ;; esac done diff --git a/debian/control b/debian/control index d040147..c88a3fc 100644 --- a/debian/control +++ b/debian/control @@ -6,7 +6,7 @@ Uploaders: Michael Prokop Build-Depends: debhelper-compat (= 12), po4a, -Standards-Version: 4.4.1 +Standards-Version: 4.5.0 Rules-Requires-Root: no Homepage: https://wiki.debian.org/DebianLive Vcs-Browser: https://git.grml.org/?p=live-boot-grml.git