svn commit: r235163 - stable/8/contrib/traceroute
Michael Tuexen
tuexen at FreeBSD.org
Wed May 9 13:08:26 UTC 2012
Author: tuexen
Date: Wed May 9 13:08:26 2012
New Revision: 235163
URL: http://svn.freebsd.org/changeset/base/235163
Log:
MFC r234701:
Fix a bug in the TCP tracerouting which resulted in not accepting any
incoming packets. So all packets seemed to be lost.
Modified:
stable/8/contrib/traceroute/traceroute.c
Directory Properties:
stable/8/contrib/traceroute/ (props changed)
Modified: stable/8/contrib/traceroute/traceroute.c
==============================================================================
--- stable/8/contrib/traceroute/traceroute.c Wed May 9 11:01:39 2012 (r235162)
+++ stable/8/contrib/traceroute/traceroute.c Wed May 9 13:08:26 2012 (r235163)
@@ -1406,8 +1406,7 @@ tcp_prep(struct outdata *outdata)
tcp->th_sport = htons(ident);
tcp->th_dport = htons(port + (fixedPort ? 0 : outdata->seq));
- tcp->th_seq = (tcp->th_sport << 16) | (tcp->th_dport +
- (fixedPort ? outdata->seq : 0));
+ tcp->th_seq = (tcp->th_sport << 16) | tcp->th_dport;
tcp->th_ack = 0;
tcp->th_off = 5;
tcp->th_flags = TH_SYN;
@@ -1425,8 +1424,8 @@ tcp_check(const u_char *data, int seq)
struct tcphdr *const tcp = (struct tcphdr *) data;
return (ntohs(tcp->th_sport) == ident
- && ntohs(tcp->th_dport) == port + (fixedPort ? 0 : seq))
- && tcp->th_seq == (((tcp_seq)ident << 16) | (port + seq));
+ && ntohs(tcp->th_dport) == port + (fixedPort ? 0 : seq)
+ && tcp->th_seq == (tcp_seq)((tcp->th_sport << 16) | tcp->th_dport));
}
void
More information about the svn-src-all
mailing list