summaryrefslogtreecommitdiff
path: root/cmake
diff options
context:
space:
mode:
Diffstat (limited to 'cmake')
-rw-r--r--cmake/Modules/CompilerRTUtils.cmake19
-rw-r--r--cmake/config-ix.cmake90
2 files changed, 43 insertions, 66 deletions
diff --git a/cmake/Modules/CompilerRTUtils.cmake b/cmake/Modules/CompilerRTUtils.cmake
index f9c7f0fed..cf690f4a3 100644
--- a/cmake/Modules/CompilerRTUtils.cmake
+++ b/cmake/Modules/CompilerRTUtils.cmake
@@ -36,16 +36,6 @@ macro(append_list_if condition value)
endif()
endmacro()
-# Appends values to list if it isn't already there
-macro(append_list_unique list)
- foreach(val ${ARGN})
- list(FIND ${list} ${val} idx)
- if(idx EQUAL -1)
- list(APPEND ${list} ${val})
- endif()
- endforeach()
-endmacro()
-
# Appends value to all strings in ARGN, if the condition is true.
macro(append_string_if condition value)
if(${condition})
@@ -77,12 +67,3 @@ macro(list_union output input1 input2)
endif()
endforeach()
endmacro()
-
-macro(check_list_contains outvar list input)
- list(FIND ${list} ${input} idx)
- if(idx GREATER -1)
- set(${outvar} True)
- else()
- set(${outvar} False)
- endif()
-endmacro()
diff --git a/cmake/config-ix.cmake b/cmake/config-ix.cmake
index 2d1bbbbc3..700422b7c 100644
--- a/cmake/config-ix.cmake
+++ b/cmake/config-ix.cmake
@@ -505,82 +505,78 @@ endif()
if (SANITIZER_COMMON_SUPPORTED_ARCH AND NOT LLVM_USE_SANITIZER AND
(OS_NAME MATCHES "Android|Darwin|Linux|FreeBSD" OR
(OS_NAME MATCHES "Windows" AND MSVC)))
- list(APPEND DEFAULT_RUNTIMES sanitizer_common)
+ set(COMPILER_RT_HAS_SANITIZER_COMMON TRUE)
+else()
+ set(COMPILER_RT_HAS_SANITIZER_COMMON FALSE)
endif()
-if (NOT OS_NAME MATCHES "Windows" OR CMAKE_SIZEOF_VOID_P EQUAL 4)
- list(APPEND DEFAULT_RUNTIMES interception)
- list(APPEND REQUIRES_COMMON interception)
+if (COMPILER_RT_HAS_SANITIZER_COMMON AND
+ (NOT OS_NAME MATCHES "Windows" OR CMAKE_SIZEOF_VOID_P EQUAL 4))
+ set(COMPILER_RT_HAS_INTERCEPTION TRUE)
+else()
+ set(COMPILER_RT_HAS_INTERCEPTION FALSE)
endif()
-if (ASAN_SUPPORTED_ARCH AND
+if (COMPILER_RT_HAS_SANITIZER_COMMON AND ASAN_SUPPORTED_ARCH AND
(NOT OS_NAME MATCHES "Windows" OR CMAKE_SIZEOF_VOID_P EQUAL 4))
- list(APPEND DEFAULT_RUNTIMES asan)
- list(APPEND REQUIRES_COMMON asan)
+ set(COMPILER_RT_HAS_ASAN TRUE)
+else()
+ set(COMPILER_RT_HAS_ASAN FALSE)
endif()
if (OS_NAME MATCHES "Linux|FreeBSD|Windows")
- set(COMPILER_RT_ASAN_HAS_STATIC_RUNTIME On)
+ set(COMPILER_RT_ASAN_HAS_STATIC_RUNTIME TRUE)
+else()
+ set(COMPILER_RT_ASAN_HAS_STATIC_RUNTIME FALSE)
endif()
# TODO: Add builtins support.
-if (DFSAN_SUPPORTED_ARCH AND
+if (COMPILER_RT_HAS_SANITIZER_COMMON AND DFSAN_SUPPORTED_ARCH AND
OS_NAME MATCHES "Linux")
- list(APPEND DEFAULT_RUNTIMES dfsan)
- list(APPEND REQUIRES_COMMON dfsan)
+ set(COMPILER_RT_HAS_DFSAN TRUE)
+else()
+ set(COMPILER_RT_HAS_DFSAN FALSE)
endif()
-if (LSAN_SUPPORTED_ARCH AND OS_NAME MATCHES "Linux|FreeBSD")
- list(APPEND DEFAULT_RUNTIMES lsan)
- list(APPEND REQUIRES_COMMON lsan)
+if (COMPILER_RT_HAS_SANITIZER_COMMON AND LSAN_SUPPORTED_ARCH AND
+ OS_NAME MATCHES "Linux|FreeBSD")
+ set(COMPILER_RT_HAS_LSAN TRUE)
+else()
+ set(COMPILER_RT_HAS_LSAN FALSE)
endif()
-if (MSAN_SUPPORTED_ARCH AND
+if (COMPILER_RT_HAS_SANITIZER_COMMON AND MSAN_SUPPORTED_ARCH AND
OS_NAME MATCHES "Linux")
- list(APPEND DEFAULT_RUNTIMES msan)
- list(APPEND REQUIRES_COMMON msan)
+ set(COMPILER_RT_HAS_MSAN TRUE)
+else()
+ set(COMPILER_RT_HAS_MSAN FALSE)
endif()
if (PROFILE_SUPPORTED_ARCH AND
OS_NAME MATCHES "Darwin|Linux|FreeBSD")
- list(APPEND DEFAULT_RUNTIMES profile)
+ set(COMPILER_RT_HAS_PROFILE TRUE)
+else()
+ set(COMPILER_RT_HAS_PROFILE FALSE)
endif()
-if (TSAN_SUPPORTED_ARCH AND
+if (COMPILER_RT_HAS_SANITIZER_COMMON AND TSAN_SUPPORTED_ARCH AND
OS_NAME MATCHES "Darwin|Linux|FreeBSD")
- list(APPEND DEFAULT_RUNTIMES tsan)
- list(APPEND REQUIRES_COMMON tsan)
+ set(COMPILER_RT_HAS_TSAN TRUE)
+else()
+ set(COMPILER_RT_HAS_TSAN FALSE)
endif()
-if (UBSAN_SUPPORTED_ARCH AND
+if (COMPILER_RT_HAS_SANITIZER_COMMON AND UBSAN_SUPPORTED_ARCH AND
OS_NAME MATCHES "Darwin|Linux|FreeBSD|Windows")
- list(APPEND DEFAULT_RUNTIMES ubsan)
- list(APPEND REQUIRES_COMMON ubsan)
+ set(COMPILER_RT_HAS_UBSAN TRUE)
+else()
+ set(COMPILER_RT_HAS_UBSAN FALSE)
endif()
-list(APPEND DEFAULT_RUNTIMES cfi)
-if (SAFESTACK_SUPPORTED_ARCH AND
+if (COMPILER_RT_HAS_SANITIZER_COMMON AND SAFESTACK_SUPPORTED_ARCH AND
OS_NAME MATCHES "Darwin|Linux|FreeBSD")
- list(APPEND DEFAULT_RUNTIMES safestack)
- list(APPEND REQUIRES_COMMON safestack)
-endif()
-
-set(COMPILER_RT_RUNTIMES_TO_BUILD "all"
- CACHE STRING "Semicolon-separated list of runtimes to build, or \"all\".")
-
-if(COMPILER_RT_RUNTIMES_TO_BUILD STREQUAL "all")
- set(COMPILER_RT_RUNTIMES_TO_BUILD ${DEFAULT_RUNTIMES})
-endif()
-
-# Several of the runtimes produce object libraries that are consumed by other
-# runtimes (i.e. asan relies on ubsan). If you're building a library that relies
-# on common bits we need to build this full set of libraries.
-list_union(SHOULD_BUILD_COMMON REQUIRES_COMMON COMPILER_RT_RUNTIMES_TO_BUILD)
-
-if(SHOULD_BUILD_COMMON)
- append_list_unique(COMPILER_RT_RUNTIMES_TO_BUILD sanitizer_common)
- append_list_unique(COMPILER_RT_RUNTIMES_TO_BUILD lsan)
- append_list_unique(COMPILER_RT_RUNTIMES_TO_BUILD ubsan)
- append_list_unique(COMPILER_RT_RUNTIMES_TO_BUILD interception)
+ set(COMPILER_RT_HAS_SAFESTACK TRUE)
+else()
+ set(COMPILER_RT_HAS_SAFESTACK FALSE)
endif()