blob: 71d14992ee77806c0a1baecd05af989233b5620e [file] [log] [blame]
Chris Bieneman18929dd2016-05-09 21:45:52 +00001# The CompilerRT build system requires CMake version 2.8.8 or higher in order
2# to use its support for building convenience "libraries" as a collection of
3# .o files. This is particularly useful in producing larger, more complex
4# runtime libraries.
5
6include(CheckIncludeFile)
7check_include_file(unwind.h HAVE_UNWIND_H)
8
9# Top level target used to build all compiler-rt libraries.
10add_custom_target(compiler-rt ALL)
Chris Bienemana213e3e2016-08-19 22:17:46 +000011add_custom_target(install-compiler-rt)
Etienne Bergerona088b362016-07-11 21:51:56 +000012set_target_properties(compiler-rt PROPERTIES FOLDER "Compiler-RT Misc")
Chris Bieneman18929dd2016-05-09 21:45:52 +000013
Chris Bienemanb6fb3832016-06-03 23:15:04 +000014# Setting these variables from an LLVM build is sufficient that compiler-rt can
15# construct the output paths, so it can behave as if it were in-tree here.
16if (LLVM_LIBRARY_OUTPUT_INTDIR AND LLVM_RUNTIME_OUTPUT_INTDIR AND PACKAGE_VERSION)
17 set(LLVM_TREE_AVAILABLE On)
18endif()
19
20if (LLVM_TREE_AVAILABLE)
Chris Bieneman18929dd2016-05-09 21:45:52 +000021 # Compute the Clang version from the LLVM version.
22 # FIXME: We should be able to reuse CLANG_VERSION variable calculated
23 # in Clang cmake files, instead of copying the rules here.
24 string(REGEX MATCH "[0-9]+\\.[0-9]+(\\.[0-9]+)?" CLANG_VERSION
25 ${PACKAGE_VERSION})
26 # Setup the paths where compiler-rt runtimes and headers should be stored.
27 set(COMPILER_RT_OUTPUT_DIR ${LLVM_LIBRARY_OUTPUT_INTDIR}/clang/${CLANG_VERSION})
28 set(COMPILER_RT_EXEC_OUTPUT_DIR ${LLVM_RUNTIME_OUTPUT_INTDIR})
29 set(COMPILER_RT_INSTALL_PATH lib${LLVM_LIBDIR_SUFFIX}/clang/${CLANG_VERSION})
30 option(COMPILER_RT_INCLUDE_TESTS "Generate and build compiler-rt unit tests."
31 ${LLVM_INCLUDE_TESTS})
32 option(COMPILER_RT_ENABLE_WERROR "Fail and stop if warning is triggered"
33 ${LLVM_ENABLE_WERROR})
34 # Use just-built Clang to compile/link tests on all platforms, except for
35 # Windows where we need to use clang-cl instead.
36 if(NOT MSVC)
37 set(COMPILER_RT_TEST_COMPILER ${LLVM_RUNTIME_OUTPUT_INTDIR}/clang)
38 set(COMPILER_RT_TEST_CXX_COMPILER ${LLVM_RUNTIME_OUTPUT_INTDIR}/clang++)
39 else()
40 set(COMPILER_RT_TEST_COMPILER ${LLVM_RUNTIME_OUTPUT_INTDIR}/clang.exe)
41 set(COMPILER_RT_TEST_CXX_COMPILER ${LLVM_RUNTIME_OUTPUT_INTDIR}/clang++.exe)
42 endif()
43else()
44 # Take output dir and install path from the user.
45 set(COMPILER_RT_OUTPUT_DIR ${CMAKE_CURRENT_BINARY_DIR} CACHE PATH
46 "Path where built compiler-rt libraries should be stored.")
47 set(COMPILER_RT_EXEC_OUTPUT_DIR ${CMAKE_CURRENT_BINARY_DIR}/bin CACHE PATH
48 "Path where built compiler-rt executables should be stored.")
49 set(COMPILER_RT_INSTALL_PATH ${CMAKE_INSTALL_PREFIX} CACHE PATH
50 "Path where built compiler-rt libraries should be installed.")
51 option(COMPILER_RT_INCLUDE_TESTS "Generate and build compiler-rt unit tests." OFF)
52 option(COMPILER_RT_ENABLE_WERROR "Fail and stop if warning is triggered" OFF)
53 # Use a host compiler to compile/link tests.
54 set(COMPILER_RT_TEST_COMPILER ${CMAKE_C_COMPILER} CACHE PATH "Compiler to use for testing")
55 set(COMPILER_RT_TEST_CXX_COMPILER ${CMAKE_CXX_COMPILER} CACHE PATH "C++ Compiler to use for testing")
56endif()
57
58if("${COMPILER_RT_TEST_COMPILER}" MATCHES "clang[+]*$")
59 set(COMPILER_RT_TEST_COMPILER_ID Clang)
60elseif("${COMPILER_RT_TEST_COMPILER}" MATCHES "clang.*.exe$")
61 set(COMPILER_RT_TEST_COMPILER_ID Clang)
62else()
63 set(COMPILER_RT_TEST_COMPILER_ID GNU)
64endif()
65
Chris Bieneman18929dd2016-05-09 21:45:52 +000066string(TOLOWER ${CMAKE_SYSTEM_NAME} COMPILER_RT_OS_DIR)
67set(COMPILER_RT_LIBRARY_OUTPUT_DIR
68 ${COMPILER_RT_OUTPUT_DIR}/lib/${COMPILER_RT_OS_DIR})
69set(COMPILER_RT_LIBRARY_INSTALL_DIR
70 ${COMPILER_RT_INSTALL_PATH}/lib/${COMPILER_RT_OS_DIR})
71
72if(APPLE)
73 # On Darwin if /usr/include doesn't exist, the user probably has Xcode but not
74 # the command line tools. If this is the case, we need to find the OS X
75 # sysroot to pass to clang.
76 if(NOT EXISTS /usr/include)
77 execute_process(COMMAND xcodebuild -version -sdk macosx Path
78 OUTPUT_VARIABLE OSX_SYSROOT
79 ERROR_QUIET
80 OUTPUT_STRIP_TRAILING_WHITESPACE)
81 set(OSX_SYSROOT_FLAG "-isysroot${OSX_SYSROOT}")
82 endif()
83
Anna Zaks06644fb2016-10-05 20:45:36 +000084 option(COMPILER_RT_ENABLE_IOS "Enable building for iOS" On)
Chris Bieneman18929dd2016-05-09 21:45:52 +000085 option(COMPILER_RT_ENABLE_WATCHOS "Enable building for watchOS - Experimental" Off)
86 option(COMPILER_RT_ENABLE_TVOS "Enable building for tvOS - Experimental" Off)
Petr Hosek330f9ef2016-12-12 23:14:02 +000087else()
88 option(COMPILER_RT_DEFAULT_TARGET_ONLY "Build builtins only for the default target" Off)
Chris Bieneman18929dd2016-05-09 21:45:52 +000089endif()
90
Francis Ricci4a0c5cd2016-09-07 20:32:48 +000091if(WIN32 AND NOT MINGW AND NOT CYGWIN)
92 set(CMAKE_SHARED_LIBRARY_PREFIX_C "")
93 set(CMAKE_SHARED_LIBRARY_PREFIX_CXX "")
94 set(CMAKE_STATIC_LIBRARY_PREFIX_C "")
95 set(CMAKE_STATIC_LIBRARY_PREFIX_CXX "")
96 set(CMAKE_STATIC_LIBRARY_SUFFIX_C ".lib")
97 set(CMAKE_STATIC_LIBRARY_SUFFIX_CXX ".lib")
98endif()
99
Chris Bieneman18929dd2016-05-09 21:45:52 +0000100macro(test_targets)
101 # Find and run MSVC (not clang-cl) and get its version. This will tell clang-cl
102 # what version of MSVC to pretend to be so that the STL works.
103 set(MSVC_VERSION_FLAG "")
104 if (MSVC)
105 # Find and run MSVC (not clang-cl) and get its version. This will tell
106 # clang-cl what version of MSVC to pretend to be so that the STL works.
107 execute_process(COMMAND "$ENV{VSINSTALLDIR}/VC/bin/cl.exe"
108 OUTPUT_QUIET
109 ERROR_VARIABLE MSVC_COMPAT_VERSION
110 )
111 string(REGEX REPLACE "^.*Compiler Version ([0-9.]+) for .*$" "\\1"
112 MSVC_COMPAT_VERSION "${MSVC_COMPAT_VERSION}")
113 if (MSVC_COMPAT_VERSION MATCHES "^[0-9].+$")
114 set(MSVC_VERSION_FLAG "-fms-compatibility-version=${MSVC_COMPAT_VERSION}")
115 # Add this flag into the host build if this is clang-cl.
116 if (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
117 append("${MSVC_VERSION_FLAG}" CMAKE_C_FLAGS CMAKE_CXX_FLAGS)
Reid Klecknerd80ed422016-06-17 17:48:52 +0000118 elseif (COMPILER_RT_TEST_COMPILER_ID MATCHES "Clang")
Etienne Bergeron73429462016-06-21 14:32:52 +0000119 # Add this flag to test compiles to suppress clang's auto-detection
120 # logic.
121 append("${MSVC_VERSION_FLAG}" COMPILER_RT_TEST_COMPILER_CFLAGS)
Chris Bieneman18929dd2016-05-09 21:45:52 +0000122 endif()
123 endif()
124 endif()
125
126 # Generate the COMPILER_RT_SUPPORTED_ARCH list.
127 if(ANDROID)
128 # Examine compiler output to determine target architecture.
129 detect_target_arch()
Chris Bienemance10b552016-06-28 16:30:23 +0000130 set(COMPILER_RT_OS_SUFFIX "-android")
Chris Bieneman18929dd2016-05-09 21:45:52 +0000131 elseif(NOT APPLE) # Supported archs for Apple platforms are generated later
Petr Hosek330f9ef2016-12-12 23:14:02 +0000132 if(COMPILER_RT_DEFAULT_TARGET_ONLY)
133 add_default_target_arch(${COMPILER_RT_DEFAULT_TARGET_ARCH})
134 elseif("${COMPILER_RT_DEFAULT_TARGET_ARCH}" MATCHES "i[2-6]86|x86|amd64")
Chris Bieneman18929dd2016-05-09 21:45:52 +0000135 if(NOT MSVC)
136 test_target_arch(x86_64 "" "-m64")
137 # FIXME: We build runtimes for both i686 and i386, as "clang -m32" may
138 # target different variant than "$CMAKE_C_COMPILER -m32". This part should
139 # be gone after we resolve PR14109.
140 test_target_arch(i686 __i686__ "-m32")
141 test_target_arch(i386 __i386__ "-m32")
142 else()
143 if (CMAKE_SIZEOF_VOID_P EQUAL 4)
Etienne Bergeron73429462016-06-21 14:32:52 +0000144 test_target_arch(i386 "" "")
Chris Bieneman18929dd2016-05-09 21:45:52 +0000145 else()
Etienne Bergeron73429462016-06-21 14:32:52 +0000146 test_target_arch(x86_64 "" "")
Chris Bieneman18929dd2016-05-09 21:45:52 +0000147 endif()
148 endif()
149 elseif("${COMPILER_RT_DEFAULT_TARGET_ARCH}" MATCHES "powerpc")
150 TEST_BIG_ENDIAN(HOST_IS_BIG_ENDIAN)
151 if(HOST_IS_BIG_ENDIAN)
152 test_target_arch(powerpc64 "" "-m64")
153 else()
154 test_target_arch(powerpc64le "" "-m64")
155 endif()
156 elseif("${COMPILER_RT_DEFAULT_TARGET_ARCH}" MATCHES "s390x")
157 test_target_arch(s390x "" "")
158 elseif("${COMPILER_RT_DEFAULT_TARGET_ARCH}" MATCHES "mipsel|mips64el")
159 # Gcc doesn't accept -m32/-m64 so we do the next best thing and use
160 # -mips32r2/-mips64r2. We don't use -mips1/-mips3 because we want to match
161 # clang's default CPU's. In the 64-bit case, we must also specify the ABI
162 # since the default ABI differs between gcc and clang.
163 # FIXME: Ideally, we would build the N32 library too.
164 test_target_arch(mipsel "" "-mips32r2" "--target=mipsel-linux-gnu")
Mohit K. Bhakkadf9fc3de2016-07-18 09:23:23 +0000165 test_target_arch(mips64el "" "-mips64r2" "--target=mips64el-linux-gnu" "-mabi=64")
Chris Bieneman18929dd2016-05-09 21:45:52 +0000166 elseif("${COMPILER_RT_DEFAULT_TARGET_ARCH}" MATCHES "mips")
167 test_target_arch(mips "" "-mips32r2" "--target=mips-linux-gnu")
Mohit K. Bhakkadf9fc3de2016-07-18 09:23:23 +0000168 test_target_arch(mips64 "" "-mips64r2" "--target=mips64-linux-gnu" "-mabi=64")
Chris Bieneman18929dd2016-05-09 21:45:52 +0000169 elseif("${COMPILER_RT_DEFAULT_TARGET_ARCH}" MATCHES "arm")
Saleem Abdulrasoolbcbb9e62016-08-05 16:53:05 +0000170 if(WIN32)
171 test_target_arch(arm "" "" "")
172 else()
173 test_target_arch(arm "" "-march=armv7-a" "-mfloat-abi=soft")
174 test_target_arch(armhf "" "-march=armv7-a" "-mfloat-abi=hard")
175 endif()
Chris Bieneman18929dd2016-05-09 21:45:52 +0000176 elseif("${COMPILER_RT_DEFAULT_TARGET_ARCH}" MATCHES "aarch32")
177 test_target_arch(aarch32 "" "-march=armv8-a")
178 elseif("${COMPILER_RT_DEFAULT_TARGET_ARCH}" MATCHES "aarch64")
179 test_target_arch(aarch64 "" "-march=armv8-a")
180 elseif("${COMPILER_RT_DEFAULT_TARGET_ARCH}" MATCHES "wasm32")
181 test_target_arch(wasm32 "" "--target=wasm32-unknown-unknown")
182 elseif("${COMPILER_RT_DEFAULT_TARGET_ARCH}" MATCHES "wasm64")
183 test_target_arch(wasm64 "" "--target=wasm64-unknown-unknown")
184 endif()
185 set(COMPILER_RT_OS_SUFFIX "")
186 endif()
187endmacro()