delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2015/09/07/08:28:57

X-Recipient: archive-cygwin AT delorie DOT com
DomainKey-Signature: a=rsa-sha1; c=nofws; d=sourceware.org; h=list-id
:list-unsubscribe:list-subscribe:list-archive:list-post
:list-help:sender:date:from:to:subject:message-id:reply-to
:references:mime-version:content-type:in-reply-to; q=dns; s=
default; b=LgdUFgFTDW1UNdNDF6Syf9u10WYdwo37uefVXilYSCTN5mXUKX/ju
amy9A/BPXjalNA0ZOLc+EKZJGsCcnFYEJ8UtY+utikw11jJMu1nFJ6oxcaF213/h
1jdinYCcWh/1Jx95aON0jLg6UtSLu7hiJiuaQwXcUFCZrhcNbKEOzc=
DKIM-Signature: v=1; a=rsa-sha1; c=relaxed; d=sourceware.org; h=list-id
:list-unsubscribe:list-subscribe:list-archive:list-post
:list-help:sender:date:from:to:subject:message-id:reply-to
:references:mime-version:content-type:in-reply-to; s=default;
bh=T1fldkb43Mvylx4eIis9u7YbqHA=; b=jpdKUyp3O/U+wWDwx1Eem+acj+uD
IOH90hPRMDDWsVnRRkGmS5g7ietwNVdnF2Fe2sRC3QIvjZjg/SN4+jAk/xlVDErr
TLvv2l8flULCrjrgCmzLZZoyuxg5HL0ZgNBp7gMf65y82Y4ayqKefMm9VfwRrMt7
HKeQLWVlPtgFJzk=
Mailing-List: contact cygwin-help AT cygwin DOT com; run by ezmlm
List-Id: <cygwin.cygwin.com>
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
Authentication-Results: sourceware.org; auth=none
X-Virus-Found: No
X-Spam-SWARE-Status: No, score=-4.5 required=5.0 tests=AWL,BAYES_20,KAM_LAZY_DOMAIN_SECURITY autolearn=no version=3.3.2
X-HELO: calimero.vinschen.de
Date: Mon, 7 Sep 2015 14:28:36 +0200
From: Corinna Vinschen <corinna-cygwin AT cygwin DOT com>
To: cygwin AT cygwin DOT com
Subject: Re: [OT] Wine + Cygwin: `script -e` exit status forwarding randomly return zero for non zero child process
Message-ID: <20150907122836.GB20288@calimero.vinschen.de>
Reply-To: cygwin AT cygwin DOT com
Mail-Followup-To: cygwin AT cygwin DOT com
References: <CALd+sZS6eHn8tUxCzB-JhGkfn2FUzg5dNKHwcY+ryBT-o=2DFw AT mail DOT gmail DOT com> <20150903105549 DOT GT23669 AT calimero DOT vinschen DOT de> <CALd+sZRO9LbvQcQZ4PVf9Ge1e5Gu0kKTQkucm=YC68ENdkNNAA AT mail DOT gmail DOT com>
MIME-Version: 1.0
In-Reply-To: <CALd+sZRO9LbvQcQZ4PVf9Ge1e5Gu0kKTQkucm=YC68ENdkNNAA@mail.gmail.com>
User-Agent: Mutt/1.5.23 (2014-03-12)

--CdrF4e02JqNVZeln
Content-Type: text/plain; charset=utf-8
Content-Disposition: inline
Content-Transfer-Encoding: quoted-printable

On Sep  7 19:02, Qian Hong wrote:
> Hi Corinna,
>=20
> Sorry for delay, our progress on this issue is slow.
>=20
> Many thanks for your great information, it does help us became closer
> to the reason.
>=20
> On Thu, Sep 3, 2015 at 6:55 PM, Corinna Vinschen
> <corinna-cygwin AT cygwin DOT com> wrote:
> > Comparing the straces, two interesting facts are conspicuous:
> > - After the forked script returned, what happens in the parent is absol=
utly
> >   identical in both cases, up to a point during exit.  This point is re=
ached
> >   with line 1573 in the "bad" case and line 1580 in the "good" case.  T=
hen
> >   "something" happens:
> >
>=20
> Thanks for the analysis, this does help us realized it should be a
> very low level issue, in a level I wasn't doubt about.
> [...]
> >    To me this looks like the "bad" script has been exited forcefully
> >    for some reason.
> >
>=20
> Yeah, this is the hard part. Sebastian has some progress on it, I
> quote his note here:
>=20
> =3D=3D=3D quote =3D=3D=3D
>=20
> Cygwin tries to forcibly kill a thread, the implementation for that is
> available here:
> https://github.com/Alexpux/Cygwin/blob/79511853f788111efd975651f87eabbd4a=
8cbf6d/winsup/cygwin/cygthread.cc#L296

