delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2002/06/11/10:55:13

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
From: "Robert Collins" <robert DOT collins AT syncretize DOT net>
To: "'David E Euresti'" <davie AT MIT DOT EDU>, <cygwin AT cygwin DOT com>
Subject: RE: More on passing file descriptors
Date: Wed, 12 Jun 2002 00:51:11 +1000
Message-ID: <00af01c21157$6d825480$0200a8c0@lifelesswks>
MIME-Version: 1.0
X-Priority: 3 (Normal)
X-MSMail-Priority: Normal
X-MimeOLE: Produced By Microsoft MimeOLE V6.00.2600.0000
Importance: Normal
In-Reply-To: <Pine.GSO.4.30L.0206111013260.14396-100000@biohazard-cafe.mit.edu>


> -----Original Message-----
> From: cygwin-owner AT cygwin DOT com 
> [mailto:cygwin-owner AT cygwin DOT com] On Behalf Of David E Euresti
> Sent: Wednesday, 12 June 2002 12:28 AM
> To: cygwin AT cygwin DOT com
> Subject: More on passing file descriptors
> 
> 
> Hello,
> 	I've talked for a while and sent a couple of messages regarding
> file descriptor passing through UNIX sockets.  I've done a little more
> research and determined the following:
> 
> Refer to http://cygwin.com/ml/cygwin/2002-06/msg00227.html for some
> details.
> 
> Unfortunately for this to work properly the message boundaries need to
> be preserved.  Why? Because if I send two messages with two file
> descriptors.  And you read all the data in one turn, how are 
> you going to
> return two file descriptors?

By sending two messages? Seriously, the application buffer != the
windows socket buffer. Cygwin will -need- to have the capability to
buffer temporarily any data after the end of a received message for the
application, so this isn't an issue. Or are you talking about how the
cygserver manages things? If so:

The cygserver framework manages this transparently. It's a message
orientated framework so should not have any trouble. What needs to
happen is the transfer:
Process 1 FD -> cygserver 
Process 1 FD -> cygserver 
Process 1 -> process 2
Process 2 FD <- cygserver
Process 2 FD <- cygserver

(The cygserver might transfer the handles immediately, but the 2nd
process will still need to query to find out the handle values.
Alternative, the cygserver could return the handle values to process 1,
and it then passes the resulting handle values to process 2 which
_already_ has them in it's process space).

Rob


--
Unsubscribe info:      http://cygwin.com/ml/#unsubscribe-simple
Bug reporting:         http://cygwin.com/bugs.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