[SCM] live-initramfs branch, master, updated. 1.157.4-1-32-gce405b2
Daniel Baumann
daniel at debian.org
Mon Dec 14 10:09:20 UTC 2009
The following commit has been merged in the master branch:
commit ce405b293cc2be1a941fb55c5d6126b1fa92c82e
Author: Daniel Baumann <daniel at debian.org>
Date: Mon Dec 14 11:06:13 2009 +0100
Adding select_eth_device script from Frederic Boiteux <fboiteux at calistel.com>.
diff --git a/scripts/init-premount/select_eth_device b/scripts/init-premount/select_eth_device
new file mode 100755
index 0000000..6ab8bfe
--- /dev/null
+++ b/scripts/init-premount/select_eth_device
@@ -0,0 +1,77 @@
+#!/bin/sh
+
+# Original script by Andreas Teuchert <ant+dl at hsg-kl.de>
+# Modified by Frédéric Boiteux <fboiteux at calistel.com>
+
+
+
+PREREQ="blacklist udev"
+
+prereqs()
+{
+ echo "$PREREQ"
+}
+
+case $1 in
+# get pre-requisites
+prereqs)
+ prereqs
+ exit 0
+ ;;
+esac
+
+# Boot type in initramfs's config
+bootconf=$(egrep '^BOOT=' /conf/initramfs.conf | tail -1)
+
+# can be superseded by command line (used by Debian-Live's netboot for example)
+for ARGUMENT in $(cat /proc/cmdline); do
+ case "${ARGUMENT}" in
+ netboot=*)
+ NETBOOT="${ARGUMENT#netboot=}"
+ ;;
+ esac
+done
+
+if [ "$bootconf" != "BOOT=nfs" ] && [ "$NETBOOT" = "" ]; then
+ # Not a net boot : nothing to do
+ exit 0
+fi
+
+# we want to do some basic IP
+modprobe -q af_packet
+
+# Available Ethernet interfaces ?
+l_interfaces=$(cd /sys/class/net/ && ls -d eth* 2>/dev/null)
+
+if [ $(echo $l_interfaces | wc -w) -lt 2 ]; then
+ # only one interface : no choice
+ echo "DEVICE=$l_interfaces" >> /conf/param.conf
+ exit 0
+fi
+
+while true; do
+ echo -n "Looking for a connected Ethernet interface ..."
+
+ for interface in $l_interfaces; do
+ # ATTR{carrier} is not set if this is not done
+ echo -n " $interface ?"
+ ipconfig -c none -d $interface -t 1 >/dev/null 2>&1
+ done
+ echo ''
+
+ for step in 1 2 3 4 5; do
+ for interface in $l_interfaces; do
+ carrier=$(cat /sys/class/net/$interface/carrier \
+ 2>/dev/null)
+ # link detected
+ if [ "$carrier" = 1 ]; then
+ echo " found $interface."
+ # inform initrd's init script :
+ echo "DEVICE=$interface" >> /conf/param.conf
+ exit 0
+ fi
+ done
+ # wait a bit
+ sleep 1
+ done
+done
--
live-initramfs
More information about the debian-live-changes
mailing list