From 269d02cf5b3c906954bbba944fc9d5918fa1ad75 Mon Sep 17 00:00:00 2001 From: lateralusX Date: Tue, 6 Nov 2018 16:23:56 +0100 Subject: [PATCH] =?utf8?q?Add=20support=20for=20LLVM=20integrated=20build?= =?utf8?q?=20as=20part=20of=20Visual=20Studio=20solution=20build.=20LLVM?= =?utf8?q?=20build=20follows=20similar=20pattern=20as=20BTLS=20build=20and?= =?utf8?q?=20will=20be=20build=20as=20part=20of=20regular=20Visual=20Studi?= =?utf8?q?o=20build=20Mono=20runtime=20if=20LLVM=20has=20been=20enabled=20?= =?utf8?q?through=20the=20autogen.sh,=20--enable-llvm=20or=20=E2=80=93with?= =?utf8?q?-llvm=20argument.=20It=20is=20also=20supports=20msbuild=20proper?= =?utf8?q?ties=20MONO=5FENABLE=5FLLVM,=20MONO=5FEXTERNAL=5FLLVM=5FCONFIG,?= =?utf8?q?=20if=20Visual=20Studio=20Mono=20runtime=20has=20been=20built=20?= =?utf8?q?without=20using=20autogen.sh.=20When=20just=20using=20=E2=80=93e?= =?utf8?q?nable-llvm,=20LLVM=20build=20will=20try=20to=20build=20internal?= =?utf8?q?=20LLVM=20branch=20under=20external/llvm=20or=20if=20override=20?= =?utf8?q?has=20been=20set=20in=20props=20file=20(using=20MONO=5FINTERNAL?= =?utf8?q?=5FLLVM=5FSOURCE=5FDIR),=20an=20alternative=20LLVM=20source=20di?= =?utf8?q?rectory=20path.=20If=20=E2=80=93with-llvm=20has=20been=20used=20?= =?utf8?q?pointing=20to=20an=20llvm-config.exe,=20no=20internal=20LLVM=20w?= =?utf8?q?ill=20be=20build,=20but=20the=20external=20LLVM=20build=20will?= =?utf8?q?=20be=20used.=20Needed=20LLVM=20executables=20(opt.exe,=20llc.ex?= =?utf8?q?e)=20will=20be=20installed=20into=20regular=20Visual=20Studio=20?= =?utf8?q?Mono=20runtime=20build=20output=20directory.?= MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit The internal Mono LLVM 6.0 release will build as part of changes to this commit, but it has not yet been fixed to work as expected during runtime. That work will be done in different commit. The Mono LLVM 3.6 branch will however work as expected for Windows x64 and can be setup and used using –with-llvm argument or build as part of Visual Studio build Mono runtime by enabling msbuild properties, MONO_ENABLE_LLVM and MONO_INTERNAL_LLVM_SOURCE_DIR. --- msvc/build-external-btls.vcxproj | 16 +- msvc/build-external-llvm.bat | 383 +++++++++++++++++++++ ...al-btls.vcxproj => build-external-llvm.vcxproj} | 40 +-- msvc/build-init.vcxproj | 30 +- msvc/libmini-llvm.targets | 5 + msvc/libmini.vcxproj | 58 +++- msvc/libmono-dynamic.vcxproj | 50 ++- msvc/libmonodac.vcxproj | 2 - msvc/mono.external.targets | 220 ++++++++++++ msvc/mono.props | 20 +- msvc/mono.sln | 15 + msvc/mono.vcxproj | 28 +- msvc/winsetup.bat | 13 +- winconfig.h | 7 - 14 files changed, 764 insertions(+), 123 deletions(-) create mode 100644 msvc/build-external-llvm.bat copy msvc/{build-external-btls.vcxproj => build-external-llvm.vcxproj} (77%) create mode 100644 msvc/mono.external.targets diff --git a/msvc/build-external-btls.vcxproj b/msvc/build-external-btls.vcxproj index fbdd0a8f7c5..bbb2357067d 100644 --- a/msvc/build-external-btls.vcxproj +++ b/msvc/build-external-btls.vcxproj @@ -145,25 +145,15 @@ + <_BtlsCFlags Condition="'$(MONO_PREPROCESSOR_DEFINITIONS)' != ''">$(MONO_PREPROCESSOR_DEFINITIONS.Replace(";"," ")) <_BtlsCFlags>$(_BtlsCFlags.Trim()) <_BtlsCFlags Condition="'$(_BtlsCFlags)' != ''">-D$(_BtlsCFlags.Replace(" "," -D")) - <_BtlsBuildDir>$(MONO_BUILD_DIR_PREFIX)$(Platform)\obj\external\btls-build-shared\$(Configuration) <_BtlsBuildCommand>build-external-btls.bat "$(MONO_DIR)" "$(_BtlsBuildDir)" "$(OutDir)" "$(_BtlsCFlags)" "$(Platform)" "$(Configuration)" - <_BtlsCheckCommand>findstr /i /r /c:".*#define.*HAVE_BTLS.*1" $(MONO_DIR)/cygconfig.h >nul 2>&1 - - - - - - true - false - - @@ -174,6 +164,6 @@ - - + + \ No newline at end of file diff --git a/msvc/build-external-llvm.bat b/msvc/build-external-llvm.bat new file mode 100644 index 00000000000..508bc0a1810 --- /dev/null +++ b/msvc/build-external-llvm.bat @@ -0,0 +1,383 @@ +:: -------------------------------------------------- +:: Run full LLVM build using msvc toolchain and available cmake generator. +:: Script needs to be run from within a matching build environment, x86|x64. +:: When executed from withing Visual Studio build environment current +:: build environment will be inherited by script. +:: +:: %1 LLVM source root directory. +:: %2 LLVM build root directory. +:: %3 LLVM install root directory. +:: %4 Mono distribution root directory. +:: %5 VS CFLAGS. +:: %6 VS platform (Win32/x64) +:: %7 VS configuration (Debug/Release) +:: %8 VS target +:: %9 MsBuild bin path, if used. +:: -------------------------------------------------- + +@echo off +setlocal + +set TEMP_PATH=%PATH% +set BUILD_RESULT=1 + +set CL_BIN_NAME=cl.exe +set LINK_BIN_NAME=link.exe +set GIT_BIN_NAME=git.exe +set CMAKE_BIN_NAME=cmake.exe +set NINJA_BIN_NAME=ninja.exe +set PYTHON_BIN_NAME=python.exe + +set LLVM_DIR=%~1 +set LLVM_BUILD_DIR=%~2 +set LLVM_INSTALL_DIR=%~3 +set MONO_DIST_DIR=%~4 +set VS_CFLAGS=%~5 +set VS_PLATFORM=%~6 +set VS_CONFIGURATION=%~7 +set VS_TARGET=%~8 +set MSBUILD_BIN_PATH=%~9 + +:: Setup toolchain. +:: set GIT= +:: set CMAKE= +:: set NINJA= +set MSBUILD=%MSBUILD_BIN_PATH%msbuild.exe + +if "%LLVM_DIR%" == "" ( + echo Missing LLVM source directory argument. + goto ECHO_USAGE +) + +if "%LLVM_BUILD_DIR%" == "" ( + echo Missing LLVM build directory argument. + goto ECHO_USAGE +) + +if "%LLVM_INSTALL_DIR%" == "" ( + echo Missing LLVM install directory argument. + goto ECHO_USAGE +) + +if "%MONO_DIST_DIR%" == "" ( + echo Missing Mono dist directory argument. + goto ECHO_USAGE +) + +if "%VS_CFLAGS%" == "" ( + echo Missing CFLAGS argument. + goto ECHO_USAGE +) + +if "%VS_PLATFORM%" == "" ( + set VS_PLATFORM=x64 +) + +if "%VS_CONFIGURATION%" == "" ( + set VS_CONFIGURATION=Release +) + +if "%VS_TARGET%" == "" ( + set VS_TARGET=Build +) + +if not exist %LLVM_DIR% ( + echo Could not find "%LLVM_DIR%". + goto ON_ERROR +) + +set LLVM_CFLAGS=%VS_CFLAGS% +set LLVM_ARCH=x86_64 +if /i "%VS_PLATFORM%" == "win32" ( + set LLVM_ARCH=i386 +) + +:: Check if executed from VS2015/VS2017 build environment. +if "%VisualStudioVersion%" == "14.0" ( + goto ON_ENV_OK +) + +if "%VisualStudioVersion%" == "15.0" ( + goto ON_ENV_OK +) + +:: Executed outside VS2015/VS2017 build environment, try to locate Visual Studio C/C++ compiler and linker. +call :FIND_PROGRAM "" "%CL_BIN_NAME%" CL_PATH +if "%CL_PATH%" == "" ( + goto ON_ENV_WARNING +) + +call :FIND_PROGRAM "" "%LINK_BIN_NAME%" LINK_PATH +if "%LINK_PATH%" == "" ( + goto ON_ENV_WARNING +) + +goto ON_ENV_OK + +:ON_ENV_WARNING + +:: VS 2015. +set VC_VARS_ALL_FILE=%ProgramFiles(x86)%\Microsoft Visual Studio 14.0\VC\vcvarsall.bat +IF EXIST "%VC_VARS_ALL_FILE%" ( + echo For VS2015 builds, make sure to run this from within Visual Studio build or using "VS2015 x86|x64 Native Tools Command Prompt" command prompt. + echo Setup a "VS2015 x86|x64 Native Tools Command Prompt" command prompt by using "%VC_VARS_ALL_FILE% x86|amd64". +) + +:: VS 2017. +set VSWHERE_TOOLS_BIN=%ProgramFiles(x86)%\Microsoft Visual Studio\Installer\vswhere.exe +if exist "%VSWHERE_TOOLS_BIN%" ( + echo For VS2017 builds, make sure to run this from within Visual Studio build or using "x86|x64 Native Tools Command Prompt for VS2017" command prompt. + for /f "tokens=*" %%a IN ('"%VSWHERE_TOOLS_BIN%" -latest -property installationPath') do ( + echo Setup a "x86|x64 Native Tools Command Prompt for VS2017" command prompt by using "%%a\VC\Auxiliary\Build\vcvars32.bat|vcvars64.bat". + ) +) + +echo Could not detect Visual Studio build environment. You may experience build problems if wrong toolchain is auto detected. + +:ON_ENV_OK + +:: Setup all cmake related generator, tools and variables. +call :SETUP_CMAKE_ENVIRONMENT +if "%CMAKE%" == "" ( + echo Failed to located working %CMAKE_BIN_NAME%, needs to be accessible in PATH or set using CMAKE environment variable. + goto ON_ERROR +) + +if "%CMAKE_GENERATOR%" == "" ( + echo Failed to setup cmake generator. + goto ON_ERROR +) + +:: Check target. +if /i "%VS_TARGET%" == "build" ( + goto ON_BUILD_LLVM +) + +if /i "%VS_TARGET%" == "install" ( + goto ON_INSTALL_LLVM +) + +if /i "%VS_TARGET%" == "clean" ( + goto ON_CLEAN_LLVM +) + +:ON_BUILD_LLVM + +:: If not set by caller, check environment for working git.exe. +call :FIND_PROGRAM "%GIT%" "%GIT_BIN_NAME%" GIT +if "%GIT%" == "" ( + echo Failed to located working %GIT_BIN_NAME%, needs to be accessible in PATH or set using GIT environment variable. + goto ON_ERROR +) + +:: Make sure llvm submodule is up to date. +pushd +cd %LLVM_DIR% +echo Updating llvm submodule. +"%GIT%" submodule update --init +if not ERRORLEVEL == 0 ( + "%GIT%" submodule init + "%GIT%" submodule update + if not ERRORLEVEL == 0 ( + echo Git llvm submodules failed to updated. You may experience compilation problems if some submodules are out of date. + ) +) +popd + +if not exist "%LLVM_BUILD_DIR%" ( + mkdir "%LLVM_BUILD_DIR%" +) + +cd "%LLVM_BUILD_DIR%" + +:: Make sure cmake pick up msvc toolchain regardless of selected generator (Visual Studio|Ninja) +set CC=%CL_BIN_NAME% +set CXX=%CL_BIN_NAME% + +set CMAKE_GENERATOR_ARGS= +if /i "%CMAKE_GENERATOR%" == "ninja" ( + set CMAKE_GENERATOR_ARGS=-DCMAKE_BUILD_TYPE=%VS_CONFIGURATION% +) else ( + set CMAKE_GENERATOR_ARGS=-Thost=x64 +) + +:: Run cmake. +"%CMAKE%" ^ +-DCMAKE_INSTALL_PREFIX="%LLVM_INSTALL_DIR%" ^ +-DLLVM_TARGETS_TO_BUILD="X86" ^ +-DLLVM_BUILD_TESTS=Off ^ +-DLLVM_INCLUDE_TESTS=Off ^ +-DLLVM_BUILD_EXAMPLES=Off ^ +-DLLVM_INCLUDE_EXAMPLES=Off ^ +-DLLVM_TOOLS_TO_BUILD="opt;llc;llvm-config;llvm-dis;llvm-mc" ^ +-DLLVM_ENABLE_LIBXML2=Off ^ +-DCMAKE_SYSTEM_PROCESSOR="%LLVM_ARCH%" ^ +%CMAKE_GENERATOR_ARGS% ^ +-G "%CMAKE_GENERATOR%" ^ +"%LLVM_DIR%" + +if not ERRORLEVEL == 0 ( + goto ON_ERROR +) + +if /i "%CMAKE_GENERATOR%" == "ninja" ( + :: Build LLVM using ninja build system. + call "%NINJA%" -j4 || ( + goto ON_ERROR + ) +) else ( + :: Build LLVM using msbuild build system. + call "%MSBUILD%" llvm.sln /p:Configuration=%VS_CONFIGURATION% /p:Platform=%VS_PLATFORM% /t:%VS_TARGET% /m:4 || ( + goto ON_ERROR + ) +) + +:ON_INSTALL_LLVM + +:: Make sure build install folder exists. +if not exist "%LLVM_INSTALL_DIR%" ( + echo Could not find "%LLVM_INSTALL_DIR%", creating folder for build output. + mkdir "%LLVM_INSTALL_DIR%" +) + +:: Make sure Mono dist folder exists. +if not exist "%MONO_DIST_DIR%" ( + echo Could not find "%MONO_DIST_DIR%", creating folder for build output. + mkdir "%MONO_DIST_DIR%" +) + +if exist "%LLVM_BUILD_DIR%\build.ninja" ( + pushd + cd "%LLVM_BUILD_DIR%" + call "%NINJA%" install + popd +) + +if exist "%LLVM_BUILD_DIR%\llvm.sln" ( + "%MSBUILD%" "%LLVM_BUILD_DIR%\llvm.sln" /p:Configuration=%VS_CONFIGURATION% /p:Platform=%VS_PLATFORM% /t:Install +) + +if not exist "%LLVM_INSTALL_DIR%\bin\opt.exe" ( + echo Missing LLVM build output, "%LLVM_INSTALL_DIR%\bin\opt.exe" + goto ON_ERROR +) + +if not exist "%LLVM_INSTALL_DIR%\bin\llc.exe" ( + echo Missing LLVM build output, "%LLVM_INSTALL_DIR%\bin\llc.exe" + goto ON_ERROR +) + +copy "%LLVM_INSTALL_DIR%\bin\opt.exe" "%MONO_DIST_DIR%" +copy "%LLVM_INSTALL_DIR%\bin\llc.exe" "%MONO_DIST_DIR%" + +goto ON_SUCCESS + +:ON_CLEAN_LLVM + +if exist "%LLVM_BUILD_DIR%\build.ninja" ( + pushd + cd "%LLVM_BUILD_DIR%" + call "%NINJA%" clean + popd +) + +if exist "%LLVM_BUILD_DIR%\llvm.sln" ( + "%MSBUILD%" "%LLVM_BUILD_DIR%\llvm.sln" /p:Configuration=%VS_CONFIGURATION% /p:Platform=%VS_PLATFORM% /t:Clean +) + +goto ON_SUCCESS + +:ON_SUCCESS + +set BUILD_RESULT=0 +goto ON_EXIT + +:ECHO_USAGE: + ECHO Usage: build-external-llvm.bat [llvm_src_dir] [llvm_build_dir] [llvm_install_dir] [mono_dist_dir] [vs_cflags] [vs_plaform] [vs_configuration]. + +:ON_ERROR + echo Failed to build LLVM. + goto ON_EXIT + +:ON_EXIT + set PATH=%TEMP_PATH% + exit /b %BUILD_RESULT% + +:: ############################################################################################################################## +:: Functions + +:: -------------------------------------------------- +:: Finds a program using environment. +:: +:: %1 Existing program to check for. +:: %2 Name of binary to locate. +:: %3 Output, variable to set if found requested program. +:: -------------------------------------------------- +:FIND_PROGRAM + +:: If not set by caller, check environment for program. +if exist "%~1" ( + goto :EOF +) + +call where /q "%~2" && ( + for /f "delims=" %%a in ('where "%~2"') do ( + set "%~3=%%a" + ) +) || ( + set "%~3=" +) + +goto :EOF + +:: -------------------------------------------------- +:: Setup up cmake build environment, including generator, build tools and variables. +:: -------------------------------------------------- +:SETUP_CMAKE_ENVIRONMENT + +:: If not set by caller, check environment for working cmake.exe. +call :FIND_PROGRAM "%CMAKE%" "%CMAKE_BIN_NAME%" CMAKE +if "%CMAKE%" == "" ( + goto _SETUP_CMAKE_ENVIRONMENT_EXIT +) + +echo Found CMake: %CMAKE% + +:: Check for optional cmake generate and build tools. +call :FIND_PROGRAM "%NINJA%" "%NINJA_BIN_NAME%" NINJA + +if not "%NINJA%" == "" ( + goto _SETUP_CMAKE_ENVIRONMENT_NINJA_GENERATOR +) + +:_SETUP_CMAKE_ENVIRONMENT_VS_GENERATOR + +echo Using Visual Studio build generator. + +:: Detect VS version to use right cmake generator. +set CMAKE_GENERATOR=Visual Studio 14 2015 +if "%VisualStudioVersion%" == "15.0" ( + set CMAKE_GENERATOR=Visual Studio 15 2017 +) + +if /i "%VS_PLATFORM%" == "x64" ( + set CMAKE_GENERATOR=%CMAKE_GENERATOR% Win64 +) + +set LLVM_BUILD_OUTPUT_DIR=%LLVM_BUILD_DIR%\%VS_CONFIGURATION% + +goto _SETUP_CMAKE_ENVIRONMENT_EXIT + +:_SETUP_CMAKE_ENVIRONMENT_NINJA_GENERATOR + +echo Found Ninja: %NINJA% +echo Using Ninja build generator. + +set CMAKE_GENERATOR=Ninja +set LLVM_BUILD_OUTPUT_DIR=%LLVM_BUILD_DIR% + +:_SETUP_CMAKE_ENVIRONMENT_EXIT + +goto :EOF + +@echo on diff --git a/msvc/build-external-btls.vcxproj b/msvc/build-external-llvm.vcxproj similarity index 77% copy from msvc/build-external-btls.vcxproj copy to msvc/build-external-llvm.vcxproj index fbdd0a8f7c5..6ab7a02a671 100644 --- a/msvc/build-external-btls.vcxproj +++ b/msvc/build-external-llvm.vcxproj @@ -19,8 +19,8 @@ - {E41DDF41-0916-454B-A7C2-6E410E45CAFD} - buildexternalbtls + {C3D4C623-55F8-4653-980D-61AA629B4E1D} + buildexternalllvm 8.1 @@ -145,35 +145,25 @@ + - <_BtlsCFlags Condition="'$(MONO_PREPROCESSOR_DEFINITIONS)' != ''">$(MONO_PREPROCESSOR_DEFINITIONS.Replace(";"," ")) - <_BtlsCFlags>$(_BtlsCFlags.Trim()) - <_BtlsCFlags Condition="'$(_BtlsCFlags)' != ''">-D$(_BtlsCFlags.Replace(" "," -D")) - <_BtlsBuildDir>$(MONO_BUILD_DIR_PREFIX)$(Platform)\obj\external\btls-build-shared\$(Configuration) - <_BtlsBuildCommand>build-external-btls.bat "$(MONO_DIR)" "$(_BtlsBuildDir)" "$(OutDir)" "$(_BtlsCFlags)" "$(Platform)" "$(Configuration)" - <_BtlsCheckCommand>findstr /i /r /c:".*#define.*HAVE_BTLS.*1" $(MONO_DIR)/cygconfig.h >nul 2>&1 + <_LLVMCFlags Condition="'$(MONO_PREPROCESSOR_DEFINITIONS)' != ''">$(MONO_PREPROCESSOR_DEFINITIONS.Replace(";"," ")) + <_LLVMCFlags>$(_LLVMCFlags.Trim()) + <_LLVMCFlags Condition="'$(_LLVMCFlags)' != ''">-D$(_LLVMCFlags.Replace(" "," -D")) + <_LLVMBuildCommand>build-external-llvm.bat "$(_LLVMSourceDir)" "$(_LLVMBuildDir)" "$(_LLVMInstallDir)" "$(_MonoOutputDir)" "$(_LLVMCFlags)" "$(Platform)" "$(Configuration)" - - - + + + - - true - false - - - - + + + - - - - - - - + + \ No newline at end of file diff --git a/msvc/build-init.vcxproj b/msvc/build-init.vcxproj index a288e844b90..57c90df4c56 100644 --- a/msvc/build-init.vcxproj +++ b/msvc/build-init.vcxproj @@ -149,31 +149,21 @@ + - - $(MONO_LLVM_BIN_DIR)/llvm-config.exe - + - + + <_OptionalDefines Condition="'$(MONO_ENABLE_BTLS)' == 'true'">$(_OptionalDefines);HAVE_BTLS + <_OptionalDefines Condition="'$(MONO_ENABLE_LLVM)' == 'true'">$(_OptionalDefines);ENABLE_LLVM;ENABLE_LLVM_RUNTIME + <_OptionalDefines>$(_OptionalDefines.Trim(';')) + + - - - - - - - - - - - - - - - - + + \ No newline at end of file diff --git a/msvc/libmini-llvm.targets b/msvc/libmini-llvm.targets index 47ecbde4416..751007c3392 100644 --- a/msvc/libmini-llvm.targets +++ b/msvc/libmini-llvm.targets @@ -7,18 +7,23 @@ $(ExcludeLLVMFromWindowsBuild) + <_MonoLLVMSourceFile>true $(ExcludeLLVMFromWindowsBuild) + <_MonoLLVMSourceFile>true $(ExcludeLLVMFromWindowsBuild) + <_MonoLLVMSourceFile>true $(ExcludeLLVMFromWindowsBuild) + <_MonoLLVMSourceFile>true $(ExcludeLLVMFromWindowsBuild) + <_MonoLLVMSourceFile>true diff --git a/msvc/libmini.vcxproj b/msvc/libmini.vcxproj index 5e411d0eb6b..e5c24e1a670 100644 --- a/msvc/libmini.vcxproj +++ b/msvc/libmini.vcxproj @@ -100,7 +100,7 @@ /D /NODEFAULTLIB:LIBCD" " %(AdditionalOptions) Disabled - $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);$(MONO_LLVM_INCLUDE_DIR);%(AdditionalIncludeDirectories) + $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);%(AdditionalIncludeDirectories) WIN32;WIN32_LEAN_AND_MEAN;_DEBUG;%(PreprocessorDefinitions) @@ -113,9 +113,7 @@ Windows - - %(AdditionalLibraryDirectories) - + @@ -125,7 +123,7 @@ /D /NODEFAULTLIB:LIBCD" " %(AdditionalOptions) Disabled - $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);$(MONO_LLVM_INCLUDE_DIR);%(AdditionalIncludeDirectories) + $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);%(AdditionalIncludeDirectories) WIN32;WIN32_LEAN_AND_MEAN;WIN64;_DEBUG;%(PreprocessorDefinitions) @@ -138,9 +136,7 @@ Windows - - %(AdditionalLibraryDirectories) - + @@ -150,7 +146,7 @@ /D /NODEFAULTLIB:LIBCD" " %(AdditionalOptions) true - $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);$(MONO_LLVM_INCLUDE_DIR);%(AdditionalIncludeDirectories) + $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);%(AdditionalIncludeDirectories) WIN32;WIN32_LEAN_AND_MEAN;NDEBUG;%(PreprocessorDefinitions) @@ -164,9 +160,7 @@ true - - %(AdditionalLibraryDirectories) - + @@ -176,7 +170,7 @@ /D /NODEFAULTLIB:LIBCD" " %(AdditionalOptions) true - $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);$(MONO_LLVM_INCLUDE_DIR);%(AdditionalIncludeDirectories) + $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);%(AdditionalIncludeDirectories) WIN32;WIN32_LEAN_AND_MEAN;WIN64;NDEBUG;%(PreprocessorDefinitions) @@ -190,9 +184,7 @@ true - - %(AdditionalLibraryDirectories) - + @@ -201,6 +193,40 @@ + + + + + $(MONO_LLVM_INCLUDE_DIR);%(AdditionalIncludeDirectories) + LLVM_API_VERSION=$(MONO_LLVM_API_VERSION);%(PreprocessorDefinitions) + + + + + false + + + + + + + $(MONO_LLVM_LIB_DIR);%(Lib.AdditionalLibraryDirectories) + $(MONO_LLVM_LIBS);%(Lib.AdditionalDependencies) + + + + + + + + _ConfigureExternalCompileDependency; + $(PrepareForBuildDependsOn); + + + $(ComputeLibInputsTargets); + _ConfigureExternalLinkDependency; + + \ No newline at end of file diff --git a/msvc/libmono-dynamic.vcxproj b/msvc/libmono-dynamic.vcxproj index cbb0d9a0d0f..5fe31adc64c 100644 --- a/msvc/libmono-dynamic.vcxproj +++ b/msvc/libmono-dynamic.vcxproj @@ -97,7 +97,7 @@ /D /NODEFAULTLIB:LIBCD" " %(AdditionalOptions) Disabled - $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);$(MONO_LLVM_INCLUDE_DIR);%(AdditionalIncludeDirectories) + $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);%(AdditionalIncludeDirectories) WIN32;WIN32_LEAN_AND_MEAN;$(GC_DEFINES);MONO_DLL_EXPORT;_DEBUG;%(PreprocessorDefinitions) @@ -114,13 +114,11 @@ $(GC_LIB);%(AdditionalDependencies) - $(MONO_LLVM_LIB_DIR);%(AdditionalLibraryDirectories) $(MONO_BUILD_DIR_PREFIX)$(Platform)\lib\$(Configuration)\$(TargetName).lib - $(MONO_LLVM_LIBS);%(AdditionalDependencies) .\libmono.bat "$(MONO_INCLUDE_DIR)" "$(SolutionDir)include\mono" -q @@ -137,7 +135,7 @@ /D /NODEFAULTLIB:LIBCD" " %(AdditionalOptions) Disabled - $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);$(MONO_LLVM_INCLUDE_DIR);%(AdditionalIncludeDirectories) + $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);%(AdditionalIncludeDirectories) WIN32;WIN32_LEAN_AND_MEAN;$(GC_DEFINES);MONO_DLL_EXPORT;WIN64;_DEBUG;%(PreprocessorDefinitions) @@ -154,11 +152,9 @@ $(GC_LIB);%(AdditionalDependencies) - $(MONO_LLVM_LIB_DIR);%(AdditionalLibraryDirectories) $(MONO_BUILD_DIR_PREFIX)$(Platform)\lib\$(Configuration)\$(TargetName).lib - $(MONO_LLVM_LIBS);%(AdditionalDependencies) .\libmono.bat "$(MONO_INCLUDE_DIR)" "$(SolutionDir)include\mono" -q @@ -172,7 +168,7 @@ /D /NODEFAULTLIB:LIBCD" " %(AdditionalOptions) true - $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);$(MONO_LLVM_INCLUDE_DIR);%(AdditionalIncludeDirectories) + $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);%(AdditionalIncludeDirectories) WIN32;WIN32_LEAN_AND_MEAN;$(GC_DEFINES);MONO_DLL_EXPORT;NDEBUG;%(PreprocessorDefinitions) true @@ -186,13 +182,11 @@ $(GC_LIB);%(AdditionalDependencies) - $(MONO_LLVM_LIB_DIR);%(AdditionalLibraryDirectories) $(MONO_BUILD_DIR_PREFIX)$(Platform)\lib\$(Configuration)\$(TargetName).lib - $(MONO_LLVM_LIBS);%(AdditionalDependencies) .\libmono.bat "$(MONO_INCLUDE_DIR)" "$(SolutionDir)include\mono" -q @@ -212,7 +206,7 @@ /D /NODEFAULTLIB:LIBCD" " %(AdditionalOptions) true - $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);$(MONO_LLVM_INCLUDE_DIR);%(AdditionalIncludeDirectories) + $(MONO_DIR);$(MONO_INCLUDE_DIR);$(LIBGC_CPPFLAGS_INCLUDE);$(GLIB_CFLAGS_INCLUDE);%(AdditionalIncludeDirectories) WIN32;WIN32_LEAN_AND_MEAN;$(GC_DEFINES);MONO_DLL_EXPORT;WIN64;NDEBUG;%(PreprocessorDefinitions) true @@ -226,11 +220,9 @@ $(GC_LIB);%(AdditionalDependencies) - $(MONO_LLVM_LIB_DIR);%(AdditionalLibraryDirectories) $(MONO_BUILD_DIR_PREFIX)$(Platform)\lib\$(Configuration)\$(TargetName).lib - $(MONO_LLVM_LIBS);%(AdditionalDependencies) .\libmono.bat "$(MONO_INCLUDE_DIR)" "$(SolutionDir)include\mono" -q @@ -261,6 +253,40 @@ + + + + + $(MONO_LLVM_INCLUDE_DIR);%(AdditionalIncludeDirectories) + LLVM_API_VERSION=$(MONO_LLVM_API_VERSION);%(PreprocessorDefinitions) + + + + + false + + + + + + + $(MONO_LLVM_LIB_DIR);%(Link.AdditionalLibraryDirectories) + $(MONO_LLVM_LIBS);%(Link.AdditionalDependencies) + + + + + + + + _ConfigureExternalCompileDependency; + $(PrepareForBuildDependsOn); + + + $(ComputeLinkInputsTargets); + _ConfigureExternalLinkDependency; + + \ No newline at end of file diff --git a/msvc/libmonodac.vcxproj b/msvc/libmonodac.vcxproj index 90f75e603e6..a66edd90ead 100644 --- a/msvc/libmonodac.vcxproj +++ b/msvc/libmonodac.vcxproj @@ -85,7 +85,6 @@ $(MONO_BUILD_DIR_PREFIX)$(Platform)\lib\$(Configuration)\$(TargetName).lib - %(AdditionalDependencies) @@ -124,7 +123,6 @@ $(MONO_BUILD_DIR_PREFIX)$(Platform)\lib\$(Configuration)\$(TargetName).lib - %(AdditionalDependencies) diff --git a/msvc/mono.external.targets b/msvc/mono.external.targets new file mode 100644 index 00000000000..9551a71e9b0 --- /dev/null +++ b/msvc/mono.external.targets @@ -0,0 +1,220 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + <_MonoSourceDir>$([System.IO.Path]::GetFullPath('$(MONO_DIR)').TrimEnd('\')) + <_MonoOutputDir>$([System.IO.Path]::GetFullPath('$(OutDir)')) + + + + <_LLVMSourceDir>$(MONO_INTERNAL_LLVM_SOURCE_DIR) + <_LLVMSourceDir Condition="'$(_LLVMSourceDir)' == ''">$(_MonoSourceDir)\external\llvm + <_LLVMBuildDir>$([System.IO.Path]::GetFullPath('$(MONO_BUILD_DIR_PREFIX)$(Platform)\obj\external\llvm-build\$(Configuration)')) + <_LLVMInstallDir>$(_LLVMBuildDir)\install + + + + <_BtlsBuildDir>$([System.IO.Path]::GetFullPath('$(MONO_BUILD_DIR_PREFIX)$(Platform)\obj\external\btls-build-shared\$(Configuration)')) + + + + <_CheckConfigurationProperty ConfFile="$(MONO_DIR)/cygconfig.h" ConfRegEx=".*#define.*HAVE_BTLS.*1"> + + + + + + <_CheckConfigurationProperty ConfFile="$(MONO_DIR)/cygconfig.h" ConfRegEx=".*#define.*ENABLE_LLVM.*1"> + + + + + + <_CheckConfigurationProperty ConfFile="$(MONO_DIR)/cygconfig.h" ConfRegEx=".*#define.*INTERNAL_LLVM.*1"> + + + + + + <_CheckConfigurationProperty ConfFile="$(MONO_DIR)\Makefile" ConfRegEx=".*EXTERNAL_LLVM_CONFIG_WIN32.*llvm-config.exe"> + + + + + <_MonoLLVMConfig Condition="'$(_MonoEnableExternalLLVM)' == 'true'">$(_CheckExternalLLVMOutput) + + + + + + <_MonoEnableExternalLLVM>true + <_MonoEnableInternalLLVM>false + <_MonoLLVMConfig>$(MONO_EXTERNAL_LLVM_CONFIG) + + + + <_MonoEnableExternalLLVM>false + <_MonoEnableInternalLLVM>true + <_MonoLLVMConfig>$(_LLVMInstallDir)\bin\llvm-config.exe + + + + + + + + <_GetLLVMConfiguration LLVMConfTool="$(_MonoLLVMConfig)" LLVMConfToolArg="--version"> + + + + + + + <_GetLLVMConfiguration LLVMConfTool="$(_MonoLLVMConfig)" LLVMConfToolArg="--mono-api-version"> + + + + + <_MonoLLVMConfigComponents>analysis core bitwriter mcjit x86codegen + <_MonoLLVMConfigComponents Condition="$(MONO_LLVM_API_VERSION) < 600">$(_MonoLLVMConfigComponents) jit + <_MonoLLVMConfigComponents Condition="$(MONO_LLVM_API_VERSION) >= 600">$(_MonoLLVMConfigComponents) orcjit + + + <_GetLLVMConfiguration LLVMConfTool="$(_MonoLLVMConfig)" LLVMConfToolArg="--libnames $(_MonoLLVMConfigComponents)"> + + + + + $(MONO_LLVM_LIBS.Split(' ')) + + + <_GetLLVMConfiguration LLVMConfTool="$(_MonoLLVMConfig)" LLVMConfToolArg="--includedir"> + + + + <_GetLLVMConfiguration LLVMConfTool="$(_MonoLLVMConfig)" LLVMConfToolArg="--bindir"> + + + + <_GetLLVMConfiguration LLVMConfTool="$(_MonoLLVMConfig)" LLVMConfToolArg="--libdir"> + + + + + + + + + + + + + + + + + + + + _ConfigureExternalMonoBuildEnvironment; + $(PrepareForBuildDependsOn); + + + + \ No newline at end of file diff --git a/msvc/mono.props b/msvc/mono.props index dd88cc7ab84..2de8f1851c4 100644 --- a/msvc/mono.props +++ b/msvc/mono.props @@ -5,8 +5,6 @@ $(MSBuildProjectDirectory)/./build/ $(MSBuildProjectDirectory)/./dist/ - - $(MONO_INSTALL_DIR_PREFIX)llvm/ sgen @@ -19,6 +17,10 @@ false false + + + + false @@ -36,11 +38,6 @@ $(MONO_LIBGC_INCLUDE_DIR) $(MONO_EGLIB_SOURCE_DIR) - - $(MONO_LLVM_INSTALL_DIR_PREFIX)include - $(MONO_LLVM_INSTALL_DIR_PREFIX)lib - $(MONO_LLVM_INSTALL_DIR_PREFIX)bin - MultiThreadedDebug MultiThreaded @@ -77,12 +74,6 @@ $(ProgramFiles)/Intel/VTune Amplifier XE 2013/include - - LLVMX86CodeGen.lib;LLVMX86Desc.lib;LLVMX86Info.lib;LLVMObject.lib;LLVMBitReader.lib;LLVMMCDisassembler.lib;LLVMX86AsmPrinter.lib;LLVMX86Utils.lib;LLVMSelectionDAG.lib;LLVMAsmPrinter.lib;LLVMMCParser.lib;LLVMCodeGen.lib;LLVMScalarOpts.lib;LLVMInstCombine.lib;LLVMTransformUtils.lib;LLVMipa.lib - LLVMMCJIT.lib;LLVMRuntimeDyld.lib;LLVMObject.lib;LLVMMCParser.lib;LLVMBitReader.lib;LLVMJIT.lib;LLVMExecutionEngine.lib;LLVMCodeGen.lib;LLVMScalarOpts.lib;LLVMInstCombine.lib;LLVMTransformUtils.lib - $(MONO_LLVM_CODEGEN_LIBS);$(MONO_LLVM_JIT_LIBS);LLVMBitWriter.lib;LLVMAnalysis.lib;LLVMTarget.lib;LLVMMC.lib;LLVMCore.lib;LLVMSupport.lib - ENABLE_LLVM=1;$(MONO_ADDITIONAL_PREPROCESSOR_DEFINITIONS) - $(MONO_BUILD_DIR_PREFIX) @@ -111,6 +102,9 @@ $(MONO_ENABLE_LLVM) + + $(MONO_EXTERNAL_LLVM_CONFIG) + $(MONO_COMPILE_AS_CPP) diff --git a/msvc/mono.sln b/msvc/mono.sln index 4db4deeecaa..1f51a6a6269 100644 --- a/msvc/mono.sln +++ b/msvc/mono.sln @@ -66,6 +66,7 @@ EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "eglib", "eglib.vcxproj", "{158073ED-99AE-4196-9EDC-DDB2344F8466}" ProjectSection(ProjectDependencies) = postProject {92AE7622-5F58-4234-9A26-9EC71876B3F4} = {92AE7622-5F58-4234-9A26-9EC71876B3F4} + {C3D4C623-55F8-4653-980D-61AA629B4E1D} = {C3D4C623-55F8-4653-980D-61AA629B4E1D} {E41DDF41-0916-454B-A7C2-6E410E45CAFD} = {E41DDF41-0916-454B-A7C2-6E410E45CAFD} EndProjectSection EndProject @@ -209,6 +210,11 @@ Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "build-external-btls", "buil {92AE7622-5F58-4234-9A26-9EC71876B3F4} = {92AE7622-5F58-4234-9A26-9EC71876B3F4} EndProjectSection EndProject +Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "build-external-llvm", "build-external-llvm.vcxproj", "{C3D4C623-55F8-4653-980D-61AA629B4E1D}" + ProjectSection(ProjectDependencies) = postProject + {92AE7622-5F58-4234-9A26-9EC71876B3F4} = {92AE7622-5F58-4234-9A26-9EC71876B3F4} + EndProjectSection +EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Debug|Win32 = Debug|Win32 @@ -433,6 +439,14 @@ Global {E41DDF41-0916-454B-A7C2-6E410E45CAFD}.Release|Win32.Build.0 = Release|Win32 {E41DDF41-0916-454B-A7C2-6E410E45CAFD}.Release|x64.ActiveCfg = Release|x64 {E41DDF41-0916-454B-A7C2-6E410E45CAFD}.Release|x64.Build.0 = Release|x64 + {C3D4C623-55F8-4653-980D-61AA629B4E1D}.Debug|Win32.ActiveCfg = Debug|Win32 + {C3D4C623-55F8-4653-980D-61AA629B4E1D}.Debug|Win32.Build.0 = Debug|Win32 + {C3D4C623-55F8-4653-980D-61AA629B4E1D}.Debug|x64.ActiveCfg = Debug|x64 + {C3D4C623-55F8-4653-980D-61AA629B4E1D}.Debug|x64.Build.0 = Debug|x64 + {C3D4C623-55F8-4653-980D-61AA629B4E1D}.Release|Win32.ActiveCfg = Release|Win32 + {C3D4C623-55F8-4653-980D-61AA629B4E1D}.Release|Win32.Build.0 = Release|Win32 + {C3D4C623-55F8-4653-980D-61AA629B4E1D}.Release|x64.ActiveCfg = Release|x64 + {C3D4C623-55F8-4653-980D-61AA629B4E1D}.Release|x64.Build.0 = Release|x64 EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE @@ -472,6 +486,7 @@ Global {88D2EB79-592D-45F8-B849-AE021C1D983A} = {0EBA83B7-0EB4-4C83-A900-77300A97E8B1} {675F4175-FFB1-480D-AD36-F397578844D4} = {DE3617B4-17A8-4E5F-A00F-BA43D956881F} {E41DDF41-0916-454B-A7C2-6E410E45CAFD} = {7AF3635B-001C-42BF-94B9-C036CFDCA71D} + {C3D4C623-55F8-4653-980D-61AA629B4E1D} = {7AF3635B-001C-42BF-94B9-C036CFDCA71D} EndGlobalSection GlobalSection(ExtensibilityGlobals) = postSolution AMDCaPersistentConfig = Debug|Win32 diff --git a/msvc/mono.vcxproj b/msvc/mono.vcxproj index b8de263f6c5..d42026f04f6 100644 --- a/msvc/mono.vcxproj +++ b/msvc/mono.vcxproj @@ -103,8 +103,7 @@ - $(MONO_LIBMONO_LIB);$(MONO_LLVM_LIBS);%(AdditionalDependencies) - $(MONO_LLVM_LIB_DIR);%(AdditionalLibraryDirectories) + $(MONO_LIBMONO_LIB);%(AdditionalDependencies) Console @@ -131,8 +130,7 @@ false - $(MONO_LIBMONO_LIB);$(MONO_LLVM_LIBS);%(AdditionalDependencies) - $(MONO_LLVM_LIB_DIR);%(AdditionalLibraryDirectories) + $(MONO_LIBMONO_LIB);%(AdditionalDependencies) Console @@ -152,8 +150,7 @@ false - $(MONO_LIBMONO_LIB);$(MONO_LLVM_LIBS);%(AdditionalDependencies) - $(MONO_LLVM_LIB_DIR);%(AdditionalLibraryDirectories) + $(MONO_LIBMONO_LIB);%(AdditionalDependencies) Console @@ -176,8 +173,7 @@ false - $(MONO_LIBMONO_LIB);$(MONO_LLVM_LIBS);%(AdditionalDependencies) - $(MONO_LLVM_LIB_DIR);%(AdditionalLibraryDirectories) + $(MONO_LIBMONO_LIB);%(AdditionalDependencies) Console @@ -198,6 +194,22 @@ + + + + + $(MONO_LLVM_LIB_DIR);%(Lib.AdditionalLibraryDirectories) + $(MONO_LLVM_LIBS);%(Lib.AdditionalDependencies) + + + + + + + $(ComputeLibInputsTargets); + _ConfigureExternalLinkDependency; + + \ No newline at end of file diff --git a/msvc/winsetup.bat b/msvc/winsetup.bat index 31363704164..aff095a122c 100755 --- a/msvc/winsetup.bat +++ b/msvc/winsetup.bat @@ -6,6 +6,7 @@ SET CYG_CONFIG_H="%~dp0..\cygconfig.h" SET WIN_CONFIG_H="%~dp0..\winconfig.h" SET CONFIGURE_AC="%~dp0..\configure.ac" SET VERSION_H="%~dp0..\mono\mini\version.h" +SET OPTIONAL_DEFINES=%~1 ECHO Setting up Mono configuration headers... @@ -63,13 +64,11 @@ echo #define PACKAGE_VERSION "%MONO_VERSION%" >> %CONFIG_H_TEMP% echo #define VERSION "%MONO_VERSION%" >> %CONFIG_H_TEMP% echo #define MONO_CORLIB_VERSION "%MONO_CORLIB_VERSION%" >> %CONFIG_H_TEMP% -:: Add dynamic configuration parameters set in original config.h affecting msvc build. -for /f "tokens=*" %%a in ('findstr /i /r /c:".*#define.*HAVE_BTLS.*1" %CYG_CONFIG_H%') do ( - echo #define HAVE_BTLS 1 >> %CONFIG_H_TEMP% -) - -for /f "tokens=*" %%a in ('findstr /i /r /c:".*#define.*LLVM.*" %CYG_CONFIG_H%') do ( - echo %%a >> %CONFIG_H_TEMP% +:: Add dynamic configuration parameters affecting msvc build. +for %%a in (%OPTIONAL_DEFINES%) do ( + echo #ifndef %%a >> %CONFIG_H_TEMP% + echo #define %%a 1 >> %CONFIG_H_TEMP% + echo #endif >> %CONFIG_H_TEMP% ) echo #endif >> %CONFIG_H_TEMP% diff --git a/winconfig.h b/winconfig.h index aa2dd17f7cc..975fc004734 100644 --- a/winconfig.h +++ b/winconfig.h @@ -673,13 +673,6 @@ /* Use mono_mutex_t */ /* #undef USE_MONO_MUTEX */ -#ifdef ENABLE_LLVM - #define ENABLE_LLVM 1 - #define ENABLE_LLVM_RUNTIME 1 - #define LLVM_VERSION "3.6.0svn-mono-" - #define LLVM_API_VERSION 4 -#endif - /* Version number of package */ #define VERSION "#MONO_VERSION#" -- 2.11.4.GIT