delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2004/07/08/11:24:25

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
X-Authentication-Warning: slinky.cs.nyu.edu: pechtcha owned process doing -bs
Date: Thu, 8 Jul 2004 11:23:41 -0400 (EDT)
From: Igor Pechtchanski <pechtcha AT cs DOT nyu DOT edu>
Reply-To: cygwin AT cygwin DOT com
To: cygwin AT cygwin DOT com
Subject: Re: negative error status: gcc vs. cl
In-Reply-To: <20040708145452.GA14402@trixie.casa.cgf.cx>
Message-ID: <Pine.GSO.4.58.0407081119210.11665@slinky.cs.nyu.edu>
References: <Pine DOT WNT DOT 4 DOT 21 DOT 0407081106020 DOT 247-100000 AT pc0197 DOT nagra-kudelski DOT ch> <20040708100919 DOT GB32001 AT cygbert DOT vinschen DOT de> <Pine DOT GSO DOT 4 DOT 58 DOT 0407081018370 DOT 11665 AT slinky DOT cs DOT nyu DOT edu> <20040708145452 DOT GA14402 AT trixie DOT casa DOT cgf DOT cx>
MIME-Version: 1.0
X-Scanned-By: MIMEDefang 2.39

On Thu, 8 Jul 2004, Christopher Faylor wrote:

> On Thu, Jul 08, 2004 at 10:25:09AM -0400, Igor Pechtchanski wrote:
> >On Thu, 8 Jul 2004, Corinna Vinschen wrote:
> >
> >> On Jul  8 11:49, Daniel Lungu wrote:
> >> > Feel like bash tcsh on Cygwin mess up with negative exit status
> >> > from a cl compiled .exe
              ^^^^^^^^^^^^^^^^
> >> The answer is "don't do that".  Use positive values in the range from
> >> 0 to 255.  See
> >> http://www.opengroup.org/onlinepubs/009695399/functions/exit.html
> >
> >Actually, it looks like another buglet in Cygwin.  The code in
> >spawn_guts() in spawn.cc (line 847 in CVS HEAD) simply binary-ORs the
> >exitcode value returned by GetExitCodeProcess with the "res" variable.
> >However, the "res" variable is also used to carry some flags, and a
> >negative exitcode, being a full DWORD, accidentally sets those, so all
> >sorts of havoc can potentially occur (and I'm surprised that all that
> >happens is the wrong exit code).
>
> This is not a bug.  A cygwin program can't set a negative exit code.
> Only the lower order 16 bits are used.  This is enforced by _exit.
>
> If someone uses ExitProcess in a cygwin program, then well, err...
> cgf

You would be right if spawn() could only be used for Cygwin programs.
Unfortunately, it can also be used for non-Cygwin programs (as shown by
the underlined phrase above) which don't operate under the above
restriction.  So, I'd say that binary-ANDing the exitcode value with 0xFF
(or 0xFFFF if you want 16 bits) is a healthy precaution.  It will
certainly do no harm, and it will make absolutely sure that the other
flags (e.g., EXIT_REPARENTING) are never tread upon.
	Igor
-- 
				http://cs.nyu.edu/~pechtcha/
      |\      _,,,---,,_		pechtcha AT cs DOT nyu DOT edu
ZZZzz /,`.-'`'    -.  ;-;;,_		igor AT watson DOT ibm DOT com
     |,4-  ) )-,_. ,\ (  `'-'		Igor Pechtchanski, Ph.D.
    '---''(_/--'  `-'\_) fL	a.k.a JaguaR-R-R-r-r-r-.-.-.  Meow!

"I have since come to realize that being between your mentor and his route
to the bathroom is a major career booster."  -- Patrick Naughton

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