From fb35ba15a454d2e4d448a57e60fce3cf1f109601 Mon Sep 17 00:00:00 2001 From: Adeel Date: Fri, 19 Jun 2020 19:31:46 +0300 Subject: [PATCH] Fix CoreCLR test build for SunOS --- eng/liveBuilds.targets | 2 +- src/coreclr/scripts/coreclr_arguments.py | 7 +++++-- src/coreclr/tests/external/external.csproj | 1 + src/coreclr/tests/runtest.sh | 6 +++++- src/coreclr/tests/src/Common/ilasm/ilasm.ilproj | 1 + src/coreclr/tests/src/Directory.Build.targets | 4 ++-- .../tests/src/profiler/native/profilerstring.h | 11 ++++++----- src/coreclr/tryrun.cmake | 6 ++---- 8 files changed, 23 insertions(+), 15 deletions(-) diff --git a/eng/liveBuilds.targets b/eng/liveBuilds.targets index 75edb9846cf0d..eaa7c54881070 100644 --- a/eng/liveBuilds.targets +++ b/eng/liveBuilds.targets @@ -199,6 +199,6 @@ $(RuntimeIdGraphDefinitionFile) - $(LiveRuntimeIdentifierGraphPath) + $(LiveRuntimeIdentifierGraphPath) diff --git a/src/coreclr/scripts/coreclr_arguments.py b/src/coreclr/scripts/coreclr_arguments.py index 55b11ab7dffd4..9c3d0aa0bdf87 100644 --- a/src/coreclr/scripts/coreclr_arguments.py +++ b/src/coreclr/scripts/coreclr_arguments.py @@ -74,7 +74,7 @@ def __init__(self, self.valid_arches = ["x64", "x86", "arm", "arm64"] self.valid_build_types = ["Debug", "Checked", "Release"] - self.valid_host_os = ["Windows_NT", "OSX", "Linux"] + self.valid_host_os = ["Windows_NT", "OSX", "Linux", "illumos", "Solaris"] self.__initialize__(args) @@ -183,8 +183,11 @@ def provide_default_host_os(): return "OSX" elif sys.platform == "win32": return "Windows_NT" + elif sys.platform.startswith("sunos"): + is_illumos = ('illumos' in subprocess.Popen(["uname", "-o"], stdout=subprocess.PIPE, stderr=subprocess.PIPE).communicate()[0].decode('utf-8')) + return 'illumos' if is_illumos else 'Solaris' else: - print("Unknown OS: %s" % self.host_os) + print("Unknown OS: %s" % sys.platform) sys.exit(1) @staticmethod diff --git a/src/coreclr/tests/external/external.csproj b/src/coreclr/tests/external/external.csproj index b27853bfbf4a7..e5b63ec76f484 100644 --- a/src/coreclr/tests/external/external.csproj +++ b/src/coreclr/tests/external/external.csproj @@ -97,6 +97,7 @@ + diff --git a/src/coreclr/tests/runtest.sh b/src/coreclr/tests/runtest.sh index 857cda101202c..a157f601724a7 100755 --- a/src/coreclr/tests/runtest.sh +++ b/src/coreclr/tests/runtest.sh @@ -73,11 +73,15 @@ function check_cpu_architecture { local CPUName=$(uname -m) local __arch= + if [[ "$(uname -s)" == "SunOS" ]]; then + CPUName=$(isainfo -n) + fi + case $CPUName in i686) __arch=x86 ;; - x86_64) + amd64|x86_64) __arch=x64 ;; armv7l) diff --git a/src/coreclr/tests/src/Common/ilasm/ilasm.ilproj b/src/coreclr/tests/src/Common/ilasm/ilasm.ilproj index 6c76895f60b67..fb5527a77e133 100644 --- a/src/coreclr/tests/src/Common/ilasm/ilasm.ilproj +++ b/src/coreclr/tests/src/Common/ilasm/ilasm.ilproj @@ -8,4 +8,5 @@ $(TestSourceDir)Common\ilasm\obj\project.assets.json + diff --git a/src/coreclr/tests/src/Directory.Build.targets b/src/coreclr/tests/src/Directory.Build.targets index 1d89eb2699e87..8eac9d93bd6f7 100644 --- a/src/coreclr/tests/src/Directory.Build.targets +++ b/src/coreclr/tests/src/Directory.Build.targets @@ -137,8 +137,8 @@ - - + + diff --git a/src/coreclr/tests/src/profiler/native/profilerstring.h b/src/coreclr/tests/src/profiler/native/profilerstring.h index 0f3a8764e0192..9eeaf2bc717d9 100644 --- a/src/coreclr/tests/src/profiler/native/profilerstring.h +++ b/src/coreclr/tests/src/profiler/native/profilerstring.h @@ -9,7 +9,11 @@ #include #include -#if defined(__linux__) || defined(__APPLE__) || defined(__FreeBSD__) +#ifdef _WIN32 +#define WCHAR(str) L##str +#define CAST_CHAR(ch) ch + +#else // defined(_WIN32) // Definitely won't work for non-ascii characters so hopefully we never start using // them in the tests @@ -56,10 +60,7 @@ inline int wcscmp(const char16_t *lhs, const char16_t *rhs) return lhs[i] - rhs[i]; } -#else // defined(__linux__) || defined(__APPLE__) || defined(__FreeBSD__) -#define WCHAR(str) L##str -#define CAST_CHAR(ch) ch -#endif // defined(__linux__) || defined(__APPLE__) || defined(__FreeBSD__) +#endif // defined(__WIN32) // 16 bit string type that works cross plat and doesn't require changing widths // on non-windows platforms diff --git a/src/coreclr/tryrun.cmake b/src/coreclr/tryrun.cmake index fdd9154cacdcd..a70a7b6936bab 100644 --- a/src/coreclr/tryrun.cmake +++ b/src/coreclr/tryrun.cmake @@ -67,7 +67,7 @@ if(TARGET_ARCH_NAME MATCHES "^(armel|arm|arm64|x86)$" OR FREEBSD OR ILLUMOS) set_cache_value(HAVE_BROKEN_FIFO_KEVENT_EXITCODE 1) set_cache_value(HAVE_PROCFS_MAPS 0) set_cache_value(HAVE_PROCFS_STAT 0) - set_cache_value(HAVE_PROCFS_STATUS_EXITCODE 0) + set_cache_value(HAVE_PROCFS_STATUS_EXITCODE 1) set_cache_value(GETPWUID_R_SETS_ERRNO 0) set_cache_value(UNGETC_NOT_RETURN_EOF 0) set_cache_value(HAVE_COMPATIBLE_ILOGBNAN 1) @@ -82,9 +82,7 @@ if(TARGET_ARCH_NAME MATCHES "^(armel|arm|arm64|x86)$" OR FREEBSD OR ILLUMOS) set_cache_value(HAVE_COMPATIBLE_LOG10_EXITCODE 1) set_cache_value(HAVE_COMPATIBLE_LOG_EXITCODE 1) set_cache_value(HAVE_LARGE_SNPRINTF_SUPPORT_EXITCODE 1) - set_cache_value(HAVE_PROCFS_CTL_EXITCODE 1) - set_cache_value(HAVE_PROCFS_STATUS_EXITCODE 1) - set_cache_value(HAVE_CLOCK_THREAD_CPUTIME_EXITCODE 1) + set_cache_value(HAVE_PROCFS_CTL_EXITCODE 0) set_cache_value(SSCANF_CANNOT_HANDLE_MISSING_EXPONENT_EXITCODE 1) set_cache_value(SSCANF_SUPPORT_ll_EXITCODE 1) set_cache_value(UNGETC_NOT_RETURN_EOF_EXITCODE 0)