bash configure: result from running a microsoft compiler was empty string
Vitaly Provodin
vitaly.provodin at jetbrains.com
Fri Apr 12 10:41:27 UTC 2019
Hello Erik,
I ran configure with this patch. Please note two ways launching WSL were exercised:
1. WSL (ubnutu in my case) was started from Command Prompt (%windir%\system32\cmd.exe)
in this way configure successfully completed
2. WSL was started directly (typed ubuntu in the search box and choose ubuntu on the top.)
in this way configure failed
I compared PATH in these two cases, they differ by the path /mnt/c/Users/vprovodin/.dnx/bin
The first one contained this path while the second one did not
All,
Then I found the causes of all my issues:
1) I had the old source snapshot of OpenJDK
2) Initially I built specifying jdk-11.0.2 as with-boot-jdk
After fetching recent sources it works well with the following cmds:
$ ./configure --with-boot-jdk=/mnt/c/Tools/Java/jdk-12 --with-toolchain-version=2017
$ make CONF=windows-x86_64-server-release images
Thanks to all
Vitaly
> On 10 Apr 2019, at 20:57, Erik Joelsson <erik.joelsson at oracle.com> wrote:
>
> Hello Vitaly,
>
> When configure fails recognize the version of CL it usually means that either CL didn't launch correctly or that a non English locale is used so we don't recognize the output. In this case, since the recorded output is empty, I'm guessing the former. The failing wslpath line could be a lead. Perhaps we fail to put together a functioning PATH variable when extracting the Visual Studio environment from vsvars*.bat.
>
> Could you try again with this patch so we can see what the PATH is set to?
>
> diff -r a84fefde0543 make/autoconf/toolchain.m4
> --- a/make/autoconf/toolchain.m4
> +++ b/make/autoconf/toolchain.m4
> @@ -357,6 +357,7 @@
> # for using basic Unix tools, so need to keep the original PATH.
> BASIC_APPEND_TO_PATH(PATH, $VS_PATH)
> BASIC_APPEND_TO_PATH(WSLENV, "PATH/l:LIB:INCLUDE")
> + $ECHO "PATH=$PATH"
> export WSLENV
> else
> # Reset path to VS_PATH. It will include everything that was on PATH at the time we
>
> /Erik
>
> On 2019-04-10 01:36, Vitaly Provodin wrote:
>> HI David, Andrew,
>>
>> Thanks for the reply
>>
>> I ran /mnt/c/Tools/VS/2017/Community/VC/Tools/MSVC/14.16.27023/bin/Hostx64/x64/cl.exe directly, it produced the following log:
>>
>> $ /mnt/c/Tools/VS/2017/Community/VC/Tools/MSVC/14.16.27023/bin/Hostx64/x64/cl.exe
>> Microsoft (R) C/C++ Optimizing Compiler Version 19.16.27030.1 for x64
>> Copyright (C) Microsoft Corporation. All rights reserved.
>>
>> usage: cl [ option... ] filename... [ /link linkoption… ]
>>
>>
>> Andrew,
>>
>> Thanks for providing me with the link to the actual doc. Now this command looks like:
>>
>> bash ./configure --with-boot-jdk=/mnt/c/Tools/Java/jdk-11.0.2 --with-toolchain-version=2017
>>
>> But the result the same :^(
>> Please note I ran it in the clean environment that means I did not set any env variables.
>>
>> Suspicious lines in log:
>> checking for Boot JDK... /mnt/c/Tools/Java/jdk-11.0.2
>> checking Boot JDK version... java version "11.0.2" 2019-01-15 LTS Java(TM) SE Runtime Environment 18.9 (build 11.0.2+9-LTS) Java HotSpot(TM) 64-Bit Server VM 18.9 (build 11.0.2+9-LTS, mixed mode)
>> checking for java.exe in Boot JDK... ok
>> checking for javac.exe in Boot JDK... ok
>> checking for javadoc.exe in Boot JDK... ok
>> checking for jar.exe in Boot JDK... ok
>> checking for jarsigner.exe in Boot JDK... ok
>> checking if Boot JDK is 32 or 64 bits... 64
>> checking for local Boot JDK Class Data Sharing (CDS)... no, creation failed
>>
>> Not sure whether it can be ignored that CDS creation failed
>> more log
>>
>> configure: Rewriting path to "/mnt/c/Windows/System32/OpenSSH"
>> configure: Rewriting path to "/mnt/c/cygwin64/bin"
>> /bin/wslpath: C:\WINDOWS\system32\config\systemprofile\.dnx\bin: Permission denied
>> configure: Rewriting path to "/mnt/c/PROGRA~1/MICROS~2/Dnvm"
>>
>> and at the end
>>
>> configure: Will use user supplied compiler CC=/mnt/c/Tools/VS/2017/Community/VC/Tools/MSVC/14.16.27023/bin/Hostx64/x64/cl.exe
>> checking resolved symbolic links for CC... no symlink
>> configure: The C compiler (located as /mnt/c/Tools/VS/2017/Community/VC/Tools/MSVC/14.16.27023/bin/Hostx64/x64/cl.exe) does not seem to be the required microsoft compiler.
>> configure: The result from running it was: ""
>> configure: error: A microsoft compiler is required. Try setting --with-tools-dir.
>> configure exiting with result code 1
>>
>> Thanks,
>> Vitaly
>>
>>> On 10 Apr 2019, at 13:32, Andrew Luo <andrewluotechnologies at outlook.com> wrote:
>>>
>>> Hi Vitaly,
>>>
>>> Those instructions are out of date, just my original proposed patch. What we eventually ended up committing is much simpler.
>>>
>>> See http://hg.openjdk.java.net/jdk/jdk/file/72f05350b4b3/doc/building.md for the latest instructions.
>>>
>>> Thanks,
>>>
>>> -Andrew
>>>
>>> -----Original Message-----
>>> From: build-dev <build-dev-bounces at openjdk.java.net> On Behalf Of David Holmes
>>> Sent: Tuesday, April 9, 2019 10:25 PM
>>> To: Vitaly Provodin <vitaly.provodin at jetbrains.com>; build-dev at openjdk.java.net
>>> Subject: Re: bash configure: result from running a microsoft compiler was empty string
>>>
>>> Hi Vitaly,
>>>
>>> What do you see if you run:
>>>
>>> /mnt/c/Tools/VS/2017/Community/VC/Tools/MSVC/14.16.27023/bin/Hostx64/x64/cl.exe
>>>
>>> directly?
>>>
>>> Cheers,
>>> David
>>>
>>> On 10/04/2019 1:35 pm, Vitaly Provodin wrote:
>>>> Hello,
>>>>
>>>> I'm trying to compile OpenJDK 13 (using WSL and following this instructions http://mail.openjdk.java.net/pipermail/build-dev/2018-December/024316.html <http://mail.openjdk.java.net/pipermail/build-dev/2018-December/024316.html>), but when I use:
>>>>
>>>> $ bash ./configure --with-boot-jdk=/mnt/c/Tools/Java/jdk-11.0.2 \
>>>> --with-tools-dir="C:\Tools\VS\2017\Community\VC\Auxiliary" \
>>>> --with-ucrt-dll-dir="C:\Tools\WindowsKits\10\bin\10.0.17763.0\x64\ucrt”
>>>>
>>>> it fail, with the following message:
>>>>
>>>> . . .
>>>> configure: Will use user supplied compiler
>>>> CC=/mnt/c/Tools/VS/2017/Community/VC/Tools/MSVC/14.16.27023/bin/Hostx6
>>>> 4/x64/cl.exe checking resolved symbolic links for CC... no symlink
>>>> configure: The C compiler (located as /mnt/c/Tools/VS/2017/Community/VC/Tools/MSVC/14.16.27023/bin/Hostx64/x64/cl.exe) does not seem to be the required microsoft compiler.
>>>> configure: The result from running it was: ""
>>>> configure: error: A microsoft compiler is required. Try setting --with-tools-dir.
>>>> configure exiting with result code 1
>>>>
>>>> It looks like the cause of this failure is in the empty string
>>>>
>>>> configure: The result from running it was: “"
>>>>
>>>> Please note I tried the following
>>>> - to run vcvars64.bat then start WSL (ubuntu)
>>>> - just start WSL (ubuntu) wiothout vcvars64.bat anyway I got the above
>>>> message.
>>>>
>>>> I'm using windows 10 64 bits
>>>>
>>>> Could you please give me advice what I should do?
>>>>
>>>> Thank you,
>>>> Vitaly
>>>>
More information about the build-dev
mailing list