Skip site navigation (1)Skip section navigation (2)
Date:      Sun, 27 Oct 2002 14:55:34 -0800
From:      Lars Eggert <larse@ISI.EDU>
To:        Lars Eggert <larse@ISI.EDU>
Cc:        Luigi Rizzo <rizzo@icir.org>, net@FreeBSD.ORG
Subject:   Re: Bridging when one interface has no carrier
Message-ID:  <3DBC6EE6.4070307@isi.edu>
In-Reply-To: <3D61224B.2020902@isi.edu>
References:  <3D61224B.2020902@isi.edu> <20020819102951.A38869@iguana.icir.org> <3DB885BD.8010203@isi.edu>

next in thread | previous in thread | raw e-mail | index | archive | help
This is a cryptographically signed message in MIME format.

--------------ms080202010704020003060206
Content-Type: multipart/mixed;
 boundary="------------090306070007090507070105"

This is a multi-part message in MIME format.
--------------090306070007090507070105
Content-Type: text/plain; charset=us-ascii; format=flowed
Content-Transfer-Encoding: 7bit

[Re-send, forgot to attach the patches. Argh.]

Lars Eggert wrote:

 > This causes the problem decribed in PR kern/41632
 > (http://www.freebsd.org/cgi/query-pr.cgi?pr=kern/41632), where dhcpd
 > "listens" on interface A which is bridged to interface B. When A has no
 > carrier, DHCP requests arriving on B are ignored. When A has a carrier,
 > dhcp will get a copy of the packet when it is bridge-forwarded out A, so
 > the problem doesn't occur then.
 >
 > Attached is a rough patch to if_ethersubr.c that fixes the problem.

That patch (new version attached) turned out to only fix part of the
problem.

When bridge-forwarding packets to an interface without a carrier, they
start to fill up its outbout queue. Once the queue is full, new packets
that are routed to that interfaces won't be bridged anymore.

This happens in the example above with dhcpd. DHCP requests come in on B
and get bridge-forwarded to A (filling up A's outbound queue). dhcpd
generates responses, which are sent via A and then bridge-forwarded to
B. Once A's outbound queue is full, those responses fall on the floor.

Attached is an ugly hack that fixes this in my setup.

The next issue is bridge interactions with IPv6 stateless autoconf. IPv6
doesn't like link-local addresses appearing on (apparently) different
interfaces...

Lars
-- 
Lars Eggert <larse@isi.edu>           USC Information Sciences Institute

--------------090306070007090507070105
Content-Type: text/plain;
 name="if_var.patch"
Content-Transfer-Encoding: 7bit
Content-Disposition: inline;
 filename="if_var.patch"

--- /nfs/ruby/larse/if_var.h	Sun Oct 27 11:48:06 2002
+++ sys/net/if_var.h	Sun Oct 27 11:47:47 2002
@@ -272,6 +272,38 @@
 	int need_if_start = 0;
 	int s = splimp();
  
+        /*
+         * Drop the packet if the outbound interface has no carrier.
+         * This prevents the queue from filling up, causing bridging
+         * to fail, since packets would be dropped before being bridged. 
+         *
+         * XXX I'd be nice if we could easily peek at the media status
+         *     here. Instead, use a 50% full queue together with the
+         *     interface not sending is an indicator.
+         */
+        if (ifp && (!(ifp->if_flags & IFF_OACTIVE)) &&
+	    ifq->ifq_len > ifq->ifq_maxlen / 2) {
+                /*   
+                 * Flush the queue here, otherwise we send out stale
+                 * packets once the interface gets a carrier.
+		 *
+		 * XXX This duplicates ifq_qflush().
+                 */ 
+		register struct mbuf *m2, *n;
+ 		n = ifq->ifq_head;
+		while ((m2 = n) != 0) {
+			n = m2->m_act;
+			m_freem(m2);
+		}
+		ifq->ifq_head = 0;
+		ifq->ifq_tail = 0;
+		ifq->ifq_len = 0;
+
+		/* Now drop the packet. */ 
+                m_freem(m);
+                return (0);
+        }
+
 	if (IF_QFULL(ifq)) {
 		IF_DROP(ifq);
 		splx(s);

--------------090306070007090507070105
Content-Type: text/plain;
 name="bridge.patch"
Content-Transfer-Encoding: 7bit
Content-Disposition: inline;
 filename="bridge.patch"

--- /nfs/ruby/larse/bridge.c	Sun Oct 27 11:48:14 2002
+++ sys/net/bridge.c	Sun Oct 27 11:51:54 2002
@@ -104,6 +104,7 @@
 #include <net/if.h>
 #include <net/if_types.h>
 #include <net/if_var.h>
+#include <net/bpf.h>
 
 #include <netinet/in.h> /* for struct arpcom */
 #include <netinet/in_systm.h>
@@ -197,7 +198,7 @@
  *
  */
 
-#define DDB(x) x
+#define DDB(x)
 #define DEB(x)
 
 static int bdginit(void);
@@ -813,7 +814,7 @@
      */
     struct ether_header save_eh = *eh ;
 
-    DEB(quad_t ticks; ticks = rdtsc();)
+    DDB(quad_t ticks; ticks = rdtsc();)
 
     args.rule = NULL;		/* did we match a firewall rule ? */
     /* Fetch state from dummynet tag, ignore others */
@@ -1015,6 +1016,21 @@
 		    return m0 ; /* the original is still there... */
 		}
 	    }
+
+	    /*
+	     * Deliver a copy of the packet to the bpf even if the interface
+	     * has no carrier. This fixes kern/41632.
+	     */
+	    if ((!(last->if_flags & IFF_OACTIVE)) && last->if_bpf != NULL) {
+		struct m_hdr mh;
+
+		/* This kludge is OK; BPF treats the "mbuf" as read-only */
+		mh.mh_next = m;
+		mh.mh_data = (char *)eh;
+		mh.mh_len = ETHER_HDR_LEN;
+		bpf_mtap(last, (struct mbuf *)&mh);
+            }
+ 
 	    /*
 	     * Add header (optimized for the common case of eh pointing
 	     * already into the mbuf) and execute last part of ether_output:
@@ -1058,7 +1074,7 @@
 	if (ifp == NULL)
 	    once = 1 ;
     }
-    DEB(bdg_fw_ticks += (u_long)(rdtsc() - ticks) ; bdg_fw_count++ ;
+    DDB(bdg_fw_ticks += (u_long)(rdtsc() - ticks) ; bdg_fw_count++ ;
 	if (bdg_fw_count != 0) bdg_fw_avg = bdg_fw_ticks/bdg_fw_count; )
     return m0 ;
 }

--------------090306070007090507070105--

--------------ms080202010704020003060206
Content-Type: application/x-pkcs7-signature; name="smime.p7s"
Content-Transfer-Encoding: base64
Content-Disposition: attachment; filename="smime.p7s"
Content-Description: S/MIME Cryptographic Signature

MIAGCSqGSIb3DQEHAqCAMIACAQExCzAJBgUrDgMCGgUAMIAGCSqGSIb3DQEHAQAAoIIJtjCC
AzgwggKhoAMCAQICEGZFcrfMdPXPY3ZFhNAukQEwDQYJKoZIhvcNAQEEBQAwgdExCzAJBgNV
BAYTAlpBMRUwEwYDVQQIEwxXZXN0ZXJuIENhcGUxEjAQBgNVBAcTCUNhcGUgVG93bjEaMBgG
A1UEChMRVGhhd3RlIENvbnN1bHRpbmcxKDAmBgNVBAsTH0NlcnRpZmljYXRpb24gU2Vydmlj
ZXMgRGl2aXNpb24xJDAiBgNVBAMTG1RoYXd0ZSBQZXJzb25hbCBGcmVlbWFpbCBDQTErMCkG
CSqGSIb3DQEJARYccGVyc29uYWwtZnJlZW1haWxAdGhhd3RlLmNvbTAeFw0wMDA4MzAwMDAw
MDBaFw0wNDA4MjcyMzU5NTlaMIGSMQswCQYDVQQGEwJaQTEVMBMGA1UECBMMV2VzdGVybiBD
YXBlMRIwEAYDVQQHEwlDYXBlIFRvd24xDzANBgNVBAoTBlRoYXd0ZTEdMBsGA1UECxMUQ2Vy
dGlmaWNhdGUgU2VydmljZXMxKDAmBgNVBAMTH1BlcnNvbmFsIEZyZWVtYWlsIFJTQSAyMDAw
LjguMzAwgZ8wDQYJKoZIhvcNAQEBBQADgY0AMIGJAoGBAN4zMqZjxwklRT7SbngnZ4HF2ogZ
gpcO40QpimM1Km1wPPrcrvfudG8wvDOQf/k0caCjbZjxw0+iZdsN+kvx1t1hpfmFzVWaNRqd
knWoJ67Ycvm6AvbXsJHeHOmr4BgDqHxDQlBRh4M88Dm0m1SKE4f/s5udSWYALQmJ7JRr6aFp
AgMBAAGjTjBMMCkGA1UdEQQiMCCkHjAcMRowGAYDVQQDExFQcml2YXRlTGFiZWwxLTI5NzAS
BgNVHRMBAf8ECDAGAQH/AgEAMAsGA1UdDwQEAwIBBjANBgkqhkiG9w0BAQQFAAOBgQAxsUtH
XfkBceX1U2xdedY9mMAmE2KBIqcS+CKV6BtJtyd7BDm6/ObyJOuR+r3sDSo491BVqGz3Da1M
G7wD9LXrokefbKIMWI0xQgkRbLAaadErErJAXWr5edDqLiXdiuT82w0fnQLzWtvKPPZE6iZp
h39Ins6ln+eE2MliYq0FxjCCAzkwggKioAMCAQICAwglQTANBgkqhkiG9w0BAQQFADCBkjEL
MAkGA1UEBhMCWkExFTATBgNVBAgTDFdlc3Rlcm4gQ2FwZTESMBAGA1UEBxMJQ2FwZSBUb3du
MQ8wDQYDVQQKEwZUaGF3dGUxHTAbBgNVBAsTFENlcnRpZmljYXRlIFNlcnZpY2VzMSgwJgYD
VQQDEx9QZXJzb25hbCBGcmVlbWFpbCBSU0EgMjAwMC44LjMwMB4XDTAyMDgyNDE4NTMzOVoX
DTAzMDgyNDE4NTMzOVowVDEPMA0GA1UEBBMGRWdnZXJ0MQ0wCwYDVQQqEwRMYXJzMRQwEgYD
VQQDEwtMYXJzIEVnZ2VydDEcMBoGCSqGSIb3DQEJARYNbGFyc2VAaXNpLmVkdTCCASIwDQYJ
KoZIhvcNAQEBBQADggEPADCCAQoCggEBANI2Rrt4ggaQ/IrOsDeOm2H4/R5FRIL6JjDY3StE
aogp1r23WKniQ1Vj98Nu5WxlaZ3Iam3Jen5T66H8u7rtMNpK4qAeAGoBsVeyVr1+CTFeuv+m
xCh7BvBJwhLdm0zDaoDT05YKYZaqtsT+F286FWJQg31Xtf+vTKLVVrHcsafnteyal2NEt7Ac
yZZfjsVLwxp2Lq3cwYfRQRoo7/yCVzS7HsgM6jmbO4taEMo4yC2rpnUbWEUCDTaCYgpAXzAl
oiNk7GDh0wz2s5ZSnHRvNSBMAjCmpNtSYHfXFI1ANwrrrHIJ7Ei83+XN32PWY4OPzO3iown9
VR+vM+8lNx9OX28CAwEAAaNWMFQwKgYFK2UBBAEEITAfAgEAMBowGAIBBAQTTDJ1TXlmZkJO
VWJOSkpjZFoyczAYBgNVHREEETAPgQ1sYXJzZUBpc2kuZWR1MAwGA1UdEwEB/wQCMAAwDQYJ
KoZIhvcNAQEEBQADgYEAXcrIlKmPLM/r8r3oz2ZLPLaT1AyMjYTZY2qq/R7SUtFa9BNlTIFh
DG78QKfJ9lo2LMzTPQqMZgNLmj95GbNPI8P8OIq2K6MeCZWz08ROackqTFP6xWbIFIfXcBVR
1dZnDDyDKBBh05KkvyTPawSQyOBUeNBfQUyO4TE+3o58U8UwggM5MIICoqADAgECAgMIJUEw
DQYJKoZIhvcNAQEEBQAwgZIxCzAJBgNVBAYTAlpBMRUwEwYDVQQIEwxXZXN0ZXJuIENhcGUx
EjAQBgNVBAcTCUNhcGUgVG93bjEPMA0GA1UEChMGVGhhd3RlMR0wGwYDVQQLExRDZXJ0aWZp
Y2F0ZSBTZXJ2aWNlczEoMCYGA1UEAxMfUGVyc29uYWwgRnJlZW1haWwgUlNBIDIwMDAuOC4z
MDAeFw0wMjA4MjQxODUzMzlaFw0wMzA4MjQxODUzMzlaMFQxDzANBgNVBAQTBkVnZ2VydDEN
MAsGA1UEKhMETGFyczEUMBIGA1UEAxMLTGFycyBFZ2dlcnQxHDAaBgkqhkiG9w0BCQEWDWxh
cnNlQGlzaS5lZHUwggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIBAQDSNka7eIIGkPyK
zrA3jpth+P0eRUSC+iYw2N0rRGqIKda9t1ip4kNVY/fDbuVsZWmdyGptyXp+U+uh/Lu67TDa
SuKgHgBqAbFXsla9fgkxXrr/psQoewbwScIS3ZtMw2qA09OWCmGWqrbE/hdvOhViUIN9V7X/
r0yi1Vax3LGn57XsmpdjRLewHMmWX47FS8Madi6t3MGH0UEaKO/8glc0ux7IDOo5mzuLWhDK
OMgtq6Z1G1hFAg02gmIKQF8wJaIjZOxg4dMM9rOWUpx0bzUgTAIwpqTbUmB31xSNQDcK66xy
CexIvN/lzd9j1mODj8zt4qMJ/VUfrzPvJTcfTl9vAgMBAAGjVjBUMCoGBStlAQQBBCEwHwIB
ADAaMBgCAQQEE0wydU15ZmZCTlViTkpKY2RaMnMwGAYDVR0RBBEwD4ENbGFyc2VAaXNpLmVk
dTAMBgNVHRMBAf8EAjAAMA0GCSqGSIb3DQEBBAUAA4GBAF3KyJSpjyzP6/K96M9mSzy2k9QM
jI2E2WNqqv0e0lLRWvQTZUyBYQxu/ECnyfZaNizM0z0KjGYDS5o/eRmzTyPD/DiKtiujHgmV
s9PETmnJKkxT+sVmyBSH13AVUdXWZww8gygQYdOSpL8kz2sEkMjgVHjQX0FMjuExPt6OfFPF
MYID1TCCA9ECAQEwgZowgZIxCzAJBgNVBAYTAlpBMRUwEwYDVQQIEwxXZXN0ZXJuIENhcGUx
EjAQBgNVBAcTCUNhcGUgVG93bjEPMA0GA1UEChMGVGhhd3RlMR0wGwYDVQQLExRDZXJ0aWZp
Y2F0ZSBTZXJ2aWNlczEoMCYGA1UEAxMfUGVyc29uYWwgRnJlZW1haWwgUlNBIDIwMDAuOC4z
MAIDCCVBMAkGBSsOAwIaBQCgggIPMBgGCSqGSIb3DQEJAzELBgkqhkiG9w0BBwEwHAYJKoZI
hvcNAQkFMQ8XDTAyMTAyNzIyNTUzNFowIwYJKoZIhvcNAQkEMRYEFFx7cdLDGo7dvEO7VC3e
x7lTcjQ+MFIGCSqGSIb3DQEJDzFFMEMwCgYIKoZIhvcNAwcwDgYIKoZIhvcNAwICAgCAMA0G
CCqGSIb3DQMCAgFAMAcGBSsOAwIHMA0GCCqGSIb3DQMCAgEoMIGrBgkrBgEEAYI3EAQxgZ0w
gZowgZIxCzAJBgNVBAYTAlpBMRUwEwYDVQQIEwxXZXN0ZXJuIENhcGUxEjAQBgNVBAcTCUNh
cGUgVG93bjEPMA0GA1UEChMGVGhhd3RlMR0wGwYDVQQLExRDZXJ0aWZpY2F0ZSBTZXJ2aWNl
czEoMCYGA1UEAxMfUGVyc29uYWwgRnJlZW1haWwgUlNBIDIwMDAuOC4zMAIDCCVBMIGtBgsq
hkiG9w0BCRACCzGBnaCBmjCBkjELMAkGA1UEBhMCWkExFTATBgNVBAgTDFdlc3Rlcm4gQ2Fw
ZTESMBAGA1UEBxMJQ2FwZSBUb3duMQ8wDQYDVQQKEwZUaGF3dGUxHTAbBgNVBAsTFENlcnRp
ZmljYXRlIFNlcnZpY2VzMSgwJgYDVQQDEx9QZXJzb25hbCBGcmVlbWFpbCBSU0EgMjAwMC44
LjMwAgMIJUEwDQYJKoZIhvcNAQEBBQAEggEAqpEHriYUGR9Fu6Z2kMnSLIcbwo1dAvwou5R5
W1yk8jfgex/76R2MkkaaWTdfKfOkm2DQ/sU8q+iXH6w9yMzJVKVLQ8gbRN6a7CMI52BOSJzO
Ejt6sVprO4yrPskc7tOPcPFqZug7u60qlW2sh8cSmkXlkAnvLezjm1ldMij69GHL7uR5KwhR
VTHnZV7SONtJw8kInvt2qMnPpViPJbjgFmLU/59+vTP56bNSwjqPhY/RuTyDRXEl4s6z3ohh
Qp/dB9p3c7Hj2IzXSL2iMsvYyEZzHbwlTRsZozV4Z1jSF7N85IVgVX9BNYMo9rY8wq5Nv1zM
hrMhf6F8ul9r4ov+2AAAAAAAAA==
--------------ms080202010704020003060206--


To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-net" in the body of the message




Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?3DBC6EE6.4070307>