PERFORCE change 147308 for review

Rui Paulo rpaulo at FreeBSD.org
Wed Aug 13 16:02:24 UTC 2008


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

Change 147308 by rpaulo at rpaulo_epsilon on 2008/08/13 16:01:52

	Disable packet padding. It's causing memory corruption.
	Cope with retransmisted SYN or SYN/ACK during connections.

Affected files ...

.. //depot/projects/soc2008/rpaulo-tcpad/handler.c#18 edit
.. //depot/projects/soc2008/rpaulo-tcpad/timer.c#9 edit
.. //depot/projects/soc2008/rpaulo-tcpad/verify.c#8 edit

Differences ...

==== //depot/projects/soc2008/rpaulo-tcpad/handler.c#18 (text+ko) ====

@@ -23,7 +23,7 @@
  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  * POSSIBILITY OF SUCH DAMAGE.
  *
- * $P4: //depot/projects/soc2008/rpaulo-tcpad/handler.c#17 $
+ * $P4: //depot/projects/soc2008/rpaulo-tcpad/handler.c#18 $
  */
 
 #include <stdio.h>
@@ -94,6 +94,7 @@
 	rcp = find_conn(ip->ip_dst, ip->ip_src, ntohs(th->th_dport),
 	    ntohs(th->th_sport));
 
+#ifdef notyet
 	/*
 	 * Erase the data in the TCP packet.
 	 * XXX: This breaks the checksum.
@@ -102,6 +103,7 @@
 	 */
 	memset((inetpkt + sizeof(struct ip) + th->th_off * 4), 'R',
 	    snaplen - (sizeof(struct ip) + th->th_off * 4) - 2);
+#endif
 
 	added = 0;
 	if (cp && cp->pktshead) {

==== //depot/projects/soc2008/rpaulo-tcpad/timer.c#9 (text+ko) ====

@@ -23,7 +23,7 @@
  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  * POSSIBILITY OF SUCH DAMAGE.
  *
- * $P4: //depot/projects/soc2008/rpaulo-tcpad/timer.c#8 $
+ * $P4: //depot/projects/soc2008/rpaulo-tcpad/timer.c#9 $
  */
 
 #include <assert.h>
@@ -117,10 +117,10 @@
 	setitimer(ITIMER_REAL, &itp, NULL);
 
 	LIST_FOREACH_SAFE(cp, &tcpchead, entries, cp_t) {
-		if (cp->pktshead)
+		if (cp->pktshead) {
 			dumper_free(cp);
-		if (cp->rcp && cp->rcp->pktshead)
 			cp->rcp->pktshead = NULL;
+		}
 		LIST_REMOVE(cp, entries);
 		free(cp);
 	}

==== //depot/projects/soc2008/rpaulo-tcpad/verify.c#8 (text+ko) ====

@@ -23,7 +23,7 @@
  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  * POSSIBILITY OF SUCH DAMAGE.
  *
- * $P4: //depot/projects/soc2008/rpaulo-tcpad/verify.c#7 $
+ * $P4: //depot/projects/soc2008/rpaulo-tcpad/verify.c#8 $
  */
 
 #include <stdio.h>
@@ -232,6 +232,8 @@
 	 */
 	if ((th->th_flags & TH_SYN) && !(th->th_flags & TH_ACK) &&
 	    !(th->th_flags & TH_RST) && !(th->th_flags & TH_FIN)) {
+		if (tp && th->th_seq == tp->irs)
+			return (cp);
 
 		cp = malloc(sizeof(*cp));
 		memset(cp, 0, sizeof(*cp));
@@ -294,11 +296,10 @@
 			    TCPAD_VERIFY_DIRECTION_IN);
 			break;
 		default:
-			dumper_error(cp, "SYN/ACK received, state != SYN_SENT");
-			dumper_free(cp);
-			LIST_REMOVE(cp, entries);
-			free(cp);
-			return NULL;
+			/*
+			 * We got a SYN/ACK retransmission. Just ignore it.
+			 */
+			return (cp);
 		}
 		tp->irs = th->th_seq;
 		tp->rcv_wnd = th->th_win;


More information about the p4-projects mailing list