From: Victor Lowther Date: Thu, 26 Feb 2009 02:42:11 +0000 (-0800) Subject: Move running dhclient on DHCP interfaces into a pre-mount hook. X-Git-Tag: 0.1~410 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=5f3e2dd2f3344c65a8e268a47a48b3fe5759364f;p=thirdparty%2Fdracut.git Move running dhclient on DHCP interfaces into a pre-mount hook. 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. --- diff --git a/dhclient-script b/dhclient-script index 5a2c66b8a..dc2d9e1e1 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 000000000..fcf890ef8 --- /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 79607db80..83f65229f 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 3def15405..b477a9c44 100755 --- a/modules/40network.sh +++ b/modules/40network.sh @@ -5,3 +5,4 @@ inst "$dsrc/dhclient-script" "/sbin/dhclient-script" instmods =networking ecb arc4 inst_rules "$dsrc/rules.d/60-net.rules" inst_hook pre-pivot 10 "$dsrc/hooks/kill-dhclient.sh" +inst_hook pre-mount 70 "$dsrc/hooks/run-dhclient.sh"