more fixes for the network scripts
authorFelix Fietkau <nbd@openwrt.org>
Sat, 19 Nov 2005 19:04:15 +0000 (19:04 +0000)
committerFelix Fietkau <nbd@openwrt.org>
Sat, 19 Nov 2005 19:04:15 +0000 (19:04 +0000)
SVN-Revision: 2537

openwrt/package/base-files/default/etc/hotplug.d/net/10-net
openwrt/package/base-files/default/sbin/ifdown
openwrt/package/base-files/default/sbin/ifup

index 3bc980f86f02110468ef7dc8d6295f9f515566d7..19f53abd7dab39b20cb37ca5ebaa13f94277a190 100644 (file)
@@ -23,22 +23,21 @@ find_name()
                IFTYPE="${ifname}"
                IFPROTO="$(nvram get ${IFTYPE}_proto)"
                IFACE="$(nvram get ${IFTYPE}_ifname)"
-               [ -z "$IFPROTO" -o "$IFPROTO" = "none" ] || {
-                       [ "${IFACE}" = "$INTERFACE" ] && return 0
-                       case "$IFPROTO" in
-                               static|dhcp)
-                                       [ "${IFACE%%[0-9]*}" = "br" ] && {
-                                               for part in $(nvram get ${IFTYPE}_ifnames); do
-                                                       [ "$part" = "$INTERFACE" ] && return 0
-                                               done
-                                       }
-                               ;;
-                               *)
-                                       [ "$(nvram get ${IFPROTO}_ifname)" = "$INTERFACE" \
-                                         -a -x /sbin/ifup.${IFPROTO} ] && return 0
-                               ;;
-                       esac
-               }
+               case "$IFPROTO" in
+                       ""|none);;
+                       static|dhcp)
+                               [ "${IFACE}" = "$INTERFACE" ] && return 0
+                               [ "${IFACE%%[0-9]*}" = "br" ] && {
+                                       for part in $(nvram get ${IFTYPE}_ifnames); do
+                                               [ "$part" = "$INTERFACE" ] && return 0
+                                       done
+                               }
+                       ;;
+                       *)
+                               [ "$(nvram get ${IFPROTO}_ifname)" = "$INTERFACE" \
+                                 -a -x /sbin/ifup.${IFPROTO} ] && return 0
+                       ;;
+               esac
        done
        IFACE=""
        IFTYPE=""
@@ -155,13 +154,12 @@ do_register()
                                do_ifup "$IFPROTO" "$IFTYPE" "$if"
                        fi
                }
-       else
-               do_ifup "$IFPROTO" "$IFTYPE" "$if"
+       else 
+               [ "${INTERFACE%%[0-9]*}" = "ppp" ] || do_ifup "$IFPROTO" "$IFTYPE" "$if"
        fi
 }
 
 do_unregister() {
-       [ "${INTERFACE%%[0-9]*}" = "atm" ] || ifconfig "$INTERFACE" 0.0.0.0 down 2>&-
        [ -z "$IFTYPE" -o -z "$IFPROTO" ] && find_name
        [ -z "$IFTYPE" -o -z "$IFPROTO" ] && return 0
        
@@ -175,13 +173,14 @@ do_unregister() {
        
        case "$IFPROTO" in
                pppoe|pppoa|pptp) 
-                       killall ifup.${IFPROTO} 2>&- >&-
                        killall pppd 2>&- >&-
                ;;
                dhcp)
                        [ -f /var/run/${INTERFACE}.pid ] && kill "$(cat /var/run/${INTERFACE}.pid)" 2>&- >&-
                ;;
        esac
+
+       [ "${INTERFACE%%[0-9]*}" = "atm" ] || ifconfig "$INTERFACE" 0.0.0.0 down 2>&-
 }
 
 case "$ACTION" in
index 8818d46145c532c6d400c61f338aaffeafc5971b..85bb2fbc5db0033562d59a789ce55a279d389839 100755 (executable)
@@ -15,6 +15,8 @@ case "$if_proto" in
        ""|none) exit 0;;
 esac
 
+[ "${if%%[0-9]*}" = "ppp" ] && if="$(nvram get ${if_proto}_ifname)"
+
 if [ "${if%%[0-9]}" = "br" ]; then
        for sif in $(nvram get ${type}_ifnames); do
                hotplug_dev unregister "$sif"
index 0a2cdf5331ccc85ef63ec56b5f761ee0cb47e372..67e01a3e90ddf81bdba8bebb7b8843ebb57f00d8 100755 (executable)
@@ -23,6 +23,8 @@ case "$if_proto" in
        none|"") exit 0;;
 esac
 
+[ "${if%%[0-9]*}" = "ppp" ] && if="$(nvram get ${if_proto}_ifname)"
+
 if [ "${if%%[0-9]}" = "br" ]; then
        for sif in $(nvram get ${type}_ifnames); do
                hotplug_dev register "$sif"