PERFORCE change 29085 for review

Robert Watson rwatson at FreeBSD.org
Wed Apr 16 13:18:25 PDT 2003


http://perforce.freebsd.org/chv.cgi?CH=29085

Change 29085 by rwatson at rwatson_tislabs on 2003/04/16 13:18:10

	Since the introduction of TCP wait state reduction,
	tcp_twrespond() has pulled an mbuf from its hat without
	labeling it before sending, resulting in invariants
	violations in the MAC code.  Add a commented out
	recommendation on how to address this, with some
	possible implementation (also commented out).

Affected files ...

.. //depot/projects/trustedbsd/mac/sys/netinet/tcp_subr.c#28 edit

Differences ...

==== //depot/projects/trustedbsd/mac/sys/netinet/tcp_subr.c#28 (text+ko) ====

@@ -1683,6 +1683,18 @@
 	return (NULL);
 }
 
+/*
+ * XXXMAC: Really, we need to pass in the mbuf we are responding to
+ * so that we have a label to assign to the outgoing packet here.
+ * Question: will one always be available?  Should we pass in the
+ * socket in the twstart case?  Perhaps:
+ *
+ * tcp_twrespond(struct tcptw *tw, struct socket *so, struct mbuf *m,
+ *     int flags)
+ *
+ * Where one of the socket or mbuf must be non-NULL so as to provide
+ * a label.
+ */
 int
 tcp_twrespond(struct tcptw *tw, int flags)
 {
@@ -1703,6 +1715,15 @@
 		return (ENOBUFS);
 	m->m_data += max_linkhdr;
 
+#ifdef 0
+#ifdef MAC
+	if (so != NULL)
+		mac_create_mbuf_from_socket(so, m);
+	else
+		mac_create_mbuf_netlayer(msrc, m);
+#endif
+#endif
+
 #ifdef INET6
 	if (isipv6) {
 		hdrlen = sizeof(struct ip6_hdr) + sizeof(struct tcphdr);


More information about the p4-projects mailing list