aboutsummaryrefslogtreecommitdiffstats
path: root/package/base-files/files/etc/hotplug.d/iface/10-routes
diff options
context:
space:
mode:
authorJo-Philipp Wich <jow@openwrt.org>2010-06-01 21:43:52 +0000
committerJo-Philipp Wich <jow@openwrt.org>2010-06-01 21:43:52 +0000
commitcde4aa7a8093bc4e4cf8c83799bcbb6525dca2b4 (patch)
treed2b45c424efe67daa70ddc192150289cecf0770a /package/base-files/files/etc/hotplug.d/iface/10-routes
parentc3e04e54af820f112722e50e4b765afbd2c95655 (diff)
downloadmaster-187ad058-cde4aa7a8093bc4e4cf8c83799bcbb6525dca2b4.tar.gz
master-187ad058-cde4aa7a8093bc4e4cf8c83799bcbb6525dca2b4.tar.bz2
master-187ad058-cde4aa7a8093bc4e4cf8c83799bcbb6525dca2b4.zip
[package] base-file: move alias setup to route hotplug, this fixes alias sections for non-static interfaces like ppp, dhcp, 6in4 etc.
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@21652 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/base-files/files/etc/hotplug.d/iface/10-routes')
-rw-r--r--package/base-files/files/etc/hotplug.d/iface/10-routes28
1 files changed, 28 insertions, 0 deletions
diff --git a/package/base-files/files/etc/hotplug.d/iface/10-routes b/package/base-files/files/etc/hotplug.d/iface/10-routes
index 011668218c..118c1a665d 100644
--- a/package/base-files/files/etc/hotplug.d/iface/10-routes
+++ b/package/base-files/files/etc/hotplug.d/iface/10-routes
@@ -68,7 +68,35 @@ case "$ACTION" in
ifup)
include /lib/network
scan_interfaces
+
+ # Setup aliases
+ config_set "$INTERFACE" aliases ""
+ config_set "$INTERFACE" alias_count 0
+ config_foreach setup_interface_alias alias "$INTERFACE" "$DEVICE"
+
+ # Save alias references in state vars
+ local aliases
+ config_get aliases "$INTERFACE" aliases
+ [ -z "$aliases" ] || uci_set_state network "$INTERFACE" aliases "$aliases"
+
+ # Make ip6addr of parent iface the main address again
+ local ip6addr
+ config_get ip6addr "$INTERFACE" ip6addr
+ [ -z "$ip6addr" ] || {
+ ifconfig "$DEVICE" del "$ip6addr"
+ ifconfig "$DEVICE" add "$ip6addr"
+ }
+
+ # Setup routes
config_foreach "add_route" route
config_foreach "add_route6" route6
;;
+ ifdown)
+ # Bring down named aliases
+ local ifn
+ for ifn in $(ifconfig | sed -ne "s/^\($DEVICE:[^[:space:]]\+\).*/\1/p"); do
+ ifconfig "$ifn" down
+ done
+ ;;
esac
+