delorie.com/archives/browse.cgi   search  
Mail Archives: cygwin/2005/05/02/23:34: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://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
Date: Mon, 2 May 2005 23:33:59 -0400
From: Christopher Faylor <cgf-no-personal-reply-please AT cygwin DOT com>
To: cygwin AT cygwin DOT com
Subject: Re: execvp error:cygwin+make+busybox
Message-ID: <20050503033359.GB8959@trixie.casa.cgf.cx>
Reply-To: cygwin AT cygwin DOT com
References: <4276C831 DOT 7000906 AT itee DOT uq DOT edu DOT au>
Mime-Version: 1.0
In-Reply-To: <4276C831.7000906@itee.uq.edu.au>
User-Agent: Mutt/1.5.8i

On Tue, May 03, 2005 at 10:39:13AM +1000, John Williams wrote:
>Attempting to cross-compile Busybox 1.00 under Cygwin (1.5.16-1) I am 
>hitting an error similar to one previously reported on the Cygwin list 
>(Jan 05):
>
>http://www.cygwin.com/ml/cygwin/2005-01/msg00657.html
>
>No resolution was posted to the list at that time.
>
>The busybox Makefile attempts to run the host CC (gcc in this case) to 
>build some setup/config tools, as well as spawning a shell script to do 
>a bit of preparatory work.  This is before any cross-compiling begins.
>
>Make reports the following error:
>
>gcc -Wall -Wstrict-prototypes -O2 -fomit-frame-pointer -o scripts/mkdep 
>/cygdrive/e/cygwin-uclinux/uClinux-dist/user/busybox/scripts/mkdep.c
>make[3]: execvp: gcc: Invalid argument
>make[3]: *** [scripts/mkdep] Error 127
>
>The problem occurs with Make versions 3.79.1 and 3.80 (haven't tested 
>any earlier versions)
>
>The Makefile fragment which fails looks like this:
>
>scripts/mkdep: $(top_srcdir)/scripts/mkdep.c
>        $(HOSTCC) $(HOSTCFLAGS) -o $@ $<
>
>HOSTCC and HOSTCFLAGS can be deduced from above output, but there's 
>nothing exotic in there.
>
>Another fragment which fails is this:
>
>.config.mkconfig: $(ROOTDIR)/config/.config
>        sh ./mkconfig > .config.tmp
>
>This fragment fails with:
>make[3]: execvp: sh: Invalid argument
>
>If executed directly from the commandline, these commands complete fine 
>- it's only when spawning from within the Makefile.
>
>cygcheck output is attached.
>
>Any insights into the nature and possible solution of this problem would 
>be greatly appreciated.

IIRC, I also had this problem on Cygwin until I deleted the
.EXPORT_ALL_VARIABLES from Rules.mak.  I have a specialized build
environment so it is possible that there are other things required to
get things working after that, but this was the culprit which caused
these problems.

Another work around is to do this:

mount -X -b -f c:\cygwin\bin /bin
mount -X -b -f c:\cygwin\bin /usr/bin
mount -x -b -f c:\cygwin\bin\strace.exe /usr/bin/strace.exe
mount -x -b -f c:\cygwin\bin\strace.exe /bin/strace.exe
mount -x -b -f c:\cygwin\bin\cygcheck.exe /usr/bin/cygcheck.exe
mount -x -b -f c:\cygwin\bin\cygcheck.exe /bin/cygcheck.exe

Mounting your /bin directory with the -X flag will make cygwin bypass
the windows mechanism for passing environment variables to subprocesses.
The errors that you are seeing are coming from environment table
overflow in in make due to every single Makefile variable being forced
into the environment.

cgf

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