X-Recipient: archive-cygwin@delorie.com
X-Spam-Check-By: sourceware.org
Date: Wed, 20 Feb 2013 08:51:43 +0100
From: Corinna Vinschen <corinna-cygwin@cygwin.com>
To: cygwin@cygwin.com
Subject: Re: non-blocking accept() can hang.
Message-ID: <20130220075143.GI23688@calimero.vinschen.de>
Reply-To: cygwin@cygwin.com
Mail-Followup-To: cygwin@cygwin.com
References: <CANjopZGmp+xaUg1Sn2FTmb77igMk8R=Lp9yBWyeDtDj3RP5R=g@mail.gmail.com> <loom.20130205T082932-242@post.gmane.org> <CANjopZHH2kv0s0pitt0beFiC=tsP5bOsSBJ8TBhSWnSD-iP7fg@mail.gmail.com> <loom.20130206T131835-535@post.gmane.org> <CANjopZHhRZts4nOm6h19h2xY02=7L5WNuVypDkLqo2cojUG2zA@mail.gmail.com> <5114A38B.6060201@gmail.com> <CANjopZExQ_qZc90jOi9qEZ+mvw4o87hOw_fAa8JhEDOfV+yQJA@mail.gmail.com> <20130219144600.GE23688@calimero.vinschen.de> <CANjopZHYnCJfhT7_8fSijiukf5gcpGdW3bOU610Uy_kULTZNCg@mail.gmail.com>
MIME-Version: 1.0
Content-Type: text/plain; charset=utf-8
Content-Disposition: inline
In-Reply-To: <CANjopZHYnCJfhT7_8fSijiukf5gcpGdW3bOU610Uy_kULTZNCg@mail.gmail.com>
User-Agent: Mutt/1.5.21 (2010-09-15)
Mailing-List: contact cygwin-help@cygwin.com; run by ezmlm
Precedence: bulk
List-Id: <cygwin.cygwin.com>
List-Unsubscribe: <mailto:cygwin-unsubscribe-archive-cygwin=delorie.com@cygwin.com>
List-Subscribe: <mailto:cygwin-subscribe@cygwin.com>
List-Archive: <http://sourceware.org/ml/cygwin/>
List-Post: <mailto:cygwin@cygwin.com>
List-Help: <mailto:cygwin-help@cygwin.com>, <http://sourceware.org/ml/#faqs>
Sender: cygwin-owner@cygwin.com
Mail-Followup-To: cygwin@cygwin.com
Delivered-To: mailing list cygwin@cygwin.com

On Feb 20 07:16, Tanaka Akira wrote:
> 2013/2/19 Corinna Vinschen
> >
> > I debugged your example code, and it can't work on Cygwin.  The problem
> > is that accept/connect on AF_LOCAL sockets performs a handshake
> > operation to make sure that the other side of the socket is a Cygwin
> > process as well, and to propagate credential information between
> > client and listener.  The way it's implemented right now requires that
> > both sides of the socket are responsive.  That's a safe thing for the
> > accept call here, but since there's neither a blocking connect, nor a
> > select or poll call waiting on the connecting side of the socket, nothing
> > goes forward.
> >
> > To get this code working, you have to use either AF_INET or AF_INET6
> > sockets, or you have to start a thread calling select or poll, so
> > there's an active function call which allows to perform the handshake
> > from the connecting side.
> 
> Thank you for the information.
> I'll use threads.

The most simple way to get a connected local socket is to use the
socketpair function, btw.


Corinna

-- 
Corinna Vinschen                  Please, send mails regarding Cygwin to
Cygwin Maintainer                 cygwin AT cygwin DOT com
Red Hat

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

