add fix for running udhcpc on bridges (patch by Eric L. Chen)
authornbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Wed, 18 Jul 2007 08:23:36 +0000 (08:23 +0000)
committernbd <nbd@3c298f89-4303-0410-b956-a3cf2f4a3e73>
Wed, 18 Jul 2007 08:23:36 +0000 (08:23 +0000)
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@8025 3c298f89-4303-0410-b956-a3cf2f4a3e73

package/busybox/patches/243-udhcpc_changed_ifindex.patch [new file with mode: 0644]

diff --git a/package/busybox/patches/243-udhcpc_changed_ifindex.patch b/package/busybox/patches/243-udhcpc_changed_ifindex.patch
new file mode 100644 (file)
index 0000000..3a95174
--- /dev/null
@@ -0,0 +1,17 @@
+Index: busybox-1.4.2/networking/udhcp/dhcpc.c
+===================================================================
+--- busybox-1.4.2.orig/networking/udhcp/dhcpc.c        2007-07-18 10:07:20.161035443 +0200
++++ busybox-1.4.2/networking/udhcp/dhcpc.c     2007-07-18 10:09:15.515609124 +0200
+@@ -273,6 +273,12 @@
+               tv.tv_sec = timeout - uptime();
+               tv.tv_usec = 0;
++              /* When running on a bridge, the ifindex may have changed (e.g. if
++               * member interfaces were added/removed or if the status of the
++               * bridge changed).
++               * Workaround: refresh it here before processing the next packet */
++              read_interface(client_config.interface, &client_config.ifindex, NULL, client_config.arp);
++
+               if (listen_mode != LISTEN_NONE && fd < 0) {
+                       if (listen_mode == LISTEN_KERNEL)
+                               fd = listen_socket(INADDR_ANY, CLIENT_PORT, client_config.interface);