delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2006/08/01/11:55:33

X-Spam-Check-By: sourceware.org
Message-ID: <44CF7953.8090808@netbauds.net>
Date: Tue, 01 Aug 2006 16:54:59 +0100
From: Darryl Miles <darryl-mailinglists AT netbauds DOT net>
User-Agent: Mozilla/5.0 (X11; U; Linux x86_64; en-GB; rv:1.8.0.5) Gecko/20060727 SeaMonkey/1.0.3
MIME-Version: 1.0
To: cygwin AT cygwin DOT com
Subject: Re: 1.5.20(0.156/4/2) pipe hangs, dos files
References: <20060801141450 DOT 88222 DOT qmail AT web51109 DOT mail DOT yahoo DOT com>
In-Reply-To: <20060801141450.88222.qmail@web51109.mail.yahoo.com>
X-IsSubscribed: yes
Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Subscribe: <mailto:cygwin-subscribe AT cygwin DOT com>
List-Archive: <http://sourceware.org/ml/cygwin/>
List-Post: <mailto:cygwin AT cygwin DOT com>
List-Help: <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/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

Saurabh Tendulkar wrote:
> We have an older cygwin on another machine: CYGWIN_NT-5.1 1.5.6(0.108/3/2),
> paste (textutils) 2.0.21, Gnu Awk 3.1.3, which runs absolutely fine.
> 
> ulimit -p is 8 on both machines.

Is this problem related to the select() code pipe problems.


This is where the writability/select event semantics do not follow POSIX 
convention.  This is specifically a problem to pipes in blocking mode 
who rely on the behaviour to stop I/O deadlocks occuring.

CYGWIN can indicate a writability event on a pipe which will block the 
next time you write to it.  The application program is not expecting it 
to block and so hangs.

The reason for the volume of data needing to be over a threshold is that 
you need to fill the pipe buffer space to cause a blocking condition to 
occur.


I did take a look at it a few weeks ago, there is code in the select.cc 
which should do the trick.  However this was disabled because one (or 
more) users of a specific application ("unison") found it to be causing 
problems with their program.  So the lastest attempt to fix this gaping 
problem was disabled, rather than having the application affected 
reviewed and a testcase created to exhibit the problem they see.

We already have a test case to prove the current CYGWIN library IO 
semantics fail.

But we dont have a test case to prove how the commented out code in 
select.cc failed for the application ("unison")  that was affected.


So we are currently stuck in the middle.  Where one group of users (who 
do have a provable test case) for which select() is broken are suffering 
because we dont understand and can't see what the problem was with other 
groups of users affected application.  This could be viewed at "The Lazy 
minority rules".  Lazy as in unison users didn't not bother to provice a 
testcase to prove where CYGWIN has broken, and Minority in that more 
popular uses remain broken.

The only mitigating circumstances are that the minority application 
users could cite that previous version of CYGWIN has worked.  But this 
should not have been justifiable grounds to reinstate


We have to face it that it is broken either way so no one way has more 
weight than another when you are en-route to finding the fix.


I am still interested in tackling the whole situation but I do need to 
be furnished with a testcase to work with.  I believe the original 
comeback by the group of users running "unison" should have insisted a 
testcase was produced by them to demonstrate the new breakage.

At the moment in time I do not understand and can not see how the 
minority application was affected by the current proposed fix.


Darryl

--
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