aboutsummaryrefslogtreecommitdiffstats
path: root/package/base-files-network/files/etc/hotplug.d/net/10-net
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2011-10-20 15:01:06 +0000
committerFelix Fietkau <nbd@openwrt.org>2011-10-20 15:01:06 +0000
commitc2b5767572c7cece21f7739e416d59458278b7d8 (patch)
treebbb6d468090141c8fe0367f573272ec8289fa755 /package/base-files-network/files/etc/hotplug.d/net/10-net
parentfce837994043793008be610cb24154d649c7b190 (diff)
downloadupstream-c2b5767572c7cece21f7739e416d59458278b7d8.tar.gz
upstream-c2b5767572c7cece21f7739e416d59458278b7d8.tar.bz2
upstream-c2b5767572c7cece21f7739e416d59458278b7d8.zip
base-files: move network related scripts to a separate package to make the transition to netifd easier
SVN-Revision: 28495
Diffstat (limited to 'package/base-files-network/files/etc/hotplug.d/net/10-net')
-rw-r--r--package/base-files-network/files/etc/hotplug.d/net/10-net72
1 files changed, 72 insertions, 0 deletions
diff --git a/package/base-files-network/files/etc/hotplug.d/net/10-net b/package/base-files-network/files/etc/hotplug.d/net/10-net
new file mode 100644
index 0000000000..013ece39ce
--- /dev/null
+++ b/package/base-files-network/files/etc/hotplug.d/net/10-net
@@ -0,0 +1,72 @@
+# Copyright (C) 2006 OpenWrt.org
+
+include /lib/network
+
+addif() {
+ # Ensure that ipv6 is loaded, autoloading happens later but ipv6 might be
+ # required now for interface setup.
+ [ -d /proc/sys/net/ipv6 ] || {
+ grep -q '^ipv6' /etc/modules.d/* && insmod ipv6
+ }
+
+ # PPP devices are configured by pppd, no need to run setup_interface here
+ case "$INTERFACE" in
+ 3g-*|ppp-*|pppoa-*|pppoe-*|pptp-*) return 0;;
+ esac
+
+ scan_interfaces
+ local cfg="$(find_config "$INTERFACE")"
+
+ case "$INTERFACE" in
+ # Skip wireless parent interfaces
+ ath[0-9]|wlan[0-9]) ;;
+ *)
+ # check the autoload setting
+ config_get auto "$cfg" auto
+ case "$auto" in
+ 1|on|enabled) setup_interface "$INTERFACE";;
+ esac
+ ;;
+ esac
+
+ # find all vlan configurations for this interface and set them up as well
+ for ifc in $interfaces; do
+ config_get iftype "$ifc" type
+ config_get ifs "$ifc" device
+ for dev in $ifs; do
+ [ "${dev%%\.*}" = "$INTERFACE" -a "$dev" != "$INTERFACE" ] && {
+ add_vlan "$dev"
+ }
+ done
+ done
+}
+
+
+delif() {
+ scan_interfaces
+
+ # find all vlan configurations for this interface and nuke 'em
+ for ifc in $interfaces; do
+ config_get iftype "$ifc" type
+ config_get ifs "$ifc" device
+ confdevs="$(uci_get network.$ifc.ifname)"
+ for dev in $ifs; do
+ [ "${dev%%\.*}" = "$INTERFACE" ] && {
+ list_contains confdevs "$dev" || list_remove ifs "$dev"
+ }
+ done
+ uci_set_state "network" "$ifc" device "$ifs"
+ done
+}
+
+case "$ACTION" in
+ add|register)
+ case "$PHYSDEVDRIVER" in
+ natsemi) sleep 1;;
+ esac
+ addif
+ ;;
+ remove|unregister)
+ delif
+ ;;
+esac