delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2003/04/15/15:37:34

Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Subscribe: <mailto:cygwin-subscribe AT cygwin DOT com>
List-Archive: <http://sources.redhat.com/ml/cygwin/>
List-Post: <mailto:cygwin AT cygwin DOT com>
List-Help: <mailto:cygwin-help AT cygwin DOT com>, <http://sources.redhat.com/ml/#faqs>
Sender: cygwin-owner AT cygwin DOT com
Mail-Followup-To: cygwin AT cygwin DOT com
Delivered-To: mailing list cygwin AT cygwin DOT com
Message-ID: <008701c30386$64cc56c0$5c51893e@pomello>
From: "Max Bowsher" <maxb AT ukf DOT net>
To: "Brian White" <bcwhite AT precidia DOT com>
Cc: <cygwin AT cygwin DOT com>
References: <3E9C374E DOT 4256358D AT precidia DOT com> <004001c30372$9b95d9b0$235e893e AT pomello> <3E9C42AF DOT F8A6AEA1 AT precidia DOT com>
Subject: Re: tcp RST instead of FIN if child exits after parent closes path
Date: Tue, 15 Apr 2003 20:36:10 +0100
MIME-Version: 1.0
X-Priority: 3
X-MSMail-Priority: Normal
X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2800.1106

Brian White wrote:
>> [a good analysis, but the subject says it all, really, once a typo is
fixed
>> (s/exists/exits)]
>
> Oops!  :-)
>
>
>> Re: tcp RST instead of FIN if child exits after parent closes path
>>
>> This is a bug/feature of Windows Sockets. I think it would be possible to
>> craft a workaround in Cygwin, but it would require some non-trivial IPC.
>> (IIUC, you would need to maintain a cross-process refcount for the
socket).
>
> Hmmm...  From my work with Amanda, the child process can continue to
> send data via the socket even after the parent has closed it's handle
> on that path, so there must be some sort of reference counting already.

Yes, but the wrong sort.

To guarantee avoiding the RST, you need to shutdown(SHUT_WR) the socket. And
that does stop all processes from writing to the socket. So, you would need
to refcount the socket, and issue a shutdown just before the last close. (I
think.)

For a quick hack, you could try sleeping for a second before exiting. Should
work most of the time.


Max.


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

- Raw text -


  webmaster     delorie software   privacy  
  Copyright © 2019   by DJ Delorie     Updated Jul 2019