From 11a916c4dfec837c32695a4c539c58c5e29150b2 Mon Sep 17 00:00:00 2001
From: jow <jow@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Date: Mon, 10 Aug 2009 23:48:10 +0000
Subject: [PATCH] [package] base-files: move ipv6 module loading from
 setup_interface() to addif() in the hotplug call, this ensures that ipv6 is
 loaded before any interfaces or aliases with ip6addr option are configured
 (#5356)

git-svn-id: svn://svn.openwrt.org/openwrt/trunk@17217 3c298f89-4303-0410-b956-a3cf2f4a3e73
---
 package/base-files/Makefile                       | 2 +-
 package/base-files/files/etc/hotplug.d/net/10-net | 6 ++++++
 package/base-files/files/lib/network/config.sh    | 9 ---------
 3 files changed, 7 insertions(+), 10 deletions(-)

diff --git a/package/base-files/Makefile b/package/base-files/Makefile
index 6901829f2..fb7debf96 100644
--- a/package/base-files/Makefile
+++ b/package/base-files/Makefile
@@ -9,7 +9,7 @@ include $(TOPDIR)/rules.mk
 include $(INCLUDE_DIR)/kernel.mk
 
 PKG_NAME:=base-files
-PKG_RELEASE:=25
+PKG_RELEASE:=26
 
 PKG_FILE_DEPENDS:=$(PLATFORM_DIR)/ $(GENERIC_PLATFORM_DIR)/base-files/
 
diff --git a/package/base-files/files/etc/hotplug.d/net/10-net b/package/base-files/files/etc/hotplug.d/net/10-net
index 06e524444..f46dcd08d 100644
--- a/package/base-files/files/etc/hotplug.d/net/10-net
+++ b/package/base-files/files/etc/hotplug.d/net/10-net
@@ -3,6 +3,12 @@
 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
 		ppp*) return 0;;
diff --git a/package/base-files/files/lib/network/config.sh b/package/base-files/files/lib/network/config.sh
index a5cadf61b..bfadf40c8 100755
--- a/package/base-files/files/lib/network/config.sh
+++ b/package/base-files/files/lib/network/config.sh
@@ -251,15 +251,6 @@ setup_interface() {
 		sleep 1
 	}
 
-	# Check whether this interface has an IPv6 address
-	# defined and ensure that the kmod is loaded since
-	# ifup could be triggered before modules are loaded.
-	local hasipv6
-	config_get hasipv6 "$config" ip6addr
-	[ -n "$hasipv6" ] && [ ! -d /proc/sys/net/ipv6 ] && {
-		grep -q '^ipv6' /etc/modules.d/* && insmod ipv6
-	}
-
 	# Interface settings
 	grep "$iface:" /proc/net/dev > /dev/null && {
 		local mtu macaddr
-- 
2.20.1