delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2020/11/30/13:15:40

X-Recipient: archive-cygwin AT delorie DOT com
DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org 04102388CC16
DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=cygwin.com;
s=default; t=1606760098;
bh=6nR2D+sUi7EvcvKViPc3iEqusAUj7j075JpL/NInKmo=;
h=Subject:To:References:Date:In-Reply-To:List-Id:List-Unsubscribe:
List-Archive:List-Post:List-Help:List-Subscribe:From:Reply-To:
From;
b=TvBCCgb+N10MxNQ57Riqb/JPKmsHA4LQRj9COO/j8pMdsPm+xFWL1CgPbVQcccV9N
VbCBtUM3c2/6jbGTSqtDProiXlh5EsxR0DkYZ8tL8oW4fiv7AUR9y2XSLCi//2x8Fu
jPe+jWL6pITNiYXsfJKM+c3hNTin5fnhDTH5d/To=
X-Original-To: cygwin AT cygwin DOT com
Delivered-To: cygwin AT cygwin DOT com
DMARC-Filter: OpenDMARC Filter v1.3.2 sourceware.org 93BD8385E021
ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none;
b=Sd/4Qwnsgl8WZ9NJrgXLGBdtLbNp74eCNsIbUjw2tqytWhs3tcC41pKHs8ayrgxNmFk0XtKVmQpaaQ+91GwzvN/ecerUCL+T39I7ucpanimsqnQ+5ujg2DHMr6yQ5V28FyWkRhVQ/Rq+OFcu852+Bn4DOEto9SpEGN68wIoKk24xb5gUhBo3bvE+9KmZPkb95tyE1OdGQI4fKXoH4VlIb4frDnJCyGBEgW5klBY7geSshJQ9PeUsOLV3artXdkjjx2EVD2mOEOa48bpa/6UKBGz3G5qdwFtR3gsT6bFNgghsbqI9As4luXQWekI5LPHM7OSa9lo+hNkmBm7hmafXZQ==
ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com;
s=arcselector9901;
h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck;
bh=TwGmYKLi+uxgZ7NW8cpqqOvcTK/gmsPfjXPqgTR01Ro=;
b=Q7A38EQiA59i21VwjGNch8WlR+XF7BP0NiScCT2eOn90IA/0+rz63w8g4o2w35kWo1H8cZ2pHuRH1fXtdLxUbc7+Iv2RUEujxRB52Ubn/aZeNrnGydkKVECFZwV4fGLzkCQ9RhX2R2n9q0fJh4sgm8JOojQqBxVz5VVqXOnPHIXKFWiHJ1xOuOeBLyREvtGFxDGWir+6hu8nPA/5RzX9ZVyrsIHg3a8E2rPxgq/qr79AmwE183jDje8TCP0PmhayqwCWcmv0/BftmCY9wFPllRFiWhRLmskuybRSsKCJIKXT/+dEXUZx3QL0xXC3N5XuRJqWIF3w420ZIQy16PyvRQ==
ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass
smtp.mailfrom=cornell.edu; dmarc=pass action=none header.from=cornell.edu;
dkim=pass header.d=cornell.edu; arc=none
Subject: Re: Unix Domain Socket Limitation?
To: cygwin <cygwin AT cygwin DOT com>
References: <71490665-31b0-f63c-74da-461a053fac21 AT huarp DOT harvard DOT edu>
<55ea1649-1979-6238-75ab-69100c22e069 AT cornell DOT edu>
<4260ad1b-4ab2-fa36-fd0e-7c9644560114 AT huarp DOT harvard DOT edu>
<38a82f82-1ef9-768e-7d3e-15f63147e188 AT cornell DOT edu>
<a1f6e9af-7c0b-4d3f-4198-1c7bff4869dc AT huarp DOT harvard DOT edu>
Message-ID: <16165727-f614-1543-70bc-36457ddbf260@cornell.edu>
Date: Mon, 30 Nov 2020 13:14:52 -0500
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101
Thunderbird/78.5.0
In-Reply-To: <a1f6e9af-7c0b-4d3f-4198-1c7bff4869dc@huarp.harvard.edu>
X-Originating-IP: [68.175.129.7]
X-ClientProxiedBy: BL1PR13CA0310.namprd13.prod.outlook.com
(2603:10b6:208:2c1::15) To MN2PR04MB6176.namprd04.prod.outlook.com
(2603:10b6:208:e3::13)
MIME-Version: 1.0
X-MS-Exchange-MessageSentRepresentingType: 1
X-MS-PublicTrafficType: Email
X-MS-Office365-Filtering-Correlation-Id: de9bd580-7001-4002-4954-08d8955bd5a4
X-MS-TrafficTypeDiagnostic: MN2PR04MB6078:
X-Microsoft-Antispam-PRVS: <MN2PR04MB6078808572997D97CBD7AC47D8F50 AT MN2PR04MB6078 DOT namprd04 DOT prod DOT outlook DOT com>
X-MS-Oob-TLC-OOBClassifiers: OLM:9508;
X-MS-Exchange-SenderADCheck: 1
X-Microsoft-Antispam: BCL:0;
X-Microsoft-Antispam-Message-Info: kqx2BZYGdOvrE4GEknWs7sjz3IseVCA/Uuv+F9CTGkiyEdweEMrEpKFAYVbdEmr5KqStx+dF3csvy8nrEOxZxtsQD+pEgOWiJX341l1qej0TDAjDRoK0XBY7sPXqNLt5b7u9cPAyqaxRFvh3T2DG4QtsYTnFr+eEX1Khr6WSw3Bwd5YXWWUepF8kIlGh3Z+EglBTROHNFx1nE4tVZtbFqFrNJSqwPEWB53dwOs7nGsf6ZVO/uZvbB/hEKxVQgE+m32+t/Z8B5KSxOln0P/wgTY/L5XcAdED/AWlo+bUPEfRMF5lJatzQBce4vZHs08+TCB8XlnLgSOoM9kA5lQYJ8ldrNzr7Sn9bgo2xeEjfI5Sa1P2/fZGsuCBPs98Yi8HWZ4MuOM3izl7xayj+q7zBo8e0A9q/zmGaLTr5p6oTi2WJuJ6dQAI8+qzlD+3dJFJJ3gmeMPn8CVHKReqtSfkt1Q==
X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:;
IPV:NLI; SFV:NSPM; H:MN2PR04MB6176.namprd04.prod.outlook.com; PTR:; CAT:NONE;
SFS:(4636009)(396003)(376002)(39860400002)(366004)(136003)(346002)(31696002)(66556008)(66476007)(5660300002)(8936002)(26005)(53546011)(3480700007)(31686004)(16526019)(6486002)(8676002)(2906002)(16576012)(316002)(83380400001)(52116002)(2616005)(36756003)(86362001)(478600001)(4326008)(66946007)(786003)(186003)(966005)(6916009)(75432002)(956004)(43740500002);
DIR:OUT; SFP:1102;
X-MS-Exchange-AntiSpam-MessageData: =?Windows-1252?Q?QWYv+E0+elkR35L5KxdUN4CPf2CG2LAO+6bahRi9U3eiX6vookwLq3WJ?=
=?Windows-1252?Q?bKDfSZyzO3/lr+KXxuXp3nZuw1OIB65fHUrJIB+DwUJ2WqMyO+d2mMYJ?=
=?Windows-1252?Q?0mtITBrRYCIBzuBGjzWAUkJw2M4b6ZigY9BvRULp6esgitqssQvJh1+e?=
=?Windows-1252?Q?nivRHczs2Dk33EB5MdkFPm4NWiDeWjjBMf5TJgCi1v1z+ODGPcf4kehO?=
=?Windows-1252?Q?vcZ3UyxOnaOm2tI5I3auwq9lmf7yso6PZIUN5jYMMI0zLJmpNd+esquc?=
=?Windows-1252?Q?OZgHBINom/kS/MmtmfIJIqv5BTKTgYc2kp8MRoqmFsIqe+rnVuTNI6Zq?=
=?Windows-1252?Q?SWQSGuv5LNcQfzZhIGnbQoJenohI53GIApnQkhBOZwLmCkM+IkAgUzSx?=
=?Windows-1252?Q?1h9RJZamjGO2hyo3Z7UOmEGZu9QR/yO11CacD+OozjSsFzVOwuABQ8oc?=
=?Windows-1252?Q?UlrPZl6k1207HmowfIvJnwCj9eQat60s9dMIXiLx9M7PSAE3+v1w1ngy?=
=?Windows-1252?Q?if4b+5kSpLJ82QMPyOjfMrGRxlGPCf/k9+qxqa14scO4J5TLJaiy6DEC?=
=?Windows-1252?Q?Kg+xpgvu8r09CuIMs3IF9ZIbcD5iv6afCi19v6ZyIMRBEITNhy0nSyGh?=
=?Windows-1252?Q?JJfnm+5n3+xLIVuePJ6ycwoL9ZsFP9lWAUdsRwd3F6d4byMMI0nsnIaL?=
=?Windows-1252?Q?T+NXOgf4B/cQkMzFW8phnrR/VTpXqHPH/17vhzNIt0Nc5UMjUJju8FU8?=
=?Windows-1252?Q?O9Gi+WqITct20IqeeA6pqixDrQ4e9jMHX256o0NmMEZsY5OrnaEMRe4u?=
=?Windows-1252?Q?joOldMzEN3dZcg3fM16+R4qRZGD2qxSQPUy7R6zqvYR0pzDZEKnzfO/n?=
=?Windows-1252?Q?xwItfjM3KNDK2rEeh8u3J/XWwLXsq5Pe74xL1xUc8y5YJHAJ5KU7NU2q?=
=?Windows-1252?Q?VR3eHBTKrs2KSeZ9xFaihJlTYKCrqP7R1qrS7cGp30LxwI6rXGDi8RIX?=
=?Windows-1252?Q?/2Iw358WXhSsSZ2XjRpxdOHF6XyHnEq3iNG4yfOk1vVdimsIcDY=3D?=
X-OriginatorOrg: cornell.edu
X-MS-Exchange-CrossTenant-Network-Message-Id: de9bd580-7001-4002-4954-08d8955bd5a4
X-MS-Exchange-CrossTenant-AuthSource: MN2PR04MB6176.namprd04.prod.outlook.com
X-MS-Exchange-CrossTenant-AuthAs: Internal
X-MS-Exchange-CrossTenant-OriginalArrivalTime: 30 Nov 2020 18:14:53.2960 (UTC)
X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted
X-MS-Exchange-CrossTenant-Id: 5d7e4366-1b9b-45cf-8e79-b14b27df46e1
X-MS-Exchange-CrossTenant-MailboxType: HOSTED
X-MS-Exchange-CrossTenant-UserPrincipalName: thqiaSv635xWn2MvjLNxykSPvDB+DP62IYlvBHPa38TP+w5n6gh4KH8vg6ZBRgrq5RIpqWhl67fJDHJwNZpKEQ==
X-MS-Exchange-Transport-CrossTenantHeadersStamped: MN2PR04MB6078
X-Spam-Status: No, score=-0.2 required=5.0 tests=BAYES_00, DKIM_INVALID,
DKIM_SIGNED, KAM_DMARC_STATUS, MSGID_FROM_MTA_HEADER, NICE_REPLY_A,
RCVD_IN_DNSWL_NONE, RCVD_IN_MSPIKE_H2, SPF_HELO_PASS, SPF_PASS,
TXREP autolearn=no autolearn_force=no version=3.4.2
X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on
server2.sourceware.org
X-BeenThere: cygwin AT cygwin DOT com
X-Mailman-Version: 2.1.29
List-Id: General Cygwin discussions and problem reports <cygwin.cygwin.com>
List-Unsubscribe: <https://cygwin.com/mailman/options/cygwin>,
<mailto:cygwin-request AT cygwin DOT com?subject=unsubscribe>
List-Archive: <https://cygwin.com/pipermail/cygwin/>
List-Post: <mailto:cygwin AT cygwin DOT com>
List-Help: <mailto:cygwin-request AT cygwin DOT com?subject=help>
List-Subscribe: <https://cygwin.com/mailman/listinfo/cygwin>,
<mailto:cygwin-request AT cygwin DOT com?subject=subscribe>
From: Ken Brown via Cygwin <cygwin AT cygwin DOT com>
Reply-To: Ken Brown <kbrown AT cornell DOT edu>
Errors-To: cygwin-bounces AT cygwin DOT com
Sender: "Cygwin" <cygwin-bounces AT cygwin DOT com>
X-MIME-Autoconverted: from quoted-printable to 8bit by delorie.com id 0AUIFMbX012086

