[Windows] Improve build environment detection, add support for Windows on ARM.
This commit is contained in:
parent
85ef0a1058
commit
8dab4a2aa3
@ -191,11 +191,11 @@ String Engine::get_architecture_name() const {
|
|||||||
#elif defined(__i386) || defined(__i386__) || defined(_M_IX86)
|
#elif defined(__i386) || defined(__i386__) || defined(_M_IX86)
|
||||||
return "x86_32";
|
return "x86_32";
|
||||||
|
|
||||||
#elif defined(__aarch64__) || defined(_M_ARM64)
|
#elif defined(__aarch64__) || defined(_M_ARM64) || defined(_M_ARM64EC)
|
||||||
return "arm64";
|
return "arm64";
|
||||||
|
|
||||||
#elif defined(__ARM_ARCH_7A__) || defined(__ARM_ARCH_7S__)
|
#elif defined(__ARM_ARCH_7A__) || defined(__ARM_ARCH_7S__) || defined(_M_ARM)
|
||||||
return "armv7";
|
return "arm32";
|
||||||
|
|
||||||
#elif defined(__riscv)
|
#elif defined(__riscv)
|
||||||
#if __riscv_xlen == 8
|
#if __riscv_xlen == 8
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
def can_build(env, platform):
|
def can_build(env, platform):
|
||||||
# Depends on Embree library, which only supports x86_64 and arm64.
|
# Depends on Embree library, which only supports x86_64 and arm64.
|
||||||
|
if platform == "windows":
|
||||||
|
return env["arch"] == "x86_64" # TODO build for Windows on ARM
|
||||||
|
|
||||||
return env["arch"] in ["x86_64", "arm64"]
|
return env["arch"] in ["x86_64", "arm64"]
|
||||||
|
|
||||||
|
|
||||||
|
@ -173,10 +173,18 @@ DWORD CrashHandlerException(EXCEPTION_POINTERS *ep) {
|
|||||||
frame.AddrStack.Mode = AddrModeFlat;
|
frame.AddrStack.Mode = AddrModeFlat;
|
||||||
frame.AddrFrame.Mode = AddrModeFlat;
|
frame.AddrFrame.Mode = AddrModeFlat;
|
||||||
|
|
||||||
#ifdef _M_X64
|
#if defined(_M_X64)
|
||||||
frame.AddrPC.Offset = context->Rip;
|
frame.AddrPC.Offset = context->Rip;
|
||||||
frame.AddrStack.Offset = context->Rsp;
|
frame.AddrStack.Offset = context->Rsp;
|
||||||
frame.AddrFrame.Offset = context->Rbp;
|
frame.AddrFrame.Offset = context->Rbp;
|
||||||
|
#elif defined(_M_ARM64) || defined(_M_ARM64EC)
|
||||||
|
frame.AddrPC.Offset = context->Pc;
|
||||||
|
frame.AddrStack.Offset = context->Sp;
|
||||||
|
frame.AddrFrame.Offset = context->Fp;
|
||||||
|
#elif defined(_M_ARM)
|
||||||
|
frame.AddrPC.Offset = context->Pc;
|
||||||
|
frame.AddrStack.Offset = context->Sp;
|
||||||
|
frame.AddrFrame.Offset = context->R11;
|
||||||
#else
|
#else
|
||||||
frame.AddrPC.Offset = context->Eip;
|
frame.AddrPC.Offset = context->Eip;
|
||||||
frame.AddrStack.Offset = context->Esp;
|
frame.AddrStack.Offset = context->Esp;
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
import methods
|
import methods
|
||||||
import os
|
import os
|
||||||
|
import subprocess
|
||||||
|
import sys
|
||||||
from platform_methods import detect_arch
|
from platform_methods import detect_arch
|
||||||
|
|
||||||
# To match other platforms
|
# To match other platforms
|
||||||
@ -14,6 +16,38 @@ def get_name():
|
|||||||
return "Windows"
|
return "Windows"
|
||||||
|
|
||||||
|
|
||||||
|
def try_cmd(test, prefix, arch):
|
||||||
|
if arch:
|
||||||
|
try:
|
||||||
|
out = subprocess.Popen(
|
||||||
|
get_mingw_bin_prefix(prefix, arch) + test,
|
||||||
|
shell=True,
|
||||||
|
stderr=subprocess.PIPE,
|
||||||
|
stdout=subprocess.PIPE,
|
||||||
|
)
|
||||||
|
out.communicate()
|
||||||
|
if out.returncode == 0:
|
||||||
|
return True
|
||||||
|
except Exception:
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
for a in ["x86_64", "x86_32", "arm64", "arm32"]:
|
||||||
|
try:
|
||||||
|
out = subprocess.Popen(
|
||||||
|
get_mingw_bin_prefix(prefix, a) + test,
|
||||||
|
shell=True,
|
||||||
|
stderr=subprocess.PIPE,
|
||||||
|
stdout=subprocess.PIPE,
|
||||||
|
)
|
||||||
|
out.communicate()
|
||||||
|
if out.returncode == 0:
|
||||||
|
return True
|
||||||
|
except Exception:
|
||||||
|
pass
|
||||||
|
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
def can_build():
|
def can_build():
|
||||||
if os.name == "nt":
|
if os.name == "nt":
|
||||||
# Building natively on Windows
|
# Building natively on Windows
|
||||||
@ -21,7 +55,7 @@ def can_build():
|
|||||||
if os.getenv("VCINSTALLDIR"): # MSVC, manual setup
|
if os.getenv("VCINSTALLDIR"): # MSVC, manual setup
|
||||||
return True
|
return True
|
||||||
|
|
||||||
# Otherwise, let SCons find MSVC if installed, or else Mingw.
|
# Otherwise, let SCons find MSVC if installed, or else MinGW.
|
||||||
# Since we're just returning True here, if there's no compiler
|
# Since we're just returning True here, if there's no compiler
|
||||||
# installed, we'll get errors when it tries to build with the
|
# installed, we'll get errors when it tries to build with the
|
||||||
# null compiler.
|
# null compiler.
|
||||||
@ -29,47 +63,132 @@ def can_build():
|
|||||||
|
|
||||||
if os.name == "posix":
|
if os.name == "posix":
|
||||||
# Cross-compiling with MinGW-w64 (old MinGW32 is not supported)
|
# Cross-compiling with MinGW-w64 (old MinGW32 is not supported)
|
||||||
mingw32 = "i686-w64-mingw32-"
|
prefix = os.getenv("MINGW_PREFIX", "")
|
||||||
mingw64 = "x86_64-w64-mingw32-"
|
|
||||||
|
|
||||||
if os.getenv("MINGW32_PREFIX"):
|
if try_cmd("gcc --version", prefix, "") or try_cmd("clang --version", prefix, ""):
|
||||||
mingw32 = os.getenv("MINGW32_PREFIX")
|
|
||||||
if os.getenv("MINGW64_PREFIX"):
|
|
||||||
mingw64 = os.getenv("MINGW64_PREFIX")
|
|
||||||
|
|
||||||
test = "gcc --version > /dev/null 2>&1"
|
|
||||||
if os.system(mingw64 + test) == 0 or os.system(mingw32 + test) == 0:
|
|
||||||
return True
|
return True
|
||||||
|
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
|
def get_mingw_bin_prefix(prefix, arch):
|
||||||
|
if not prefix:
|
||||||
|
mingw_bin_prefix = ""
|
||||||
|
elif prefix[-1] != "/":
|
||||||
|
mingw_bin_prefix = prefix + "/bin/"
|
||||||
|
else:
|
||||||
|
mingw_bin_prefix = prefix + "bin/"
|
||||||
|
|
||||||
|
if arch == "x86_64":
|
||||||
|
mingw_bin_prefix += "x86_64-w64-mingw32-"
|
||||||
|
elif arch == "x86_32":
|
||||||
|
mingw_bin_prefix += "i686-w64-mingw32-"
|
||||||
|
elif arch == "arm32":
|
||||||
|
mingw_bin_prefix += "armv7-w64-mingw32-"
|
||||||
|
elif arch == "arm64":
|
||||||
|
mingw_bin_prefix += "aarch64-w64-mingw32-"
|
||||||
|
|
||||||
|
return mingw_bin_prefix
|
||||||
|
|
||||||
|
|
||||||
|
def detect_build_env_arch():
|
||||||
|
msvc_target_aliases = {
|
||||||
|
"amd64": "x86_64",
|
||||||
|
"i386": "x86_32",
|
||||||
|
"i486": "x86_32",
|
||||||
|
"i586": "x86_32",
|
||||||
|
"i686": "x86_32",
|
||||||
|
"x86": "x86_32",
|
||||||
|
"x64": "x86_64",
|
||||||
|
"x86_64": "x86_64",
|
||||||
|
"arm": "arm32",
|
||||||
|
"arm64": "arm64",
|
||||||
|
"aarch64": "arm64",
|
||||||
|
}
|
||||||
|
if os.getenv("VCINSTALLDIR") or os.getenv("VCTOOLSINSTALLDIR"):
|
||||||
|
if os.getenv("Platform"):
|
||||||
|
msvc_arch = os.getenv("Platform").lower()
|
||||||
|
if msvc_arch in msvc_target_aliases.keys():
|
||||||
|
return msvc_target_aliases[msvc_arch]
|
||||||
|
|
||||||
|
if os.getenv("VSCMD_ARG_TGT_ARCH"):
|
||||||
|
msvc_arch = os.getenv("VSCMD_ARG_TGT_ARCH").lower()
|
||||||
|
if msvc_arch in msvc_target_aliases.keys():
|
||||||
|
return msvc_target_aliases[msvc_arch]
|
||||||
|
|
||||||
|
# Pre VS 2017 checks.
|
||||||
|
if os.getenv("VCINSTALLDIR"):
|
||||||
|
PATH = os.getenv("PATH").upper()
|
||||||
|
VCINSTALLDIR = os.getenv("VCINSTALLDIR").upper()
|
||||||
|
path_arch = {
|
||||||
|
"BIN\\x86_ARM;": "arm32",
|
||||||
|
"BIN\\amd64_ARM;": "arm32",
|
||||||
|
"BIN\\x86_ARM64;": "arm64",
|
||||||
|
"BIN\\amd64_ARM64;": "arm64",
|
||||||
|
"BIN\\x86_amd64;": "a86_64",
|
||||||
|
"BIN\\amd64;": "x86_64",
|
||||||
|
"BIN\\amd64_x86;": "x86_32",
|
||||||
|
"BIN;": "x86_32",
|
||||||
|
}
|
||||||
|
for path, arch in path_arch.items():
|
||||||
|
final_path = VCINSTALLDIR + path
|
||||||
|
if final_path in PATH:
|
||||||
|
return arch
|
||||||
|
|
||||||
|
# VS 2017 and newer.
|
||||||
|
if os.getenv("VCTOOLSINSTALLDIR"):
|
||||||
|
host_path_index = os.getenv("PATH").upper().find(os.getenv("VCTOOLSINSTALLDIR").upper() + "BIN\\HOST")
|
||||||
|
if host_path_index > -1:
|
||||||
|
first_path_arch = os.getenv("PATH").split(";")[0].rsplit("\\", 1)[-1].lower()
|
||||||
|
return msvc_target_aliases[first_path_arch]
|
||||||
|
|
||||||
|
msys_target_aliases = {
|
||||||
|
"mingw32": "x86_32",
|
||||||
|
"mingw64": "x86_64",
|
||||||
|
"ucrt64": "x86_64",
|
||||||
|
"clang64": "x86_64",
|
||||||
|
"clang32": "x86_32",
|
||||||
|
"clangarm64": "arm64",
|
||||||
|
}
|
||||||
|
if os.getenv("MSYSTEM"):
|
||||||
|
msys_arch = os.getenv("MSYSTEM").lower()
|
||||||
|
if msys_arch in msys_target_aliases.keys():
|
||||||
|
return msys_target_aliases[msys_arch]
|
||||||
|
|
||||||
|
return ""
|
||||||
|
|
||||||
|
|
||||||
def get_opts():
|
def get_opts():
|
||||||
from SCons.Variables import BoolVariable, EnumVariable
|
from SCons.Variables import BoolVariable, EnumVariable
|
||||||
|
|
||||||
# TODO: These shouldn't be hard-coded for x86.
|
mingw = os.getenv("MINGW_PREFIX", "")
|
||||||
mingw32 = ""
|
|
||||||
mingw64 = ""
|
|
||||||
if os.name == "posix":
|
|
||||||
mingw32 = "i686-w64-mingw32-"
|
|
||||||
mingw64 = "x86_64-w64-mingw32-"
|
|
||||||
|
|
||||||
if os.getenv("MINGW32_PREFIX"):
|
|
||||||
mingw32 = os.getenv("MINGW32_PREFIX")
|
|
||||||
if os.getenv("MINGW64_PREFIX"):
|
|
||||||
mingw64 = os.getenv("MINGW64_PREFIX")
|
|
||||||
|
|
||||||
return [
|
return [
|
||||||
("mingw_prefix_32", "MinGW prefix (Win32)", mingw32),
|
("mingw_prefix", "MinGW prefix", mingw),
|
||||||
("mingw_prefix_64", "MinGW prefix (Win64)", mingw64),
|
|
||||||
# Targeted Windows version: 7 (and later), minimum supported version
|
# Targeted Windows version: 7 (and later), minimum supported version
|
||||||
# XP support dropped after EOL due to missing API for IPv6 and other issues
|
# XP support dropped after EOL due to missing API for IPv6 and other issues
|
||||||
# Vista support dropped after EOL due to GH-10243
|
# Vista support dropped after EOL due to GH-10243
|
||||||
("target_win_version", "Targeted Windows version, >= 0x0601 (Windows 7)", "0x0601"),
|
(
|
||||||
BoolVariable("debug_symbols", "Add debugging symbols to release/release_debug builds", True),
|
"target_win_version",
|
||||||
|
"Targeted Windows version, >= 0x0601 (Windows 7)",
|
||||||
|
"0x0601",
|
||||||
|
),
|
||||||
|
BoolVariable(
|
||||||
|
"debug_symbols",
|
||||||
|
"Add debugging symbols to release/release_debug builds",
|
||||||
|
True,
|
||||||
|
),
|
||||||
EnumVariable("windows_subsystem", "Windows subsystem", "gui", ("gui", "console")),
|
EnumVariable("windows_subsystem", "Windows subsystem", "gui", ("gui", "console")),
|
||||||
BoolVariable("separate_debug_symbols", "Create a separate file containing debugging symbols", False),
|
BoolVariable(
|
||||||
("msvc_version", "MSVC version to use. Ignored if VCINSTALLDIR is set in shell env.", None),
|
"separate_debug_symbols",
|
||||||
|
"Create a separate file containing debugging symbols",
|
||||||
|
False,
|
||||||
|
),
|
||||||
|
(
|
||||||
|
"msvc_version",
|
||||||
|
"MSVC version to use. Ignored if VCINSTALLDIR is set in shell env.",
|
||||||
|
None,
|
||||||
|
),
|
||||||
BoolVariable("use_mingw", "Use the Mingw compiler, even if MSVC is installed.", False),
|
BoolVariable("use_mingw", "Use the Mingw compiler, even if MSVC is installed.", False),
|
||||||
BoolVariable("use_llvm", "Use the LLVM compiler", False),
|
BoolVariable("use_llvm", "Use the LLVM compiler", False),
|
||||||
BoolVariable("use_thinlto", "Use ThinLTO", False),
|
BoolVariable("use_thinlto", "Use ThinLTO", False),
|
||||||
@ -79,73 +198,63 @@ def get_opts():
|
|||||||
|
|
||||||
|
|
||||||
def get_flags():
|
def get_flags():
|
||||||
|
arch = detect_build_env_arch() or detect_arch()
|
||||||
|
|
||||||
return [
|
return [
|
||||||
("arch", detect_arch()),
|
("arch", arch),
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
def build_res_file(target, source, env):
|
def build_res_file(target, source, env):
|
||||||
# TODO: This shouldn't be hard-coded for x86.
|
arch_aliases = {
|
||||||
if env["arch"] == "x86_32":
|
"x86_32": "pe-i386",
|
||||||
cmdbase = env["mingw_prefix_32"]
|
"x86_64": "pe-x86-64",
|
||||||
else:
|
"arm32": "armv7-w64-mingw32",
|
||||||
cmdbase = env["mingw_prefix_64"]
|
"arm64": "aarch64-w64-mingw32",
|
||||||
cmdbase = cmdbase + "windres --include-dir . "
|
}
|
||||||
import subprocess
|
cmdbase = "windres --include-dir . --target=" + arch_aliases[env["arch"]]
|
||||||
|
|
||||||
|
mingw_bin_prefix = get_mingw_bin_prefix(env["mingw_prefix"], env["arch"])
|
||||||
|
|
||||||
for x in range(len(source)):
|
for x in range(len(source)):
|
||||||
cmd = cmdbase + "-i " + str(source[x]) + " -o " + str(target[x])
|
ok = True
|
||||||
|
# Try prefixed executable (MinGW on Linux).
|
||||||
|
cmd = mingw_bin_prefix + cmdbase + " -i " + str(source[x]) + " -o " + str(target[x])
|
||||||
try:
|
try:
|
||||||
out = subprocess.Popen(cmd, shell=True, stderr=subprocess.PIPE).communicate()
|
out = subprocess.Popen(cmd, shell=True, stderr=subprocess.PIPE).communicate()
|
||||||
if len(out[1]):
|
if len(out[1]):
|
||||||
return 1
|
ok = False
|
||||||
except Exception:
|
except Exception:
|
||||||
return 1
|
ok = False
|
||||||
|
|
||||||
|
# Try generic executable (MSYS2).
|
||||||
|
if not ok:
|
||||||
|
cmd = cmdbase + " -i " + str(source[x]) + " -o " + str(target[x])
|
||||||
|
try:
|
||||||
|
out = subprocess.Popen(cmd, shell=True, stderr=subprocess.PIPE).communicate()
|
||||||
|
if len(out[1]):
|
||||||
|
return -1
|
||||||
|
except Exception:
|
||||||
|
return -1
|
||||||
|
|
||||||
return 0
|
return 0
|
||||||
|
|
||||||
|
|
||||||
def setup_msvc_manual(env):
|
def setup_msvc_manual(env):
|
||||||
# FIXME: This is super hacky, and probably obsolete.
|
"""Running from VCVARS environment"""
|
||||||
# Won't work with detect_arch() used for `arch` by default.
|
|
||||||
|
|
||||||
"""Set up env to use MSVC manually, using VCINSTALLDIR"""
|
env_arch = detect_build_env_arch()
|
||||||
if env["arch"] != "auto":
|
if env["arch"] != env_arch:
|
||||||
print(
|
print(
|
||||||
"""
|
"""
|
||||||
Arch argument is not supported for MSVC manual configuration (VCINSTALLDIR configured).
|
Arch argument (%s) is not matching Native/Cross Compile Tools Prompt/Developer Console (or Visual Studio settings) that is being used to run SCons (%s).
|
||||||
Architecture depends on the Native/Cross Compile Tools Prompt/Developer Console (or Visual Studio settings) that is being used to run SCons.
|
Run SCons again without arch argument (example: scons p=windows) and SCons will attempt to detect what MSVC compiler will be executed and inform you.
|
||||||
As a consequence, the arch argument is disabled. Run scons again without arch argument (example: scons p=windows)
|
|
||||||
and SCons will attempt to detect what MSVC compiler will be executed and inform you.
|
|
||||||
"""
|
"""
|
||||||
|
% (env["arch"], env_arch)
|
||||||
)
|
)
|
||||||
raise SCons.Errors.UserError("Arch argument should not be used when using VCINSTALLDIR")
|
sys.exit(200)
|
||||||
|
|
||||||
# Force ARCH arg
|
print("Found MSVC, arch %s" % (env_arch))
|
||||||
# (Actually msys2 mingw can support 64-bit, we could detect that)
|
|
||||||
# TODO: This is wrong, but not sure what to do about it.
|
|
||||||
# We want to determine the arch and bitness in the SConstruct only.
|
|
||||||
# We can check if it's correct in here, but if it's not, it should
|
|
||||||
# just fail with an error message instead of trying to force it.
|
|
||||||
|
|
||||||
# find compiler manually
|
|
||||||
compiler_version_str = methods.detect_visual_c_compiler_version(env["ENV"])
|
|
||||||
print("Found MSVC compiler: " + compiler_version_str)
|
|
||||||
|
|
||||||
# If building for 64bit architecture, disable assembly optimisations for 32 bit builds (theora as of writing)... vc compiler for 64bit can not compile _asm
|
|
||||||
if compiler_version_str == "amd64" or compiler_version_str == "x86_amd64":
|
|
||||||
env["arch"] = "x86_64"
|
|
||||||
env["x86_libtheora_opt_vc"] = False
|
|
||||||
print("Compiled program architecture will be a 64 bit executable (forcing arch=x86_64).")
|
|
||||||
elif compiler_version_str == "x86" or compiler_version_str == "amd64_x86":
|
|
||||||
env["arch"] = "x86_32"
|
|
||||||
env["x86_libtheora_opt_vc"] = True
|
|
||||||
print("Compiled program architecture will be a 32 bit executable (forcing arch=x86_32).")
|
|
||||||
else:
|
|
||||||
print(
|
|
||||||
"Failed to manually detect MSVC compiler architecture version.\n"
|
|
||||||
"You should check your settings/compilation setup, or avoid setting VCINSTALLDIR."
|
|
||||||
)
|
|
||||||
sys.exit()
|
|
||||||
|
|
||||||
|
|
||||||
def setup_msvc_auto(env):
|
def setup_msvc_auto(env):
|
||||||
@ -179,23 +288,50 @@ def setup_msvc_auto(env):
|
|||||||
env["MSVC_VERSION"] = env["msvc_version"]
|
env["MSVC_VERSION"] = env["msvc_version"]
|
||||||
env.Tool("msvc")
|
env.Tool("msvc")
|
||||||
env.Tool("mssdk") # we want the MS SDK
|
env.Tool("mssdk") # we want the MS SDK
|
||||||
|
|
||||||
# Note: actual compiler version can be found in env['MSVC_VERSION'], e.g. "14.1" for VS2015
|
# Note: actual compiler version can be found in env['MSVC_VERSION'], e.g. "14.1" for VS2015
|
||||||
print("Found MSVC version %s, arch %s" % (env["MSVC_VERSION"], env["TARGET_ARCH"]))
|
print("Found MSVC version %s, arch %s" % (env["MSVC_VERSION"], env["arch"]))
|
||||||
if env["arch"] == "x86_32":
|
|
||||||
env["x86_libtheora_opt_vc"] = False
|
|
||||||
|
|
||||||
|
|
||||||
def setup_mingw(env):
|
def setup_mingw(env):
|
||||||
"""Set up env for use with mingw"""
|
"""Set up env for use with mingw"""
|
||||||
# Nothing to do here
|
|
||||||
print("Using MinGW")
|
env_arch = detect_build_env_arch()
|
||||||
|
if os.getenv("MSYSTEM") == "MSYS":
|
||||||
|
print(
|
||||||
|
"""
|
||||||
|
Running from base MSYS2 console/environment, use target specific environment instead (e.g., mingw32, mingw64, clang32, clang64).
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
sys.exit(201)
|
||||||
|
|
||||||
|
if env_arch != "" and env["arch"] != env_arch:
|
||||||
|
print(
|
||||||
|
"""
|
||||||
|
Arch argument (%s) is not matching MSYS2 console/environment that is being used to run SCons (%s).
|
||||||
|
Run SCons again without arch argument (example: scons p=windows) and SCons will attempt to detect what MSYS2 compiler will be executed and inform you.
|
||||||
|
"""
|
||||||
|
% (env["arch"], env_arch)
|
||||||
|
)
|
||||||
|
sys.exit(202)
|
||||||
|
|
||||||
|
if not try_cmd("gcc --version", env["mingw_prefix"], env["arch"]) and not try_cmd(
|
||||||
|
"clang --version", env["mingw_prefix"], env["arch"]
|
||||||
|
):
|
||||||
|
print(
|
||||||
|
"""
|
||||||
|
No valid compilers found, use MINGW_PREFIX environment variable to set MinGW path.
|
||||||
|
"""
|
||||||
|
)
|
||||||
|
sys.exit(202)
|
||||||
|
|
||||||
|
print("Using MinGW, arch %s" % (env["arch"]))
|
||||||
|
|
||||||
|
|
||||||
def configure_msvc(env, manual_msvc_config):
|
def configure_msvc(env, vcvars_msvc_config):
|
||||||
"""Configure env to work with MSVC"""
|
"""Configure env to work with MSVC"""
|
||||||
|
|
||||||
# Build type
|
# Build type
|
||||||
|
|
||||||
if env["target"] == "release":
|
if env["target"] == "release":
|
||||||
if env["optimize"] == "speed": # optimize for speed (default)
|
if env["optimize"] == "speed": # optimize for speed (default)
|
||||||
env.Append(CCFLAGS=["/O2"])
|
env.Append(CCFLAGS=["/O2"])
|
||||||
@ -235,6 +371,9 @@ def configure_msvc(env, manual_msvc_config):
|
|||||||
else:
|
else:
|
||||||
env.AppendUnique(CCFLAGS=["/MD"])
|
env.AppendUnique(CCFLAGS=["/MD"])
|
||||||
|
|
||||||
|
if env["arch"] == "x86_32":
|
||||||
|
env["x86_libtheora_opt_vc"] = True
|
||||||
|
|
||||||
env.AppendUnique(CCFLAGS=["/Gd", "/GR", "/nologo"])
|
env.AppendUnique(CCFLAGS=["/Gd", "/GR", "/nologo"])
|
||||||
env.AppendUnique(CCFLAGS=["/utf-8"]) # Force to use Unicode encoding.
|
env.AppendUnique(CCFLAGS=["/utf-8"]) # Force to use Unicode encoding.
|
||||||
env.AppendUnique(CXXFLAGS=["/TP"]) # assume all sources are C++
|
env.AppendUnique(CXXFLAGS=["/TP"]) # assume all sources are C++
|
||||||
@ -243,7 +382,7 @@ def configure_msvc(env, manual_msvc_config):
|
|||||||
# for notes on why this shouldn't be enabled for gcc
|
# for notes on why this shouldn't be enabled for gcc
|
||||||
env.AppendUnique(CCFLAGS=["/bigobj"])
|
env.AppendUnique(CCFLAGS=["/bigobj"])
|
||||||
|
|
||||||
if manual_msvc_config: # should be automatic if SCons found it
|
if vcvars_msvc_config: # should be automatic if SCons found it
|
||||||
if os.getenv("WindowsSdkDir") is not None:
|
if os.getenv("WindowsSdkDir") is not None:
|
||||||
env.Prepend(CPPPATH=[os.getenv("WindowsSdkDir") + "/Include"])
|
env.Prepend(CPPPATH=[os.getenv("WindowsSdkDir") + "/Include"])
|
||||||
else:
|
else:
|
||||||
@ -302,7 +441,7 @@ def configure_msvc(env, manual_msvc_config):
|
|||||||
|
|
||||||
env.Append(LINKFLAGS=[p + env["LIBSUFFIX"] for p in LIBS])
|
env.Append(LINKFLAGS=[p + env["LIBSUFFIX"] for p in LIBS])
|
||||||
|
|
||||||
if manual_msvc_config:
|
if vcvars_msvc_config:
|
||||||
if os.getenv("WindowsSdkDir") is not None:
|
if os.getenv("WindowsSdkDir") is not None:
|
||||||
env.Append(LIBPATH=[os.getenv("WindowsSdkDir") + "/Lib"])
|
env.Append(LIBPATH=[os.getenv("WindowsSdkDir") + "/Lib"])
|
||||||
else:
|
else:
|
||||||
@ -318,7 +457,7 @@ def configure_msvc(env, manual_msvc_config):
|
|||||||
else:
|
else:
|
||||||
env.AppendUnique(LINKFLAGS=["/LTCG"])
|
env.AppendUnique(LINKFLAGS=["/LTCG"])
|
||||||
|
|
||||||
if manual_msvc_config:
|
if vcvars_msvc_config:
|
||||||
env.Prepend(CPPPATH=[p for p in os.getenv("INCLUDE").split(";")])
|
env.Prepend(CPPPATH=[p for p in os.getenv("INCLUDE").split(";")])
|
||||||
env.Append(LIBPATH=[p for p in os.getenv("LIB").split(";")])
|
env.Append(LIBPATH=[p for p in os.getenv("LIB").split(";")])
|
||||||
|
|
||||||
@ -342,6 +481,12 @@ def configure_mingw(env):
|
|||||||
|
|
||||||
## Build type
|
## Build type
|
||||||
|
|
||||||
|
if not env["use_llvm"] and not try_cmd("gcc --version", env["mingw_prefix"], env["arch"]):
|
||||||
|
env["use_llvm"] = True
|
||||||
|
|
||||||
|
if env["use_llvm"] and not try_cmd("clang --version", env["mingw_prefix"], env["arch"]):
|
||||||
|
env["use_llvm"] = False
|
||||||
|
|
||||||
if env["target"] == "release":
|
if env["target"] == "release":
|
||||||
env.Append(CCFLAGS=["-msse2"])
|
env.Append(CCFLAGS=["-msse2"])
|
||||||
|
|
||||||
@ -383,36 +528,39 @@ def configure_mingw(env):
|
|||||||
if os.name != "nt":
|
if os.name != "nt":
|
||||||
env["PROGSUFFIX"] = env["PROGSUFFIX"] + ".exe" # for linux cross-compilation
|
env["PROGSUFFIX"] = env["PROGSUFFIX"] + ".exe" # for linux cross-compilation
|
||||||
|
|
||||||
mingw_prefix = ""
|
|
||||||
|
|
||||||
# TODO: This doesn't seem to be working, or maybe I just have
|
|
||||||
# MinGW set up incorrectly. It always gives me x86_64 builds,
|
|
||||||
# even though arch == "x86_32" and the file name has x86_32 in it.
|
|
||||||
if env["arch"] == "x86_32":
|
if env["arch"] == "x86_32":
|
||||||
if env["use_static_cpp"]:
|
if env["use_static_cpp"]:
|
||||||
env.Append(LINKFLAGS=["-static"])
|
env.Append(LINKFLAGS=["-static"])
|
||||||
env.Append(LINKFLAGS=["-static-libgcc"])
|
env.Append(LINKFLAGS=["-static-libgcc"])
|
||||||
env.Append(LINKFLAGS=["-static-libstdc++"])
|
env.Append(LINKFLAGS=["-static-libstdc++"])
|
||||||
mingw_prefix = env["mingw_prefix_32"]
|
|
||||||
else:
|
else:
|
||||||
if env["use_static_cpp"]:
|
if env["use_static_cpp"]:
|
||||||
env.Append(LINKFLAGS=["-static"])
|
env.Append(LINKFLAGS=["-static"])
|
||||||
mingw_prefix = env["mingw_prefix_64"]
|
|
||||||
|
if env["arch"] in ["x86_32", "x86_64"]:
|
||||||
|
env["x86_libtheora_opt_gcc"] = True
|
||||||
|
|
||||||
|
mingw_bin_prefix = get_mingw_bin_prefix(env["mingw_prefix"], env["arch"])
|
||||||
|
|
||||||
if env["use_llvm"]:
|
if env["use_llvm"]:
|
||||||
env["CC"] = mingw_prefix + "clang"
|
env["CC"] = mingw_bin_prefix + "clang"
|
||||||
env["CXX"] = mingw_prefix + "clang++"
|
env["CXX"] = mingw_bin_prefix + "clang++"
|
||||||
env["AS"] = mingw_prefix + "as"
|
if try_cmd("as --version", env["mingw_prefix"], env["arch"]):
|
||||||
env["AR"] = mingw_prefix + "ar"
|
env["AS"] = mingw_bin_prefix + "as"
|
||||||
env["RANLIB"] = mingw_prefix + "ranlib"
|
if try_cmd("ar --version", env["mingw_prefix"], env["arch"]):
|
||||||
|
env["AR"] = mingw_bin_prefix + "ar"
|
||||||
|
if try_cmd("ranlib --version", env["mingw_prefix"], env["arch"]):
|
||||||
|
env["RANLIB"] = mingw_bin_prefix + "ranlib"
|
||||||
|
env.extra_suffix = ".llvm" + env.extra_suffix
|
||||||
else:
|
else:
|
||||||
env["CC"] = mingw_prefix + "gcc"
|
env["CC"] = mingw_bin_prefix + "gcc"
|
||||||
env["CXX"] = mingw_prefix + "g++"
|
env["CXX"] = mingw_bin_prefix + "g++"
|
||||||
env["AS"] = mingw_prefix + "as"
|
if try_cmd("as --version", env["mingw_prefix"], env["arch"]):
|
||||||
env["AR"] = mingw_prefix + "gcc-ar"
|
env["AS"] = mingw_bin_prefix + "as"
|
||||||
env["RANLIB"] = mingw_prefix + "gcc-ranlib"
|
if try_cmd("gcc-ar --version", env["mingw_prefix"], env["arch"]):
|
||||||
|
env["AR"] = mingw_bin_prefix + "gcc-ar"
|
||||||
env["x86_libtheora_opt_gcc"] = True
|
if try_cmd("gcc-ranlib --version", env["mingw_prefix"], env["arch"]):
|
||||||
|
env["RANLIB"] = mingw_bin_prefix + "gcc-ranlib"
|
||||||
|
|
||||||
if env["use_lto"]:
|
if env["use_lto"]:
|
||||||
if not env["use_llvm"] and env.GetOption("num_jobs") > 1:
|
if not env["use_llvm"] and env.GetOption("num_jobs") > 1:
|
||||||
@ -430,10 +578,16 @@ def configure_mingw(env):
|
|||||||
|
|
||||||
## Compile flags
|
## Compile flags
|
||||||
|
|
||||||
env.Append(CCFLAGS=["-mwindows"])
|
if not env["use_llvm"]:
|
||||||
|
env.Append(CCFLAGS=["-mwindows"])
|
||||||
|
|
||||||
env.Append(CPPDEFINES=["WINDOWS_ENABLED", "WASAPI_ENABLED", "WINMIDI_ENABLED"])
|
env.Append(CPPDEFINES=["WINDOWS_ENABLED", "WASAPI_ENABLED", "WINMIDI_ENABLED"])
|
||||||
env.Append(CPPDEFINES=[("WINVER", env["target_win_version"]), ("_WIN32_WINNT", env["target_win_version"])])
|
env.Append(
|
||||||
|
CPPDEFINES=[
|
||||||
|
("WINVER", env["target_win_version"]),
|
||||||
|
("_WIN32_WINNT", env["target_win_version"]),
|
||||||
|
]
|
||||||
|
)
|
||||||
env.Append(
|
env.Append(
|
||||||
LIBS=[
|
LIBS=[
|
||||||
"mingw32",
|
"mingw32",
|
||||||
@ -492,22 +646,21 @@ def configure(env):
|
|||||||
env["ENV"]["TMP"] = os.environ["TMP"]
|
env["ENV"]["TMP"] = os.environ["TMP"]
|
||||||
|
|
||||||
# First figure out which compiler, version, and target arch we're using
|
# First figure out which compiler, version, and target arch we're using
|
||||||
if os.getenv("VCINSTALLDIR") and not env["use_mingw"]:
|
if os.getenv("VCINSTALLDIR") and detect_build_env_arch() and not env["use_mingw"]:
|
||||||
# Manual setup of MSVC
|
|
||||||
setup_msvc_manual(env)
|
setup_msvc_manual(env)
|
||||||
env.msvc = True
|
env.msvc = True
|
||||||
manual_msvc_config = True
|
vcvars_msvc_config = True
|
||||||
elif env.get("MSVC_VERSION", "") and not env["use_mingw"]:
|
elif env.get("MSVC_VERSION", "") and not env["use_mingw"]:
|
||||||
setup_msvc_auto(env)
|
setup_msvc_auto(env)
|
||||||
env.msvc = True
|
env.msvc = True
|
||||||
manual_msvc_config = False
|
vcvars_msvc_config = False
|
||||||
else:
|
else:
|
||||||
setup_mingw(env)
|
setup_mingw(env)
|
||||||
env.msvc = False
|
env.msvc = False
|
||||||
|
|
||||||
# Now set compiler/linker flags
|
# Now set compiler/linker flags
|
||||||
if env.msvc:
|
if env.msvc:
|
||||||
configure_msvc(env, manual_msvc_config)
|
configure_msvc(env, vcvars_msvc_config)
|
||||||
|
|
||||||
else: # MinGW
|
else: # MinGW
|
||||||
configure_mingw(env)
|
configure_mingw(env)
|
||||||
|
@ -123,7 +123,7 @@ bool EditorExportPlatformWindows::get_export_option_visibility(const EditorExpor
|
|||||||
|
|
||||||
void EditorExportPlatformWindows::get_export_options(List<ExportOption> *r_options) {
|
void EditorExportPlatformWindows::get_export_options(List<ExportOption> *r_options) {
|
||||||
EditorExportPlatformPC::get_export_options(r_options);
|
EditorExportPlatformPC::get_export_options(r_options);
|
||||||
r_options->push_back(ExportOption(PropertyInfo(Variant::STRING, "binary_format/architecture", PROPERTY_HINT_ENUM, "x86_64,x86_32"), "x86_64"));
|
r_options->push_back(ExportOption(PropertyInfo(Variant::STRING, "binary_format/architecture", PROPERTY_HINT_ENUM, "x86_64,x86_32,arm64"), "x86_64"));
|
||||||
|
|
||||||
r_options->push_back(ExportOption(PropertyInfo(Variant::BOOL, "codesign/enable"), false));
|
r_options->push_back(ExportOption(PropertyInfo(Variant::BOOL, "codesign/enable"), false));
|
||||||
r_options->push_back(ExportOption(PropertyInfo(Variant::INT, "codesign/identity_type", PROPERTY_HINT_ENUM, "Select automatically,Use PKCS12 file (specify *.PFX/*.P12 file),Use certificate store (specify SHA1 hash)"), 0));
|
r_options->push_back(ExportOption(PropertyInfo(Variant::INT, "codesign/identity_type", PROPERTY_HINT_ENUM, "Select automatically,Use PKCS12 file (specify *.PFX/*.P12 file),Use certificate store (specify SHA1 hash)"), 0));
|
||||||
|
6
thirdparty/README.md
vendored
6
thirdparty/README.md
vendored
@ -345,6 +345,9 @@ File extracted from upstream release tarball:
|
|||||||
- Added 2 files `godot_core_mbedtls_platform.c` and `godot_core_mbedtls_config.h`
|
- Added 2 files `godot_core_mbedtls_platform.c` and `godot_core_mbedtls_config.h`
|
||||||
providing configuration for light bundling with core.
|
providing configuration for light bundling with core.
|
||||||
|
|
||||||
|
Some changes have been made in order to fix Windows on ARM build errors.
|
||||||
|
They are marked with `// -- GODOT start --` and `// -- GODOT end --`
|
||||||
|
|
||||||
|
|
||||||
## meshoptimizer
|
## meshoptimizer
|
||||||
|
|
||||||
@ -375,6 +378,9 @@ Files extracted from upstream repository:
|
|||||||
- `minimp3_ex.h`
|
- `minimp3_ex.h`
|
||||||
- `LICENSE`
|
- `LICENSE`
|
||||||
|
|
||||||
|
Some changes have been made in order to fix Windows on ARM build errors.
|
||||||
|
They are marked with `// -- GODOT start --` and `// -- GODOT end --`
|
||||||
|
|
||||||
|
|
||||||
## miniupnpc
|
## miniupnpc
|
||||||
|
|
||||||
|
4
thirdparty/mbedtls/library/timing.c
vendored
4
thirdparty/mbedtls/library/timing.c
vendored
@ -195,8 +195,10 @@ unsigned long mbedtls_timing_hardclock( void )
|
|||||||
#endif /* !HAVE_HARDCLOCK && MBEDTLS_HAVE_ASM &&
|
#endif /* !HAVE_HARDCLOCK && MBEDTLS_HAVE_ASM &&
|
||||||
__GNUC__ && __ia64__ */
|
__GNUC__ && __ia64__ */
|
||||||
|
|
||||||
#if !defined(HAVE_HARDCLOCK) && defined(_MSC_VER) && \
|
// -- GODOT start --
|
||||||
|
#if !defined(HAVE_HARDCLOCK) && defined(_WIN32) && \
|
||||||
!defined(EFIX64) && !defined(EFI32)
|
!defined(EFIX64) && !defined(EFI32)
|
||||||
|
// -- GODOT end --
|
||||||
|
|
||||||
#define HAVE_HARDCLOCK
|
#define HAVE_HARDCLOCK
|
||||||
|
|
||||||
|
23
thirdparty/minimp3/minimp3.h
vendored
23
thirdparty/minimp3/minimp3.h
vendored
@ -1566,7 +1566,18 @@ static void mp3d_synth(float *xl, mp3d_sample_t *dstl, int nch, float *lins)
|
|||||||
|
|
||||||
#else /* MINIMP3_FLOAT_OUTPUT */
|
#else /* MINIMP3_FLOAT_OUTPUT */
|
||||||
|
|
||||||
|
// -- GODOT start --
|
||||||
|
#if defined(_MSC_VER) && (defined(_M_ARM64) || defined(_M_ARM64EC) || defined(_M_ARM))
|
||||||
|
static f4 g_scale;
|
||||||
|
g_scale = vsetq_lane_f32(1.0f/32768.0f, g_scale, 0);
|
||||||
|
g_scale = vsetq_lane_f32(1.0f/32768.0f, g_scale, 1);
|
||||||
|
g_scale = vsetq_lane_f32(1.0f/32768.0f, g_scale, 2);
|
||||||
|
g_scale = vsetq_lane_f32(1.0f/32768.0f, g_scale, 3);
|
||||||
|
#else
|
||||||
static const f4 g_scale = { 1.0f/32768.0f, 1.0f/32768.0f, 1.0f/32768.0f, 1.0f/32768.0f };
|
static const f4 g_scale = { 1.0f/32768.0f, 1.0f/32768.0f, 1.0f/32768.0f, 1.0f/32768.0f };
|
||||||
|
#endif
|
||||||
|
// -- GODOT end --
|
||||||
|
|
||||||
a = VMUL(a, g_scale);
|
a = VMUL(a, g_scale);
|
||||||
b = VMUL(b, g_scale);
|
b = VMUL(b, g_scale);
|
||||||
#if HAVE_SSE
|
#if HAVE_SSE
|
||||||
@ -1813,7 +1824,19 @@ void mp3dec_f32_to_s16(const float *in, int16_t *out, int num_samples)
|
|||||||
int aligned_count = num_samples & ~7;
|
int aligned_count = num_samples & ~7;
|
||||||
for(; i < aligned_count; i += 8)
|
for(; i < aligned_count; i += 8)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
// -- GODOT start --
|
||||||
|
#if defined(_MSC_VER) && (defined(_M_ARM64) || defined(_M_ARM64EC) || defined(_M_ARM))
|
||||||
|
static f4 g_scale;
|
||||||
|
g_scale = vsetq_lane_f32(32768.0f, g_scale, 0);
|
||||||
|
g_scale = vsetq_lane_f32(32768.0f, g_scale, 1);
|
||||||
|
g_scale = vsetq_lane_f32(32768.0f, g_scale, 2);
|
||||||
|
g_scale = vsetq_lane_f32(32768.0f, g_scale, 3);
|
||||||
|
#else
|
||||||
static const f4 g_scale = { 32768.0f, 32768.0f, 32768.0f, 32768.0f };
|
static const f4 g_scale = { 32768.0f, 32768.0f, 32768.0f, 32768.0f };
|
||||||
|
#endif
|
||||||
|
// -- GODOT end --
|
||||||
|
|
||||||
f4 a = VMUL(VLD(&in[i ]), g_scale);
|
f4 a = VMUL(VLD(&in[i ]), g_scale);
|
||||||
f4 b = VMUL(VLD(&in[i+4]), g_scale);
|
f4 b = VMUL(VLD(&in[i+4]), g_scale);
|
||||||
#if HAVE_SSE
|
#if HAVE_SSE
|
||||||
|
Loading…
Reference in New Issue
Block a user