Merge branch 'master' into 'master'
authorRaphaël Hertzog <hertzog@debian.org>
Sat, 12 Dec 2020 16:10:37 +0000 (16:10 +0000)
committerRaphaël Hertzog <hertzog@debian.org>
Sat, 12 Dec 2020 16:10:37 +0000 (16:10 +0000)
9990-select-eth-device.sh: check carrier, pick NIC

See merge request live-team/live-boot!33

1  2 
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
                        # 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 ''
                do
                        for interface in $l_interfaces
                        do
+                               ip link set $interface up
                                carrier=$(cat /sys/class/net/$interface/carrier \
                                        2>/dev/null)
                                # link detected
                                        1)
                                                echo "Connected $interface found"
                                                # inform initrd's init script :
 -                                              found_eth_dev="$found_eth_dev $interface"
 +                                              found_eth_dev="$interface"
                                                ;;
                                esac
                        done