projects
/
openwrt.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
[package] kmod-libertas needs kmod-lib80211 to load
[openwrt.git]
/
package
/
base-files
/
files
/
sbin
/
ifdown
diff --git
a/package/base-files/files/sbin/ifdown
b/package/base-files/files/sbin/ifdown
index
26d0e62
..
8de414d
100755
(executable)
--- a/
package/base-files/files/sbin/ifdown
+++ b/
package/base-files/files/sbin/ifdown
@@
-1,8
+1,17
@@
#!/bin/sh
# Copyright (C) 2006 OpenWrt.org
#!/bin/sh
# Copyright (C) 2006 OpenWrt.org
-[ $# = 0 ] && { echo " $0 <group>"; exit; }
. /etc/functions.sh
. /etc/functions.sh
+[ $# = 0 ] && { echo " $0 <group>"; exit; }
+[ "x$1" = "x-a" ] && {
+ [ -e "/tmp/resolv.conf.auto" ] && rm /tmp/resolv.conf.auto
+ config_cb() {
+ [ interface != "$1" -o -z "$2" ] || eval "$0 $2"
+ }
+ config_load network
+ exit
+}
+
include /lib/network
scan_interfaces
include /lib/network
scan_interfaces
@@
-13,8
+22,8
@@
config_get proto "$cfg" proto
[ -z "$proto" ] && { echo "interface not found."; exit; }
config_get iface "$cfg" device
[ -z "$proto" ] && { echo "interface not found."; exit; }
config_get iface "$cfg" device
-[ "
$proto" = "static
" ] && {
- env -i ACTION="ifdown" INTERFACE="$c
onfig" DEVICE="$iface" PROTO=static /sbin/hotplug "iface" &
+[ "
static" = "$proto" -o "none" = "$proto
" ] && {
+ env -i ACTION="ifdown" INTERFACE="$c
fg" DEVICE="$iface" PROTO="$proto" /sbin/hotplug-call "iface"
}
# call interface stop handler
}
# call interface stop handler
@@
-43,13
+52,21
@@
done
rm -f /var/run/${ifname}.pid /var/run/ppp-${cfg}.pid
config_get ifname "$cfg" ifname
rm -f /var/run/${ifname}.pid /var/run/ppp-${cfg}.pid
config_get ifname "$cfg" ifname
-config_get device "$cfg"
ifnam
e
+config_get device "$cfg"
devic
e
[ ."$device" != ."$ifname" ] || device=
for dev in $ifname $device; do
[ ."$device" != ."$ifname" ] || device=
for dev in $ifname $device; do
- ifconfig "$
ifname
" 0.0.0.0 down >/dev/null 2>/dev/null
+ ifconfig "$
dev
" 0.0.0.0 down >/dev/null 2>/dev/null
done
config_get iftype "$cfg" type
done
config_get iftype "$cfg" type
-[ "$iftype" = "bridge" ] && brctl delbr "$ifname" >/dev/null 2>/dev/null
+[ "bridge" = "$iftype" ] && brctl delbr "$ifname" >/dev/null 2>/dev/null
+
+# remove the interface's network state
+uci_revert_state network "$1"
+# revert aliases state as well
+config_get aliases "$1" aliases
+for config in $aliases; do
+ uci_revert_state network "$config"
+done
This page took
0.023196 seconds
and
4
git commands to generate.