X-Git-Url: http://git.ozo.com/?a=blobdiff_plain;f=package%2Fbase-files%2Ffiles%2Fusr%2Fshare%2Fudhcpc%2Fdefault.script;h=53bb6999f6aa13dcde0f4551cf5b4dc05707f000;hb=1f9301993a46fff9e69043e6ae0027f29cff2b24;hp=f39d21ed8c2ae380180b5d0e9d90fadfa694c808;hpb=5ad62fbdd3e65c841a917ee5f2d1fc238921078c;p=openwrt-10.03%2F.git diff --git a/package/base-files/files/usr/share/udhcpc/default.script b/package/base-files/files/usr/share/udhcpc/default.script index f39d21ed8..53bb6999f 100755 --- a/package/base-files/files/usr/share/udhcpc/default.script +++ b/package/base-files/files/usr/share/udhcpc/default.script @@ -14,7 +14,7 @@ hotplug_event() { config_get proto $ifc proto [ "$proto" = "dhcp" ] || continue - env -i ACTION="$1" INTERFACE="$ifc" DEVICE="$ifname" PROTO=dhcp /sbin/hotplug iface + env -i ACTION="$1" INTERFACE="$ifc" DEVICE="$ifname" PROTO=dhcp /sbin/hotplug-call iface done } @@ -28,15 +28,17 @@ case "$1" in netmask ${subnet:-255.255.255.0} \ broadcast ${broadcast:-+} - if [ -n "$router" ] ; then - echo "deleting routers" - while route del default gw 0.0.0.0 dev $interface >&- 2>&- ; do :; done - + [ -n "$router" ] && { for i in $router ; do echo "adding router $i" route add default gw $i dev $interface + valid="$valid|$i" + done - fi + + echo "deleting old routes" + $(route -n | awk '/^0.0.0.0\W{9}('$valid')\W/ {next} /^0.0.0.0/ {print "route del -net "$1" gw "$2";"}') + } [ -n "$dns" ] && { echo -n > $RESOLV_CONF