diff options
author | Jo-Philipp Wich <jow@openwrt.org> | 2010-06-01 21:43:52 +0000 |
---|---|---|
committer | Jo-Philipp Wich <jow@openwrt.org> | 2010-06-01 21:43:52 +0000 |
commit | cde4aa7a8093bc4e4cf8c83799bcbb6525dca2b4 (patch) | |
tree | d2b45c424efe67daa70ddc192150289cecf0770a /package/base-files/files/etc/hotplug.d/iface | |
parent | c3e04e54af820f112722e50e4b765afbd2c95655 (diff) | |
download | master-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')
-rw-r--r-- | package/base-files/files/etc/hotplug.d/iface/10-routes | 28 |
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 + |