On 15/12/2011 05:23, Lee wrote:
> On 12/14/11, David Groves wrote:
>> I am having some issues with cygwin applications (specifically sshd)
>> and TCP Window Scaling Factors. I am using OpenSSH client on either a
>> Debian Linux or FreeBSD machine to connect to sshd on a Windows 2k8 R2
                                                           ^^^^^^^^^^^^^^
>> server.

> No pointers, but it does look like a Cygwin problem.
> 
> Start up wireshark on a Windows XP machine and ssh (from a cygwin
                          ^^^^^^^^^^^^^^^^^^
> window) to another machine - tcp syn packet has a window size of 65535
> and a widow scale of zero.  Use putty from the dos prompt to ssh to
> the same machine and that has a window size of 65535 and a window
> scale of 2

  1.  MS completely replaced the networking stack in Vista/2k8 with their
so-called "Next Generation TCP/IP stack", so you can't extrapolate from XP to 
2k8.

  2.  On XP, window scaling is enabled by a registry setting, and when it is
in effect, Windows decides what scale setting to use by considering the
SO_RCVBUF size used when the connection is initiated.  In that light, the fact
that Cygwin applications show a scale of zero is probably not unrelated to
this snippet of code from net.cc#fdsock():

>   /* Raise default buffer sizes (instead of WinSock default 8K).
> 
>      64K appear to have the best size/performance ratio for a default
>      value.  Tested with ssh/scp on Vista over Gigabit LAN.
> 
>      NOTE.  If the SO_RCVBUF size exceeds 65535(*), and if the socket is
>      connected to a remote machine, then calling WSADuplicateSocket on
>      fork/exec fails with WinSock error 10022, WSAEINVAL.  Fortunately
>      we don't use WSADuplicateSocket anymore, rather we just utilize
>      handle inheritance.  An explanation for this weird behaviour would
>      be nice, though.
> 
>      (*) Maximum normal TCP window size.  Coincidence?  */
>   ((fhandler_socket *) fd)->rmem () = 65535;
>   ((fhandler_socket *) fd)->wmem () = 65535;
>   if (::setsockopt (soc, SOL_SOCKET, SO_RCVBUF,
>                   (char *) &((fhandler_socket *) fd)->rmem (), sizeof (int)))
>     {
        [ ... snip error handling ... ]
>     }

  I would guess that a >65536 default would cause Windows to send a non-zero
scale in the SYN packet, but as the comment says, that created some other sort
of problem somehow.

  3.  On 2k8 (also Vista and 7), window scaling is no longer controlled by the
registry but enabled automatically, as part of a new feature called "Receive
Window Auto-Tuning".  I could not infer from any documentation that I could
find in ten minutes googling whether or not it still pays attention to the
initial SO_RCVBUF setting.  It might be worth trying a custom build of the
Cygwin DLL with a 64k or 128k setting in place of 65535.  Then again, it seems
there may yet be problems in this functionality, e.g. the known bug described
at http://support.microsoft.com/kb/983528; perhaps if the custom Cygwin DLL
doesn't help, that hot-fix might.

    cheers,
      DaveK


--
Problem reports:       http://cygwin.com/problems.html
FAQ:                   http://cygwin.com/faq/
Documentation:         http://cygwin.com/docs.html
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple

Reply via email to