Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 29 Jun 2007 22:27:06 +0100
From:      David Malone <dwmalone@maths.tcd.ie>
To:        Steve Kargl <sgk@troutmask.apl.washington.edu>
Cc:        freebsd-current@freebsd.org
Subject:   Re: SYNCOOKIE authentication problems 
Message-ID:  <200706292227.aa62881@salmon.maths.tcd.ie>
In-Reply-To: Your message of "Fri, 29 Jun 2007 09:32:47 PDT." <20070629163247.GA6373@troutmask.apl.washington.edu> 

next in thread | previous in thread | raw e-mail | index | archive | help
> Jun 29 09:21:58 node11 kernel: TCP: [192.168.0.12]:54528 to [192.168.0.11]:526

OK - I can see the packets corresponding to this error by doing something
like:

% tcpdump -S -r synfinrstdata -n port 62391 and port 60621
17:22:01.607876 192.168.0.15.62391 > 192.168.0.11.60621: S 106955928:106955928(0) win 65535 <mss 1460,nop,wscale 8,sackOK,timestamp 419300 0>
17:22:01.607967 192.168.0.11.60621 > 192.168.0.15.62391: S 2273558377:2273558377(0) ack 106955929 win 65535 <mss 1460,nop,wscale 8,nop,nop,timestamp 4153368860 419300>
17:22:01.608514 192.168.0.15.62391 > 192.168.0.11.60621: F 106955941:106955941(0) ack 2273558378 win 260 <nop,nop,timestamp 419301 4153368860>
17:22:01.609638 192.168.0.11.60621 > 192.168.0.15.62391: F 2273558378:2273558378(0) ack 106955942 win 260 <nop,nop,timestamp 4153368862 419301>
17:22:01.609697 192.168.0.11.60621 > 192.168.0.15.62391: F 2273558378:2273558378(0) ack 106955942 win 260 <nop,nop,timestamp 4153368862 419301>
17:22:01.610103 192.168.0.11.60621 > 192.168.0.15.62391: R 2273558379:2273558379(0) win 0

The start of this looks like a perfectly normal TCP connection -
it opens normally, transfers about 12 bytes in one direction and
then closes. Strangley, 192.168.0.11 then sends two FIN packets,
followed by a reset. The error message produced by the kernel should
have produced a reset in response, but I'm not sure I can see quite
enough to see what happened.

We could try to get all of the packets in the connection by doing:

	tcpdump -i whatever_interface -w /tmp/fulldump -s 80

then wait for an error (that is not local to this machine - I think
they are going to lo0). Then note the port numbers and do:

	tcpdump -r /tmp/fulldump port _port1_ and port _port2_

With regard to the truss output

> poll({4/POLLIN 5/POLLIN 6/POLLIN 7/POLLIN 9/POLLIN 10/POLLIN 11/POLLIN 13/POLL

It looks like MPI is looking only for file discriptors to become
ready for reading. I'd guess one of the file discriptors is in an
error state, but MPI isn't checking for theat, so it is spinning.

	David.



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