Static interfaces are still configured on the fly as we add them, but discussions on the mailing list have suggested that we need to have finer control over bringing up dhcp interfaces. The default hook just runs all the requested dhclients in parallel and waits for them to all return. If you need something more complicated than this, or need to have more control over bringing interfaces up, you will probably need to override some stuff in the 40network hook. --- dhclient-script | 4 +++- hooks/run-dhclient.sh | 7 +++++++ ifup | 5 ++--- modules/40network.sh | 1 + 4 files changed, 13 insertions(+), 4 deletions(-) diff --git a/dhclient-script b/dhclient-script index 5a2c66b..dc2d9e1 100755 --- a/dhclient-script +++ b/dhclient-script @@ -19,7 +19,9 @@ case $reason in for s in $new_domain_name_servers; do echo "nameserver $s" >> /etc/resolv.conf done - set |grep -e '^new_[a-z_]=' >/net.$interface.dhcpopts + set |grep -e '^new_[a-z_]=' |while read line; do + echo "${line%%=*}=\'${line#*=}\'">>/net.$interface.dhcpopts + done >/net.$interface.up ;; *) ;; esac diff --git a/hooks/kill-dhclient.sh b/hooks/kill-dhclient.sh old mode 100644 new mode 100755 diff --git a/hooks/run-dhclient.sh b/hooks/run-dhclient.sh new file mode 100755 index 0000000..fcf890e --- /dev/null +++ b/hooks/run-dhclient.sh @@ -0,0 +1,7 @@ +#!/bin/sh +for i in /net.*.dhcp; do + dev=${i#net.}; dev=${i%.dhcp} + dhclient -1 -q $dev & +done +wait + \ No newline at end of file diff --git a/ifup b/ifup index 79607db..83f6522 100755 --- a/ifup +++ b/ifup @@ -1,5 +1,4 @@ #!/bin/sh ->/net.$1 # loopback is always handled the same way [ "$1" = "lo" ] && { @@ -14,13 +13,13 @@ for p in $(cat /proc/cmdline); do p=${p#ip=} case $p in none|off) exit 0;; # we were told to not configure anything - dhcp|on|any) dhclient -nw "$1"; exit 0;; + dhcp|on|any) >/net.$1.dhcp; exit 0;; bootp|rarp|both) exit 0;; #dunno how to do this *) echo ${ip#ip=} | \ (IFS=':' read client server gw netmask hostname device autoconf if [ -z "$device" -o "$device" = "$1" ]; then case $autoconf in - dhcp|on|any) dhclient -nw "$1";; + dhcp|on|any) >/net.$1.dhcp ;; none|off|'') # do some basic configuration ip link set $1 up ip addr add $client/$netmask dev $1 diff --git a/modules/40network.sh b/modules/40network.sh index 59f523a..cee74b4 100755 --- a/modules/40network.sh +++ b/modules/40network.sh @@ -5,3 +5,4 @@ inst "$dsrc/dhclient-script" "/sbin/dhclient-script" instmods =drivers/net ecb arc4 inst_rules 60-net.rules inst_hook pre-pivot 10 "$dsrc/hooks/kill-dhclient.sh" +inst_hook pre-mount 70 "$dsrc/hooks/run-dhclient.sh" -- 1.6.0.6 -- To unsubscribe from this list: send the line "unsubscribe initramfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html