On 11/30/2020 12:19 PM, Norton Allen wrote:
> On 11/26/2020 12:13 PM, Ken Brown wrote:
>> [Adding the Cygwin list back to the Cc.]
>>
>> On 11/26/2020 11:27 AM, Norton Allen wrote:
>>> On 11/25/2020 5:27 PM, Ken Brown via Cygwin wrote:
>>>> On 11/25/2020 4:47 PM, Norton Allen wrote:
>>>>> In my recent tests, it appears as though it is not possible to successfully 
>>>>> connect via two Unix Domain sockets from one client application to one 
>>>>> server application.
>>>>>
>>>>> Specifically, if I create a server which listens on a Unix Domain socket 
>>>>> and a client, which attempts to connect() twice, both seem to lock up. This 
>>>>> is not the behavior under Linux.
>>>>>
>>>>> I will be happy to work up a minimal example if it is helpful in tracking 
>>>>> this down. I wanted to start by asking whether this is a known limitation 
>>>>> and/or if there is something about the Cygwin implementation that makes 
>>>>> this sort of thing very difficult.
>>>>
>>>> A minimal example would be extremely helpful.
>>>>
>>>> Corinna can answer questions about limitations in the current 
>>>> implementation. But there is a new implementation under development. It's in 
>>>> the topic/af_unix branch of the Cygwin git repository if you're interested 
>>>> in looking at it.
>>>>
>>>> Corinna began working on this a couple years ago, and I've recently been 
>>>> trying to finish it.  I've made quite a bit of progress, but there's still 
>>>> more to do and undoubtedly many bugs. So any test cases you have would be 
>>>> very useful. 
>>>
>>> Thanks Ken,
>>>
>>> As it happens, attempting to produce a minimal example suggests my problem 
>>> may be somewhere else. I think I've worked in most of the features of my 
>>> application one by one but have not yet revealed a failure.
>>
>> OK.  But if you ever do have occasion to write small test programs involving 
>> AF_UNIX sockets, please send them on.  The new AF_UNIX code needs as much 
>> testing as it can get.
>>
> I have finally put together a start of a minimal example, although it seems to 
> require a certain level of complexity before tripping on the bug. At the moment, 
> I do not believe the issue is related to having multiple sockets between the 
> client and server. I am thinking it is some sort of race condition related to 
> non-blocking sockets, since I have only observed it when both the client and 
> server are using non-blocking sockets.
> 
> I have yet to plunge into cygwin.dll, but I think I have reached that point.
> 
> Here is the code: https://github.com/nthallen/cygwin_unix
> 
> Since I have only exercised this on my machine, I would be very interested to 
> know if it is reproducible on anyone else's.

I can reproduce the hang, and it happens if I use the new AF_UNIX code also. 
But what I'm seeing (at least with the new code) isn't exactly what you describe.

When the server's first select call returns, accept succeeds.  The server then 
calls select a second time, and that call doesn't return.  I haven't checked yet 
to see what's going on in the client, and I may not get to that for a while.

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

- Raw text -


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