From: Raphaƫl Hertzog Date: Sat, 12 Dec 2020 16:10:37 +0000 (+0000) Subject: Merge branch 'master' into 'master' X-Git-Tag: debian/1%20210122~3 X-Git-Url: http://git.grml.org/?p=live-boot-grml.git;a=commitdiff_plain;h=4e260c46192d5c6e67fd7b6775aaa2f07ea8301e;hp=-c Merge branch 'master' into 'master' 9990-select-eth-device.sh: check carrier, pick NIC See merge request live-team/live-boot!33 --- 4e260c46192d5c6e67fd7b6775aaa2f07ea8301e diff --combined components/9990-select-eth-device.sh index 09642c8,8d7ef84..365d64b --- a/components/9990-select-eth-device.sh +++ b/components/9990-select-eth-device.sh @@@ -1,5 -1,30 +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 +71,7 @@@ then # only one interface : no choice echo "DEVICE=$l_interfaces" >> /conf/param.conf + Wait_for_carrier $l_interfaces return fi @@@ -57,6 -83,7 +83,7 @@@ 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 +102,7 @@@ # 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 +111,7 @@@ do for interface in $l_interfaces do + ip link set $interface up carrier=$(cat /sys/class/net/$interface/carrier \ 2>/dev/null) # link detected @@@ -91,7 -120,7 +120,7 @@@ 1) echo "Connected $interface found" # inform initrd's init script : - found_eth_dev="$found_eth_dev $interface" + found_eth_dev="$interface" ;; esac done