delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2006/06/30/15:43:20

X-Spam-Check-By: sourceware.org
Message-ID: <44A57EC6.2060805@netbauds.net>
Date: Fri, 30 Jun 2006 20:43:02 +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.4) Gecko/20060614 SeaMonkey/1.0.2
MIME-Version: 1.0
To: cygwin AT cygwin DOT com
Subject: Re: rsync over ssh hang issue understood
References: <44A348D1 DOT 6070908 AT netbauds DOT net> <ba40711f0606291839p2e1d7b10l7befd8cf2cc2d1a7 AT mail DOT gmail DOT com> <44A507F8 DOT 4030409 AT netbauds DOT net> <44A53F4B DOT 4070503 AT netbauds DOT net> <e83hnt$lve$1 AT sea DOT gmane DOT org>
In-Reply-To: <e83hnt$lve$1@sea.gmane.org>
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

mwoehlke wrote:
> Darryl Miles wrote:
> [snip]
>>  * The outstanding byte count needs to be protected by a mutex.
> 
> Are you familiar with the Interlocked* family of functions? Depending on 
> what exactly you need to do with the value, a mutex may be unnecessary.

Do these function perform buslock prefixed increment/add with memory 
operand.   As per Linux kernel /usr/src/linux/include/asm-i386/atomic.h. 
  Its an atomic add operation that would be needed, but I dont think 
that will be the only thing that will need intra-thread protection.  The 
close() case flag setting might need to be involved too as well as other 
things, like we need serialization.



One point from my last post was:
 > Select justs need to lookup the outstanding by count and update the 
write_ready state based on the threshold.

I need to revise that, in that all decrement operations on the 
outstanding byte count need to re-test for the new decremented value 
ends is below the threshold to allow more IO to occur.  If so it should 
_consider_ waking up all threads waiting on the fd under select(2).


That consideration would be along the lines of:

  * If there is blocked IO already waiting behind the serialization gate 
to come through, then this instance of the io completion routine is not 
responsible for waking up select(2).  That responsibility passes to the 
next IO after it has come through the gate and called WriteFileEx() and 
then added its byte count to the outstanding byte count as necessary.

  * If there is no blocked IO waiting at the gate to come through, then 
its the responsibility of this completion routine to wake up select waiters.


This is to stop false writable events from waking up select then we 
already have an IO queued up and blocked.



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