Guys, no offense meant, but I'd really appreciate if you could peruse
and refer to the original upstream Cygwin repo at

https://sourceware.org/git/?p=3Dnewlib-cygwin.git

This is what we're talking about in the first place so I'd like to stick
to this, ok?

> Excerpt from the log with annotations:
>=20
> --- snip ---
> 0027:Call KERNEL32.TerminateThread(00000168,00000000) ret=3D610055ca
> 0027: terminate_thread( handle=3D0168, exit_code=3D0 )
> 0027: terminate_thread() =3D 0 { self=3D0, last=3D0 }
> 0027:Ret  KERNEL32.TerminateThread() retval=3D00000001 ret=3D610055ca
> // handle 00000168 corresponds to thread 0x0029
>=20
> 0027:Call KERNEL32.WaitForSingleObject(00000168,ffffffff) ret=3D610055e0
> 0027: select( flags=3D2, cookie=3D0060ba6c, timeout=3Dinfinite,
> prev_apc=3D0000, result=3D{}, data=3D{WAIT,handles=3D{0168}} )
> 0027: select() =3D 0 { timeout=3Dinfinite, call=3D{APC_NONE}, apc_handle=
=3D0000 }
> 0027:Ret  KERNEL32.WaitForSingleObject() retval=3D00000000 ret=3D610055e0
> // WaitForSingleObject doesn't block, so cygwin assumes the thread is gone
>=20
> [...]
>=20
> 0027:Call KERNEL32.VirtualFree(00a10000,00000000,00008000) ret=3D61005767
> // Cygwin tries to release the thread stack

Ah, ok.  What OS does Wine emulate here?  Have a look at
https://sourceware.org/git/?p=3Dnewlib-cygwin.git;a=3Dblob;f=3Dwinsup/cygwi=
n/cygthread.cc;h=3De48a73e545e7ca90884fc891f1b188e0ab3bf863;hb=3DHEAD#l316

The terminate_thread_frees_stack flag is set to false for XP/2003 and to
true for any newer OS.  I guess this is a double-free because Wine's
TerminateThread already freed the stack and Cygwin got the info it's
supposedly running under XP/2003, so it tries to workaround the fact
that TerminateThread on these systems didn't free the stack by themselves.

> As a workaround NtFreeVirtualMemory can be replaced with a no-op
> implementation returning STATUS_SUCCESS.

I don't think this is the right thing to do.  It's a hack covering
the problem that TerminateThread should not free the thread stack
if we're running an XP/2003 emulation.

If my assumption here is incorrect, we need to know what address
ret=3D61005767 is refering to.  addr2line would help.


Corinna

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

--CdrF4e02JqNVZeln
Content-Type: application/pgp-signature

-----BEGIN PGP SIGNATURE-----
Version: GnuPG v2

iQIcBAEBCAAGBQJV7YL0AAoJEPU2Bp2uRE+gwEUQAIBR1UhBUtLQTuqeBEox0uVS
NVnqJ7N5/dw08XqkUSuuDjlVl5R8TU2fqafagCgNyLPiEUw98hu/um68X9tzK+Jq
8qJgjutqqOFcqQGSvxgLFt0w2XyK3WnRzFG40sqiyEu2b397nYpAprTCeN7XbgdC
b8SPWn0ux/0Ow8wbHGSqUDi2+iMeCiG94Tgtt2yK/piRaeAgKEYpPwzm+JWCfNmd
I9LdYaWH7pzc2sSB3mxk9XTkiPjIH5dfqrKv2Z1ShhkRF4Sa/CRT1+d0DYUei44Q
RJ636Bys/dUSBxnKk9ckFc/BmRquB3ypzhfuRuJGMlfYxRE2AfnQXMVt/9ebZdjo
wxyOGD1LB+H8sWknnnq6a605cdEmaCr2De7SNfMLUNMhKj7pfiLP5aOfGOaWd/h4
y92m/oMt06/c0lTHSMZNX1wLpYb01FfOj674w3Kyzp10L3qUU2GiQXNDRHGIzWgJ
8IZ59hs9HAPIquVCEOcusONp4M7Yit/uCw6KOK0ckyOGYUz/4d72LuzRm2s7w1ve
yQsKH6N6xCPe3ASRHU9l+B4fpJ2/Tw8r/rMmgPf+qh+3mf1eAB/Ta+IiQ05RI5ly
//53BkI8JTA0Y0euIUwxC+/0+3ej1e+Hqof6ylCcKPgjawH5PUoWVTvpmDAtM++1
FyjaBHES+/GhW+fNZRnE
=hAT3
-----END PGP SIGNATURE-----

--CdrF4e02JqNVZeln--

- Raw text -


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