2011-11-05 03:04:35 +08:00
# This CMake module is responsible for interpreting the user defined LLVM_
# options and executing the appropriate CMake commands to realize the users'
# selections.
2014-11-15 15:45:31 +08:00
# This is commonly needed so make sure it's defined before we include anything
# else.
string ( TOUPPER "${CMAKE_BUILD_TYPE}" uppercase_CMAKE_BUILD_TYPE )
2016-03-03 00:42:56 +08:00
include ( CheckCompilerVersion )
2022-04-21 15:42:08 +08:00
include ( CheckProblematicConfigurations )
2014-02-05 08:02:37 +08:00
include ( HandleLLVMStdlib )
2012-11-26 10:02:08 +08:00
include ( CheckCCompilerFlag )
2013-03-02 09:00:40 +08:00
include ( CheckCXXCompilerFlag )
2019-02-20 06:02:38 +08:00
include ( CheckSymbolExists )
2020-05-09 01:45:44 +08:00
include ( CMakeDependentOption )
[cmake] Don't build with -O3 -fPIC on Solaris/sparcv9
Tests on Solaris/sparcv9 currently show about 250 failures when building
with gcc, most of them like the following:
FAIL: LLVM-Unit :: Support/./SupportTests/TaskQueueTest.UnOrderedFutures (4269 of 67884)
******************** TEST 'LLVM-Unit :: Support/./SupportTests/TaskQueueTest.UnOrderedFutures' FAILED ********************
Note: Google Test filter = TaskQueueTest.UnOrderedFutures
[==========] Running 1 test from 1 test case.
[----------] Global test environment set-up.
[----------] 1 test from TaskQueueTest
[ RUN ] TaskQueueTest.UnOrderedFutures
0 SupportTests 0x0000000100753b20 llvm::sys::PrintStackTrace(llvm::raw_ostream&) + 32
1 SupportTests 0x0000000100752974 llvm::sys::RunSignalHandlers() + 68
2 SupportTests 0x0000000100752b18 SignalHandler(int) + 372
3 libc.so.1 0xffffffff7eedc800 __sighndlr + 12
4 libc.so.1 0xffffffff7eecf23c call_user_handler + 852
5 libc.so.1 0xffffffff7eecf594 sigacthandler + 84
6 SupportTests 0x00000001006f8cb8 std::thread::_State_impl<std::thread::_Invoker<std::tuple<llvm::ThreadPool::ThreadPool(llvm::ThreadPoolStrategy)::'lambda'()> > >::_M_run() + 512
7 libstdc++.so.6.0.28 0xfffffffc628117cc execute_native_thread_routine + 16
8 libc.so.1 0xffffffff7eedc6a0 _lwp_start + 0
Since it's effectively impossible to debug such a `SEGV` in a `Release`
build, I tried a `Debug` build instead, only to find that the failures had
gone away.
Further investigation revealed that most of the issue centers around
`llvm/lib/Support/ThreadPool.cpp`. That file is built with `-O3 -fPIC` in
a `Release` build. The failure vanishes if
- compiling without `-fPIC`
- compiling with `-O -fPIC`
- linking with GNU `ld` instead of Solaris `ld`
It has meanwhile been determined that `gcc` doesn't correctly heed some TLS
code sequences. To make things worse, Solaris `ld` doesn't properly
validate its assumptions against the input, generating wrong code.
`gld` like `gcc` is more liberal here and correctly deals with the code it
gets fed from `gcc`.
There's PR target/96607: GCC feeds SPARC/Solaris linker with unrecognized
TLS sequences <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=96607> now.
An attempt to build with `-DLLVM_ENABLE_PIC=Off` initially failed since
neither `libRemarks.so` (D85626 <https://reviews.llvm.org/D85626>) nor
`LLVMPolly.so` (D85627 <https://reviews.llvm.org/D85627>) heed that option.
Even with that fixed, a few codegen failures remain.
Next I tried to build just `ThreadPool.cpp` with `-O -fPIC`. While that
fixed the vast majority of the failures, 16 `LLVM :: CodeGen/X86` failures
remained.
Given that that solution was both incomplete and fragile, I went for
building the whole tree with `-O -fPIC` for `Release` and `RelWithDebInfo`
builds.
As detailed in Bug 47304, 2-stage builds also show large numbers of
failures when building with `-O3` or `-O2`, which are likewise worked
around by building with `-O` until they are sufficiently analyzed and
fixed.
This way, all failures relative to a `Debug` build go away.
Tested on `sparcv9-sun-solaris2.11`.
Differential Revision: https://reviews.llvm.org/D85630
2020-08-28 17:40:34 +08:00
include ( LLVMProcessSources )
2011-02-04 04:57:36 +08:00
2021-05-21 14:58:07 +08:00
if ( CMAKE_LINKER MATCHES ".*lld" OR ( LLVM_USE_LINKER STREQUAL "lld" OR LLVM_ENABLE_LLD ) )
set ( LINKER_IS_LLD TRUE )
else ( )
set ( LINKER_IS_LLD FALSE )
endif ( )
2020-05-25 15:28:17 +08:00
if ( CMAKE_LINKER MATCHES "lld-link" OR ( MSVC AND ( LLVM_USE_LINKER STREQUAL "lld" OR LLVM_ENABLE_LLD ) ) )
2017-03-02 03:22:18 +08:00
set ( LINKER_IS_LLD_LINK TRUE )
else ( )
set ( LINKER_IS_LLD_LINK FALSE )
endif ( )
2017-04-29 04:17:15 +08:00
set ( LLVM_ENABLE_LTO OFF CACHE STRING "Build LLVM with LTO. May be specified as Thin or Full to use a particular kind of LTO" )
string ( TOUPPER "${LLVM_ENABLE_LTO}" uppercase_LLVM_ENABLE_LTO )
2017-02-08 03:06:22 +08:00
# Ninja Job Pool support
# The following only works with the Ninja generator in CMake >= 3.0.
set ( LLVM_PARALLEL_COMPILE_JOBS "" CACHE STRING
2018-10-11 05:36:12 +08:00
" D e f i n e t h e m a x i m u m n u m b e r o f c o n c u r r e n t c o m p i l a t i o n jobs ( Ninja only ) . " )
2017-02-08 03:06:22 +08:00
if ( LLVM_PARALLEL_COMPILE_JOBS )
2022-01-25 09:49:37 +08:00
if ( NOT CMAKE_GENERATOR MATCHES "Ninja" )
2017-02-08 03:06:22 +08:00
message ( WARNING "Job pooling is only available with Ninja generators." )
else ( )
set_property ( GLOBAL APPEND PROPERTY JOB_POOLS compile_job_pool= ${ LLVM_PARALLEL_COMPILE_JOBS } )
set ( CMAKE_JOB_POOL_COMPILE compile_job_pool )
endif ( )
endif ( )
set ( LLVM_PARALLEL_LINK_JOBS "" CACHE STRING
2018-10-11 05:36:12 +08:00
" D e f i n e t h e m a x i m u m n u m b e r o f c o n c u r r e n t l i n k jobs ( Ninja only ) . " )
2022-01-25 09:49:37 +08:00
if ( CMAKE_GENERATOR MATCHES "Ninja" )
2017-04-29 04:17:15 +08:00
if ( NOT LLVM_PARALLEL_LINK_JOBS AND uppercase_LLVM_ENABLE_LTO STREQUAL "THIN" )
message ( STATUS "ThinLTO provides its own parallel linking - limiting parallel link jobs to 2." )
set ( LLVM_PARALLEL_LINK_JOBS "2" )
endif ( )
if ( LLVM_PARALLEL_LINK_JOBS )
2017-02-08 03:06:22 +08:00
set_property ( GLOBAL APPEND PROPERTY JOB_POOLS link_job_pool= ${ LLVM_PARALLEL_LINK_JOBS } )
set ( CMAKE_JOB_POOL_LINK link_job_pool )
endif ( )
2017-04-29 04:17:15 +08:00
elseif ( LLVM_PARALLEL_LINK_JOBS )
message ( WARNING "Job pooling is only available with Ninja generators." )
2017-02-08 03:06:22 +08:00
endif ( )
2011-02-04 04:57:36 +08:00
if ( LLVM_ENABLE_ASSERTIONS )
# MSVC doesn't like _DEBUG on release builds. See PR 4379.
if ( NOT MSVC )
add_definitions ( -D_DEBUG )
endif ( )
2013-07-17 17:34:51 +08:00
# On non-Debug builds cmake automatically defines NDEBUG, so we
2011-02-04 04:57:36 +08:00
# explicitly undefine it:
2013-07-17 17:34:51 +08:00
if ( NOT uppercase_CMAKE_BUILD_TYPE STREQUAL "DEBUG" )
2020-02-03 02:49:03 +08:00
# NOTE: use `add_compile_options` rather than `add_definitions` since
# `add_definitions` does not support generator expressions.
2020-02-03 08:18:00 +08:00
add_compile_options ( $< $<OR:$<COMPILE_LANGUAGE:C > , $< COMPILE_LANGUAGE:CXX > >:-UNDEBUG> )
2021-04-21 07:03:53 +08:00
if ( MSVC )
# Also remove /D NDEBUG to avoid MSVC warnings about conflicting defines.
foreach ( flags_var_to_scrub
C M A K E _ C X X _ F L A G S _ R E L E A S E
C M A K E _ C X X _ F L A G S _ R E L W I T H D E B I N F O
C M A K E _ C X X _ F L A G S _ M I N S I Z E R E L
C M A K E _ C _ F L A G S _ R E L E A S E
C M A K E _ C _ F L A G S _ R E L W I T H D E B I N F O
C M A K E _ C _ F L A G S _ M I N S I Z E R E L )
string ( REGEX REPLACE "(^| )[/-]D *NDEBUG($| )" " "
" $ { f l a g s _ v a r _ t o _ s c r u b } " " $ { $ { f l a g s _ v a r _ t o _ s c r u b } } " )
endforeach ( )
endif ( )
2011-02-04 04:57:36 +08:00
endif ( )
endif ( )
2016-04-29 23:22:48 +08:00
if ( LLVM_ENABLE_EXPENSIVE_CHECKS )
add_definitions ( -DEXPENSIVE_CHECKS )
2020-02-27 02:47:14 +08:00
# In some libstdc++ versions, std::min_element is not constexpr when
# _GLIBCXX_DEBUG is enabled.
CHECK_CXX_SOURCE_COMPILES ( "
#define _GLIBCXX_DEBUG
#include <algorithm>
i n t main ( int argc, char** argv ) {
s t a t i c c o n s t e x p r i n t d a t a [ ] = { 0 , 1 } ;
c o n s t e x p r c o n s t i n t * m i n _ e l t = s t d : : min_element ( &data[0], &data[2] ) ;
r e t u r n 0 ;
} " C X X _ S U P P O R T S _ G L I B C X X _ D E B U G )
if ( CXX_SUPPORTS_GLIBCXX_DEBUG )
add_definitions ( -D_GLIBCXX_DEBUG )
else ( )
add_definitions ( -D_GLIBCXX_ASSERTIONS )
endif ( )
2016-04-29 23:22:48 +08:00
endif ( )
2020-03-13 17:13:34 +08:00
[ValueTypes] Add EVT::isFixedLengthVector
Summary:
Related to D75672, this patch adds EVT::isFixedLengthVector to determine
if the underlying vector type is of fixed length.
An assert is introduced in EVT::getVectorNumElements that triggers for
types that aren't fixed length. This is currently guarded by a flag
added D75297 that is off by default and has been renamed to the more
generic ENABLE_STRICT_FIXED_SIZE_VECTORS.
Ideally we want to get rid of getVectorNumElements but a quick grep
shows there are >350 uses in lib/CodeGen and 75 in lib/Target/AArch64
alone. All of these probably aren't EVT::getVectorNumElements (some may
be the MVT equivalent), but there are many places to fixup and having
the assert on by default would make the SVE upstreaming effort
difficult.
Reviewers: sdesmalen, efriedma, ctetreau, huntergr, rengolin
Reviewed By: efriedma
Subscribers: mgorny, kristof.beyls, hiraditya, danielkiss, llvm-commits
Tags: #llvm
Differential Revision: https://reviews.llvm.org/D76376
2020-03-19 00:51:45 +08:00
if ( LLVM_ENABLE_STRICT_FIXED_SIZE_VECTORS )
add_definitions ( -DSTRICT_FIXED_SIZE_VECTORS )
2020-03-13 17:13:34 +08:00
endif ( )
2016-04-29 23:22:48 +08:00
2015-03-27 03:25:01 +08:00
string ( TOUPPER "${LLVM_ABI_BREAKING_CHECKS}" uppercase_LLVM_ABI_BREAKING_CHECKS )
if ( uppercase_LLVM_ABI_BREAKING_CHECKS STREQUAL "WITH_ASSERTS" )
if ( LLVM_ENABLE_ASSERTIONS )
set ( LLVM_ENABLE_ABI_BREAKING_CHECKS 1 )
endif ( )
elseif ( uppercase_LLVM_ABI_BREAKING_CHECKS STREQUAL "FORCE_ON" )
set ( LLVM_ENABLE_ABI_BREAKING_CHECKS 1 )
elseif ( uppercase_LLVM_ABI_BREAKING_CHECKS STREQUAL "FORCE_OFF" )
2022-04-07 01:30:51 +08:00
# We don't need to do anything special to turn off ABI breaking checks.
2015-05-13 06:49:18 +08:00
elseif ( NOT DEFINED LLVM_ABI_BREAKING_CHECKS )
# Treat LLVM_ABI_BREAKING_CHECKS like "FORCE_OFF" when it has not been
# defined.
2015-03-27 03:25:01 +08:00
else ( )
message ( FATAL_ERROR "Unknown value for LLVM_ABI_BREAKING_CHECKS: \" ${ LLVM_ABI_BREAKING_CHECKS } \"!")
endif ( )
[cmake] Enable reverse iteration by default through build macro
Summary:
Reverse iteration can be turned on, by default, by setting -DLLVM_REVERSE_ITERATION:BOOL=ON during cmake.
With this enabled, we can uncover lots of cases of non-determinism in codegen by simply running our tests (without any other change).
We can then setup a buildbot which will have this turned on by default. Initially, a lot of unit tests will fail in this configuration.
Once we start fixing non-determinism issues, we can gradually make this a blocker for patches.
Reviewers: davide, dblaikie, mehdi_amini, dberlin
Reviewed By: dblaikie
Subscribers: probinson, mgorny, llvm-commits
Differential Revision: https://reviews.llvm.org/D33908
llvm-svn: 304757
2017-06-06 08:36:09 +08:00
if ( LLVM_REVERSE_ITERATION )
set ( LLVM_ENABLE_REVERSE_ITERATION 1 )
endif ( )
2011-02-04 04:57:36 +08:00
if ( WIN32 )
2013-12-29 07:31:44 +08:00
set ( LLVM_HAVE_LINK_VERSION_SCRIPT 0 )
2011-02-04 04:57:36 +08:00
if ( CYGWIN )
set ( LLVM_ON_WIN32 0 )
set ( LLVM_ON_UNIX 1 )
else ( CYGWIN )
set ( LLVM_ON_WIN32 1 )
set ( LLVM_ON_UNIX 0 )
endif ( CYGWIN )
else ( WIN32 )
2018-05-03 09:38:49 +08:00
if ( FUCHSIA OR UNIX )
2011-02-04 04:57:36 +08:00
set ( LLVM_ON_WIN32 0 )
set ( LLVM_ON_UNIX 1 )
2016-07-20 06:46:39 +08:00
if ( APPLE OR ${ CMAKE_SYSTEM_NAME } MATCHES "AIX" )
2013-12-29 07:31:44 +08:00
set ( LLVM_HAVE_LINK_VERSION_SCRIPT 0 )
2016-07-20 06:46:39 +08:00
else ( )
2013-12-29 07:31:44 +08:00
set ( LLVM_HAVE_LINK_VERSION_SCRIPT 1 )
2016-07-20 06:46:39 +08:00
endif ( )
2018-05-03 09:38:49 +08:00
else ( FUCHSIA OR UNIX )
2011-02-04 04:57:36 +08:00
MESSAGE ( SEND_ERROR "Unable to determine platform" )
2018-05-03 09:38:49 +08:00
endif ( FUCHSIA OR UNIX )
2011-02-04 04:57:36 +08:00
endif ( WIN32 )
2020-07-09 20:17:33 +08:00
if ( CMAKE_SYSTEM_NAME MATCHES "OS390" )
set ( LLVM_HAVE_LINK_VERSION_SCRIPT 0 )
endif ( )
2014-01-08 19:10:24 +08:00
set ( EXEEXT ${ CMAKE_EXECUTABLE_SUFFIX } )
set ( LTDL_SHLIB_EXT ${ CMAKE_SHARED_LIBRARY_SUFFIX } )
2014-02-13 19:19:00 +08:00
2021-03-04 22:52:04 +08:00
# We use *.dylib rather than *.so on darwin, but we stick with *.so on AIX.
if ( ${ CMAKE_SYSTEM_NAME } MATCHES "AIX" )
set ( LLVM_PLUGIN_EXT ${ CMAKE_SHARED_MODULE_SUFFIX } )
else ( )
set ( LLVM_PLUGIN_EXT ${ CMAKE_SHARED_LIBRARY_SUFFIX } )
endif ( )
2014-01-08 19:10:24 +08:00
2014-02-13 19:19:11 +08:00
if ( APPLE )
# Darwin-specific linker flags for loadable modules.
set ( CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,-flat_namespace -Wl,-undefined -Wl,suppress" )
endif ( )
2019-11-22 13:06:33 +08:00
if ( ${ CMAKE_SYSTEM_NAME } MATCHES "Linux" )
# RHEL7 has ar and ranlib being non-deterministic by default. The D flag forces determinism,
2020-02-20 18:22:35 +08:00
# however only GNU version of ar and ranlib (2.27) have this option.
2019-11-22 13:06:33 +08:00
# RHEL DTS7 is also affected by this, which uses GNU binutils 2.28
execute_process ( COMMAND ${ CMAKE_AR } rD t.a
2020-02-20 18:22:35 +08:00
W O R K I N G _ D I R E C T O R Y $ { C M A K E _ B I N A R Y _ D I R }
R E S U L T _ V A R I A B L E A R _ R E S U L T
O U T P U T _ Q U I E T
E R R O R _ Q U I E T
)
2019-11-22 13:06:33 +08:00
if ( ${ AR_RESULT } EQUAL 0 )
execute_process ( COMMAND ${ CMAKE_RANLIB } -D t.a
2020-02-20 18:22:35 +08:00
W O R K I N G _ D I R E C T O R Y $ { C M A K E _ B I N A R Y _ D I R }
R E S U L T _ V A R I A B L E R A N L I B _ R E S U L T
O U T P U T _ Q U I E T
E R R O R _ Q U I E T
)
2019-11-22 13:06:33 +08:00
if ( ${ RANLIB_RESULT } EQUAL 0 )
2022-01-11 02:53:31 +08:00
set ( CMAKE_C_ARCHIVE_CREATE "<CMAKE_AR> Dqc <TARGET> <LINK_FLAGS> <OBJECTS>"
C A C H E S T R I N G " a r c h i v e c r e a t e c o m m a n d " )
2019-11-22 13:06:33 +08:00
set ( CMAKE_C_ARCHIVE_APPEND "<CMAKE_AR> Dq <TARGET> <LINK_FLAGS> <OBJECTS>" )
2022-01-14 17:10:23 +08:00
set ( CMAKE_C_ARCHIVE_FINISH "<CMAKE_RANLIB> -D <TARGET>" CACHE STRING "ranlib command" )
2019-11-22 13:06:33 +08:00
2022-01-11 02:53:31 +08:00
set ( CMAKE_CXX_ARCHIVE_CREATE "<CMAKE_AR> Dqc <TARGET> <LINK_FLAGS> <OBJECTS>"
C A C H E S T R I N G " a r c h i v e c r e a t e c o m m a n d " )
2019-11-22 13:06:33 +08:00
set ( CMAKE_CXX_ARCHIVE_APPEND "<CMAKE_AR> Dq <TARGET> <LINK_FLAGS> <OBJECTS>" )
2022-01-14 17:10:23 +08:00
set ( CMAKE_CXX_ARCHIVE_FINISH "<CMAKE_RANLIB> -D <TARGET>" CACHE STRING "ranlib command" )
2019-11-22 13:06:33 +08:00
endif ( )
file ( REMOVE ${ CMAKE_BINARY_DIR } /t.a )
endif ( )
endif ( )
2019-03-14 05:50:25 +08:00
if ( ${ CMAKE_SYSTEM_NAME } MATCHES "AIX" )
# -fPIC does not enable the large code model for GCC on AIX but does for XL.
2020-07-30 20:31:54 +08:00
if ( CMAKE_CXX_COMPILER_ID MATCHES "GNU|Clang" )
2019-03-14 05:50:25 +08:00
append ( "-mcmodel=large" CMAKE_CXX_FLAGS CMAKE_C_FLAGS )
elseif ( CMAKE_CXX_COMPILER_ID MATCHES "XL" )
# XL generates a small number of relocations not of the large model, -bbigtoc is needed.
append ( "-Wl,-bbigtoc"
C M A K E _ E X E _ L I N K E R _ F L A G S C M A K E _ M O D U L E _ L I N K E R _ F L A G S C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
2020-05-16 05:15:04 +08:00
# The default behaviour on AIX processes dynamic initialization of non-local variables with
# static storage duration even for archive members that are otherwise unreferenced.
# Since `--whole-archive` is not used by the LLVM build to keep such initializations for Linux,
# we can limit the processing for archive members to only those that are otherwise referenced.
append ( "-bcdtors:mbr"
C M A K E _ E X E _ L I N K E R _ F L A G S C M A K E _ M O D U L E _ L I N K E R _ F L A G S C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
2019-03-14 05:50:25 +08:00
endif ( )
2021-03-20 11:48:48 +08:00
if ( BUILD_SHARED_LIBS )
# See rpath handling in AddLLVM.cmake
# FIXME: Remove this warning if this rpath is no longer hardcoded.
message ( WARNING "Build and install environment path info may be exposed; binaries will also be unrelocatable." )
endif ( )
2019-03-14 05:50:25 +08:00
endif ( )
2015-01-22 22:06:51 +08:00
# Pass -Wl,-z,defs. This makes sure all symbols are defined. Otherwise a DSO
# build might work on ELF but fail on MachO/COFF.
2022-07-27 18:33:51 +08:00
if ( NOT ( CMAKE_SYSTEM_NAME MATCHES "Darwin|FreeBSD|OpenBSD|DragonFly|AIX|OS390" OR
2019-03-14 05:50:25 +08:00
WIN32 O R CYGWIN ) A N D
2015-01-23 04:57:30 +08:00
N O T L L V M _ U S E _ S A N I T I Z E R )
2015-01-22 22:06:51 +08:00
set ( CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,-z,defs" )
endif ( )
2017-11-28 06:23:09 +08:00
# Pass -Wl,-z,nodelete. This makes sure our shared libraries are not unloaded
# by dlclose(). We need that since the CLI API relies on cross-references
# between global objects which became horribly broken when one of the libraries
# is unloaded.
if ( ${ CMAKE_SYSTEM_NAME } MATCHES "Linux" )
set ( CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,-z,nodelete" )
2018-08-16 23:12:12 +08:00
set ( CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -Wl,-z,nodelete" )
2017-11-28 06:23:09 +08:00
endif ( )
2015-01-22 22:06:51 +08:00
2013-03-25 21:25:34 +08:00
function ( append value )
foreach ( variable ${ ARGN } )
2013-03-14 04:50:23 +08:00
set ( ${ variable } "${${variable}} ${value}" PARENT_SCOPE )
2013-03-25 21:25:34 +08:00
endforeach ( variable )
endfunction ( )
function ( append_if condition value )
if ( ${ condition } )
foreach ( variable ${ ARGN } )
set ( ${ variable } "${${variable}} ${value}" PARENT_SCOPE )
endforeach ( variable )
2013-03-14 04:50:23 +08:00
endif ( )
endfunction ( )
2014-07-09 11:38:19 +08:00
macro ( add_flag_if_supported flag name )
check_c_compiler_flag ( "-Werror ${flag}" "C_SUPPORTS_${name}" )
append_if ( "C_SUPPORTS_${name}" "${flag}" CMAKE_C_FLAGS )
check_cxx_compiler_flag ( "-Werror ${flag}" "CXX_SUPPORTS_${name}" )
append_if ( "CXX_SUPPORTS_${name}" "${flag}" CMAKE_CXX_FLAGS )
2013-03-26 15:49:46 +08:00
endmacro ( )
2014-07-09 11:38:19 +08:00
function ( add_flag_or_print_warning flag name )
check_c_compiler_flag ( "-Werror ${flag}" "C_SUPPORTS_${name}" )
check_cxx_compiler_flag ( "-Werror ${flag}" "CXX_SUPPORTS_${name}" )
2014-09-27 05:35:48 +08:00
if ( C_SUPPORTS_ ${ name } AND CXX_SUPPORTS_ ${ name } )
2014-07-09 11:38:19 +08:00
message ( STATUS "Building with ${flag}" )
set ( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${flag}" PARENT_SCOPE )
set ( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${flag}" PARENT_SCOPE )
2015-07-28 22:43:53 +08:00
set ( CMAKE_ASM_FLAGS "${CMAKE_ASM_FLAGS} ${flag}" PARENT_SCOPE )
2014-07-09 11:38:19 +08:00
else ( )
message ( WARNING "${flag} is not supported." )
endif ( )
endfunction ( )
2022-01-25 05:42:39 +08:00
function ( has_msvc_incremental_no_flag flags incr_no_flag_on )
set ( ${ incr_no_flag_on } OFF PARENT_SCOPE )
string ( FIND "${flags}" "/INCREMENTAL" idx REVERSE )
if ( ${ idx } GREATER -1 )
string ( SUBSTRING "${flags}" ${ idx } 15 no_flag )
if ( ${ no_flag } MATCHES "/INCREMENTAL:NO" )
set ( ${ incr_no_flag_on } ON PARENT_SCOPE )
endif ( )
endif ( )
endfunction ( )
2017-01-15 11:21:30 +08:00
if ( LLVM_ENABLE_LLD )
2019-05-08 21:02:32 +08:00
if ( LLVM_USE_LINKER )
message ( FATAL_ERROR "LLVM_ENABLE_LLD and LLVM_USE_LINKER can't be set at the same time" )
endif ( )
2020-05-29 19:14:51 +08:00
# In case of MSVC cmake always invokes the linker directly, so the linker
# should be specified by CMAKE_LINKER cmake variable instead of by -fuse-ld
# compiler option.
if ( NOT MSVC )
set ( LLVM_USE_LINKER "lld" )
endif ( )
2017-01-15 11:21:30 +08:00
endif ( )
if ( LLVM_USE_LINKER )
2017-10-31 05:19:54 +08:00
set ( OLD_CMAKE_REQUIRED_FLAGS ${ CMAKE_REQUIRED_FLAGS } )
set ( CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} -fuse-ld=${LLVM_USE_LINKER}" )
check_cxx_source_compiles ( "int main() { return 0; }" CXX_SUPPORTS_CUSTOM_LINKER )
2017-01-15 11:21:30 +08:00
if ( NOT CXX_SUPPORTS_CUSTOM_LINKER )
2019-05-08 21:02:32 +08:00
message ( FATAL_ERROR "Host compiler does not support '-fuse-ld=${LLVM_USE_LINKER}'" )
2017-01-15 11:21:30 +08:00
endif ( )
2017-10-31 05:19:54 +08:00
set ( CMAKE_REQUIRED_FLAGS ${ OLD_CMAKE_REQUIRED_FLAGS } )
2017-01-15 11:21:30 +08:00
append ( "-fuse-ld=${LLVM_USE_LINKER}"
2016-07-29 08:46:13 +08:00
C M A K E _ E X E _ L I N K E R _ F L A G S C M A K E _ M O D U L E _ L I N K E R _ F L A G S C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
endif ( )
2011-02-04 04:57:36 +08:00
if ( LLVM_ENABLE_PIC )
if ( XCODE )
# Xcode has -mdynamic-no-pic on by default, which overrides -fPIC. I don't
# know how to disable this, so just force ENABLE_PIC off for now.
message ( WARNING "-fPIC not supported with Xcode." )
2011-12-16 14:21:08 +08:00
elseif ( WIN32 OR CYGWIN )
2011-02-04 04:57:36 +08:00
# On Windows all code is PIC. MinGW warns if -fPIC is used.
else ( )
2014-07-09 11:38:19 +08:00
add_flag_or_print_warning ( "-fPIC" FPIC )
2021-06-04 06:26:34 +08:00
# Enable interprocedural optimizations for non-inline functions which would
# otherwise be disabled due to GCC -fPIC's default.
2021-07-09 13:09:21 +08:00
# Note: GCC<10.3 has a bug on SystemZ.
2021-06-04 06:26:34 +08:00
#
# Note: Clang allows IPO for -fPIC so this optimization is less effective.
2022-01-14 07:38:02 +08:00
# Clang 13 has a bug related to -fsanitize-coverage
# -fno-semantic-interposition (https://reviews.llvm.org/D117183).
2021-07-09 13:09:21 +08:00
if ( ( CMAKE_COMPILER_IS_GNUCXX AND
NOT ( LLVM_NATIVE_ARCH STREQUAL "SystemZ" AND CMAKE_CXX_COMPILER_VERSION VERSION_LESS 10.3 ) )
2022-01-14 07:38:02 +08:00
OR ( CMAKE_CXX_COMPILER_ID MATCHES "Clang" AND CMAKE_CXX_COMPILER_VERSION GREATER_EQUAL 14 ) )
2021-06-04 06:26:34 +08:00
add_flag_if_supported ( "-fno-semantic-interposition" FNO_SEMANTIC_INTERPOSITION )
endif ( )
2011-02-04 04:57:36 +08:00
endif ( )
2019-04-27 17:28:54 +08:00
# GCC for MIPS can miscompile LLVM due to PR37701.
if ( CMAKE_COMPILER_IS_GNUCXX AND LLVM_NATIVE_ARCH STREQUAL "Mips" AND
N O T U p p e r c a s e _ C M A K E _ B U I L D _ T Y P E S T R E Q U A L " D E B U G " )
add_flag_or_print_warning ( "-fno-shrink-wrap" FNO_SHRINK_WRAP )
endif ( )
[cmake] Don't build with -O3 -fPIC on Solaris/sparcv9
Tests on Solaris/sparcv9 currently show about 250 failures when building
with gcc, most of them like the following:
FAIL: LLVM-Unit :: Support/./SupportTests/TaskQueueTest.UnOrderedFutures (4269 of 67884)
******************** TEST 'LLVM-Unit :: Support/./SupportTests/TaskQueueTest.UnOrderedFutures' FAILED ********************
Note: Google Test filter = TaskQueueTest.UnOrderedFutures
[==========] Running 1 test from 1 test case.
[----------] Global test environment set-up.
[----------] 1 test from TaskQueueTest
[ RUN ] TaskQueueTest.UnOrderedFutures
0 SupportTests 0x0000000100753b20 llvm::sys::PrintStackTrace(llvm::raw_ostream&) + 32
1 SupportTests 0x0000000100752974 llvm::sys::RunSignalHandlers() + 68
2 SupportTests 0x0000000100752b18 SignalHandler(int) + 372
3 libc.so.1 0xffffffff7eedc800 __sighndlr + 12
4 libc.so.1 0xffffffff7eecf23c call_user_handler + 852
5 libc.so.1 0xffffffff7eecf594 sigacthandler + 84
6 SupportTests 0x00000001006f8cb8 std::thread::_State_impl<std::thread::_Invoker<std::tuple<llvm::ThreadPool::ThreadPool(llvm::ThreadPoolStrategy)::'lambda'()> > >::_M_run() + 512
7 libstdc++.so.6.0.28 0xfffffffc628117cc execute_native_thread_routine + 16
8 libc.so.1 0xffffffff7eedc6a0 _lwp_start + 0
Since it's effectively impossible to debug such a `SEGV` in a `Release`
build, I tried a `Debug` build instead, only to find that the failures had
gone away.
Further investigation revealed that most of the issue centers around
`llvm/lib/Support/ThreadPool.cpp`. That file is built with `-O3 -fPIC` in
a `Release` build. The failure vanishes if
- compiling without `-fPIC`
- compiling with `-O -fPIC`
- linking with GNU `ld` instead of Solaris `ld`
It has meanwhile been determined that `gcc` doesn't correctly heed some TLS
code sequences. To make things worse, Solaris `ld` doesn't properly
validate its assumptions against the input, generating wrong code.
`gld` like `gcc` is more liberal here and correctly deals with the code it
gets fed from `gcc`.
There's PR target/96607: GCC feeds SPARC/Solaris linker with unrecognized
TLS sequences <https://gcc.gnu.org/bugzilla/show_bug.cgi?id=96607> now.
An attempt to build with `-DLLVM_ENABLE_PIC=Off` initially failed since
neither `libRemarks.so` (D85626 <https://reviews.llvm.org/D85626>) nor
`LLVMPolly.so` (D85627 <https://reviews.llvm.org/D85627>) heed that option.
Even with that fixed, a few codegen failures remain.
Next I tried to build just `ThreadPool.cpp` with `-O -fPIC`. While that
fixed the vast majority of the failures, 16 `LLVM :: CodeGen/X86` failures
remained.
Given that that solution was both incomplete and fragile, I went for
building the whole tree with `-O -fPIC` for `Release` and `RelWithDebInfo`
builds.
As detailed in Bug 47304, 2-stage builds also show large numbers of
failures when building with `-O3` or `-O2`, which are likewise worked
around by building with `-O` until they are sufficiently analyzed and
fixed.
This way, all failures relative to a `Debug` build go away.
Tested on `sparcv9-sun-solaris2.11`.
Differential Revision: https://reviews.llvm.org/D85630
2020-08-28 17:40:34 +08:00
# gcc with -O3 -fPIC generates TLS sequences that violate the spec on
# Solaris/sparcv9, causing executables created with the system linker
# to SEGV (GCC PR target/96607).
# clang with -O3 -fPIC generates code that SEGVs.
# Both can be worked around by compiling with -O instead.
if ( ${ CMAKE_SYSTEM_NAME } STREQUAL "SunOS" AND LLVM_NATIVE_ARCH STREQUAL "Sparc" )
llvm_replace_compiler_option ( CMAKE_CXX_FLAGS_RELEASE "-O[23]" "-O" )
llvm_replace_compiler_option ( CMAKE_CXX_FLAGS_RELWITHDEBINFO "-O[23]" "-O" )
endif ( )
2011-02-04 04:57:36 +08:00
endif ( )
2021-08-20 11:01:22 +08:00
if ( NOT WIN32 AND NOT CYGWIN AND NOT ( ${ CMAKE_SYSTEM_NAME } MATCHES "AIX" ) )
2015-11-19 06:49:26 +08:00
# MinGW warns if -fvisibility-inlines-hidden is used.
2021-08-20 11:01:22 +08:00
# GCC on AIX warns if -fvisibility-inlines-hidden is used and Clang on AIX doesn't currently support visibility.
2015-11-19 06:49:26 +08:00
check_cxx_compiler_flag ( "-fvisibility-inlines-hidden" SUPPORTS_FVISIBILITY_INLINES_HIDDEN_FLAG )
append_if ( SUPPORTS_FVISIBILITY_INLINES_HIDDEN_FLAG "-fvisibility-inlines-hidden" CMAKE_CXX_FLAGS )
endif ( )
2018-10-24 20:22:12 +08:00
if ( CMAKE_SIZEOF_VOID_P EQUAL 8 AND MINGW )
add_definitions ( -D_FILE_OFFSET_BITS=64 )
endif ( )
2011-02-04 04:57:36 +08:00
if ( CMAKE_SIZEOF_VOID_P EQUAL 8 AND NOT WIN32 )
# TODO: support other platforms and toolchains.
if ( LLVM_BUILD_32_BITS )
message ( STATUS "Building 32 bits executables and libraries." )
2016-06-06 13:54:55 +08:00
set ( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -m32" )
set ( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -m32" )
2012-05-24 02:42:02 +08:00
set ( CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -m32" )
set ( CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -m32" )
2012-06-08 17:41:23 +08:00
set ( CMAKE_MODULE_LINKER_FLAGS "${CMAKE_MODULE_LINKER_FLAGS} -m32" )
2017-11-04 14:03:29 +08:00
# FIXME: CMAKE_SIZEOF_VOID_P is still 8
add_definitions ( -D_LARGEFILE_SOURCE )
add_definitions ( -D_FILE_OFFSET_BITS=64 )
2011-02-04 04:57:36 +08:00
endif ( LLVM_BUILD_32_BITS )
endif ( CMAKE_SIZEOF_VOID_P EQUAL 8 AND NOT WIN32 )
2017-04-24 18:36:46 +08:00
# If building on a GNU specific 32-bit system, make sure off_t is 64 bits
2017-09-02 07:12:43 +08:00
# so that off_t can stored offset > 2GB.
# Android until version N (API 24) doesn't support it.
if ( ANDROID AND ( ANDROID_NATIVE_API_LEVEL LESS 24 ) )
set ( LLVM_FORCE_SMALLFILE_FOR_ANDROID TRUE )
endif ( )
if ( CMAKE_SIZEOF_VOID_P EQUAL 4 AND NOT LLVM_FORCE_SMALLFILE_FOR_ANDROID )
2017-11-04 14:03:29 +08:00
# FIXME: It isn't handled in LLVM_BUILD_32_BITS.
2017-04-24 18:36:46 +08:00
add_definitions ( -D_LARGEFILE_SOURCE )
add_definitions ( -D_FILE_OFFSET_BITS=64 )
endif ( )
2014-03-13 14:37:28 +08:00
if ( XCODE )
# For Xcode enable several build settings that correspond to
# many warnings that are on by default in Clang but are
# not enabled for historical reasons. For versions of Xcode
# that do not support these options they will simply
# be ignored.
set ( CMAKE_XCODE_ATTRIBUTE_GCC_WARN_ABOUT_RETURN_TYPE "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_GCC_WARN_ABOUT_MISSING_NEWLINE "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_GCC_WARN_UNUSED_VALUE "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_GCC_WARN_UNUSED_VARIABLE "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_GCC_WARN_SIGN_COMPARE "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_GCC_WARN_UNUSED_FUNCTION "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_GCC_WARN_INITIALIZER_NOT_FULLY_BRACKETED "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_GCC_WARN_UNINITIALIZED_AUTOS "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_CLANG_WARN_BOOL_CONVERSION "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_CLANG_WARN_EMPTY_BODY "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_CLANG_WARN_ENUM_CONVERSION "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_CLANG_WARN_INT_CONVERSION "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_CLANG_WARN_CONSTANT_CONVERSION "YES" )
set ( CMAKE_XCODE_ATTRIBUTE_GCC_WARN_NON_VIRTUAL_DESTRUCTOR "YES" )
endif ( )
2012-04-21 22:50:56 +08:00
# On Win32 using MS tools, provide an option to set the number of parallel jobs
# to use.
2012-04-21 22:51:02 +08:00
if ( MSVC_IDE )
2011-03-03 01:47:37 +08:00
set ( LLVM_COMPILER_JOBS "0" CACHE STRING
" N u m b e r o f p a r a l l e l c o m p i l e r j o b s . 0 m e a n s u s e a l l p r o c e s s o r s . D e f a u l t i s 0 . " )
if ( NOT LLVM_COMPILER_JOBS STREQUAL "1" )
if ( LLVM_COMPILER_JOBS STREQUAL "0" )
2017-03-21 12:03:24 +08:00
add_definitions ( /MP )
2011-03-03 01:47:37 +08:00
else ( )
2014-03-25 17:34:20 +08:00
message ( STATUS "Number of parallel compiler jobs set to " ${ LLVM_COMPILER_JOBS } )
2017-03-21 12:03:24 +08:00
add_definitions ( /MP ${ LLVM_COMPILER_JOBS } )
2011-03-03 01:47:37 +08:00
endif ( )
else ( )
message ( STATUS "Parallel compilation disabled" )
endif ( )
endif ( )
2016-09-01 06:43:23 +08:00
# set stack reserved size to ~10MB
if ( MSVC )
# CMake previously automatically set this value for MSVC builds, but the
# behavior was changed in CMake 2.8.11 (Issue 12437) to use the MSVC default
# value (1 MB) which is not enough for us in tasks such as parsing recursive
# C++ templates in Clang.
set ( CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} /STACK:10000000" )
elseif ( MINGW ) # FIXME: Also cygwin?
set ( CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,--stack,16777216" )
2016-12-23 03:12:14 +08:00
2021-05-15 04:45:07 +08:00
# Pass -mbig-obj to mingw gas to avoid COFF 2**16 section limit.
2021-05-19 04:36:50 +08:00
if ( NOT CMAKE_CXX_COMPILER_ID MATCHES "Clang" )
2016-12-23 03:12:14 +08:00
append ( "-Wa,-mbig-obj" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
endif ( )
2016-09-01 06:43:23 +08:00
endif ( )
2020-09-22 01:22:51 +08:00
option ( LLVM_ENABLE_WARNINGS "Enable compiler warnings." ON )
2011-02-04 04:57:36 +08:00
if ( MSVC )
include ( ChooseMSVCCRT )
# Add definitions that make MSVC much less annoying.
2017-03-21 12:03:24 +08:00
add_definitions (
2011-02-04 04:57:36 +08:00
# For some reason MS wants to deprecate a bunch of standard functions...
- D _ C R T _ S E C U R E _ N O _ D E P R E C A T E
- D _ C R T _ S E C U R E _ N O _ W A R N I N G S
- D _ C R T _ N O N S T D C _ N O _ D E P R E C A T E
- D _ C R T _ N O N S T D C _ N O _ W A R N I N G S
- D _ S C L _ S E C U R E _ N O _ D E P R E C A T E
- D _ S C L _ S E C U R E _ N O _ W A R N I N G S
2015-03-20 00:32:47 +08:00
)
2011-02-04 04:57:36 +08:00
2016-06-24 03:02:09 +08:00
# Tell MSVC to use the Unicode version of the Win32 APIs instead of ANSI.
2017-03-21 12:03:24 +08:00
add_definitions (
2016-06-24 03:02:09 +08:00
- D U N I C O D E
- D _ U N I C O D E
)
2021-02-17 23:03:02 +08:00
if ( LLVM_WINSYSROOT )
if ( NOT CLANG_CL )
message ( ERROR "LLVM_WINSYSROOT requires clang-cl" )
endif ( )
append ( "/winsysroot${LLVM_WINSYSROOT}" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
endif ( )
2011-02-04 04:57:36 +08:00
if ( LLVM_ENABLE_WERROR )
2017-03-17 01:05:16 +08:00
append ( "/WX" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2011-02-04 04:57:36 +08:00
endif ( LLVM_ENABLE_WERROR )
2015-03-20 00:32:47 +08:00
2015-08-13 01:09:25 +08:00
append ( "/Zc:inline" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2020-07-17 20:58:28 +08:00
# Some projects use the __cplusplus preprocessor macro to check support for
# a particular version of the C++ standard. When this option is not specified
# explicitly, macro's value is "199711L" that implies C++98 Standard.
# https://devblogs.microsoft.com/cppblog/msvc-now-correctly-reports-__cplusplus/
append ( "/Zc:__cplusplus" CMAKE_CXX_FLAGS )
2018-02-16 05:25:23 +08:00
# Allow users to request PDBs in release mode. CMake offeres the
# RelWithDebInfo configuration, but it uses different optimization settings
# (/Ob1 vs /Ob2 or -O2 vs -O3). LLVM provides this flag so that users can get
# PDBs without changing codegen.
option ( LLVM_ENABLE_PDB OFF )
if ( LLVM_ENABLE_PDB AND uppercase_CMAKE_BUILD_TYPE STREQUAL "RELEASE" )
2018-02-08 03:37:52 +08:00
append ( "/Zi" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2018-02-16 05:25:23 +08:00
# /DEBUG disables linker GC and ICF, but we want those in Release mode.
append ( "/DEBUG /OPT:REF /OPT:ICF"
C M A K E _ E X E _ L I N K E R _ F L A G S C M A K E _ M O D U L E _ L I N K E R _ F L A G S
C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
endif ( )
2018-02-08 03:37:52 +08:00
2021-05-28 05:32:48 +08:00
# Get all linker flags in upper case form so we can search them.
2022-01-06 09:21:46 +08:00
string ( CONCAT all_linker_flags_uppercase
2022-01-15 10:42:03 +08:00
$ { C M A K E _ E X E _ L I N K E R _ F L A G S _ $ { u p p e r c a s e _ C M A K E _ B U I L D _ T Y P E } } " "
$ { C M A K E _ E X E _ L I N K E R _ F L A G S } " "
$ { C M A K E _ M O D U L E _ L I N K E R _ F L A G S _ $ { u p p e r c a s e _ C M A K E _ B U I L D _ T Y P E } } " "
$ { C M A K E _ M O D U L E _ L I N K E R _ F L A G S } " "
$ { C M A K E _ S H A R E D _ L I N K E R _ F L A G S _ $ { u p p e r c a s e _ C M A K E _ B U I L D _ T Y P E } } " "
2022-01-06 09:21:46 +08:00
$ { C M A K E _ S H A R E D _ L I N K E R _ F L A G S } )
2021-05-28 05:32:48 +08:00
string ( TOUPPER "${all_linker_flags_uppercase}" all_linker_flags_uppercase )
if ( CLANG_CL AND LINKER_IS_LLD )
# If we are using clang-cl with lld-link and /debug is present in any of the
# linker flag variables, pass -gcodeview-ghash to the compiler to speed up
# linking. This flag is orthogonal from /Zi, /Z7, and other flags that
# enable debug info emission, and only has an effect if those are also in
# use.
string ( FIND "${all_linker_flags_uppercase}" "/DEBUG" linker_flag_idx )
if ( ${ linker_flag_idx } GREATER -1 )
add_flag_if_supported ( "-gcodeview-ghash" GCODEVIEW_GHASH )
endif ( )
endif ( )
2016-01-25 22:17:39 +08:00
# "Generate Intrinsic Functions".
append ( "/Oi" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2017-03-02 03:22:18 +08:00
if ( CMAKE_CXX_COMPILER_ID MATCHES "Clang" AND NOT LLVM_ENABLE_LTO )
2016-01-07 03:05:19 +08:00
# clang-cl and cl by default produce non-deterministic binaries because
# link.exe /incremental requires a timestamp in the .obj file. clang-cl
2016-05-06 03:57:03 +08:00
# has the flag /Brepro to force deterministic binaries. We want to pass that
2017-03-02 03:22:18 +08:00
# whenever you're building with clang unless you're passing /incremental
# or using LTO (/Brepro with LTO would result in a warning about the flag
# being unused, because we're not generating object files).
2016-01-07 03:05:19 +08:00
# This checks CMAKE_CXX_COMPILER_ID in addition to check_cxx_compiler_flag()
# because cl.exe does not emit an error on flags it doesn't understand,
# letting check_cxx_compiler_flag() claim it understands all flags.
check_cxx_compiler_flag ( "/Brepro" SUPPORTS_BREPRO )
if ( SUPPORTS_BREPRO )
# Check if /INCREMENTAL is passed to the linker and complain that it
# won't work with /Brepro.
2022-01-25 05:42:39 +08:00
has_msvc_incremental_no_flag ( "${CMAKE_EXE_LINKER_FLAGS_${uppercase_CMAKE_BUILD_TYPE}} ${CMAKE_EXE_LINKER_FLAGS}" NO_INCR_EXE )
has_msvc_incremental_no_flag ( "${CMAKE_MODULE_LINKER_FLAGS_${uppercase_CMAKE_BUILD_TYPE}} ${CMAKE_MODULE_LINKER_FLAGS}" NO_INCR_MODULE )
has_msvc_incremental_no_flag ( "${CMAKE_SHARED_LINKER_FLAGS_${uppercase_CMAKE_BUILD_TYPE}} ${CMAKE_SHARED_LINKER_FLAGS}" NO_INCR_SHARED )
if ( NO_INCR_EXE AND NO_INCR_MODULE AND NO_INCR_SHARED )
2016-05-06 03:57:03 +08:00
append ( "/Brepro" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2022-01-25 05:42:39 +08:00
else ( )
message ( WARNING "/Brepro not compatible with /INCREMENTAL linking - builds will be non-deterministic" )
2016-01-07 03:05:19 +08:00
endif ( )
endif ( )
endif ( )
2020-07-29 06:59:33 +08:00
# By default MSVC has a 2^16 limit on the number of sections in an object file,
# but in many objects files need more than that. This flag is to increase the
# number of sections.
append ( "/bigobj" CMAKE_CXX_FLAGS )
2022-06-21 03:39:00 +08:00
# Enable standards conformance mode.
# This ensures handling of various C/C++ constructs is more similar to other compilers.
append ( "/permissive-" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2019-08-19 06:02:24 +08:00
endif ( MSVC )
2016-01-07 03:05:19 +08:00
2019-08-19 06:02:24 +08:00
# Warnings-as-errors handling for GCC-compatible compilers:
if ( LLVM_COMPILER_IS_GCC_COMPATIBLE )
append_if ( LLVM_ENABLE_WERROR "-Werror" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
append_if ( LLVM_ENABLE_WERROR "-Wno-error" CMAKE_REQUIRED_FLAGS )
endif ( LLVM_COMPILER_IS_GCC_COMPATIBLE )
# Specific default warnings-as-errors for compilers accepting GCC-compatible warning flags:
if ( LLVM_COMPILER_IS_GCC_COMPATIBLE OR CMAKE_CXX_COMPILER_ID MATCHES "XL" )
add_flag_if_supported ( "-Werror=date-time" WERROR_DATE_TIME )
add_flag_if_supported ( "-Werror=unguarded-availability-new" WERROR_UNGUARDED_AVAILABILITY_NEW )
endif ( LLVM_COMPILER_IS_GCC_COMPATIBLE OR CMAKE_CXX_COMPILER_ID MATCHES "XL" )
# Modules enablement for GCC-compatible compilers:
if ( LLVM_COMPILER_IS_GCC_COMPATIBLE AND LLVM_ENABLE_MODULES )
set ( OLD_CMAKE_REQUIRED_FLAGS ${ CMAKE_REQUIRED_FLAGS } )
set ( module_flags "-fmodules -fmodules-cache-path=${PROJECT_BINARY_DIR}/module.cache" )
if ( ${ CMAKE_SYSTEM_NAME } MATCHES "Darwin" )
# On Darwin -fmodules does not imply -fcxx-modules.
set ( module_flags "${module_flags} -fcxx-modules" )
endif ( )
if ( LLVM_ENABLE_LOCAL_SUBMODULE_VISIBILITY )
set ( module_flags "${module_flags} -Xclang -fmodules-local-submodule-visibility" )
endif ( )
if ( LLVM_ENABLE_MODULE_DEBUGGING AND
( ( u p p e r c a s e _ C M A K E _ B U I L D _ T Y P E S T R E Q U A L " D E B U G " ) O R
( u p p e r c a s e _ C M A K E _ B U I L D _ T Y P E S T R E Q U A L " R E L W I T H D E B I N F O " ) ) )
set ( module_flags "${module_flags} -gmodules" )
endif ( )
set ( CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} ${module_flags}" )
# Check that we can build code with modules enabled, and that repeatedly
# including <cassert> still manages to respect NDEBUG properly.
CHECK_CXX_SOURCE_COMPILES ( " #undef NDEBUG
#include <cassert>
#define NDEBUG
#include <cassert>
i n t main ( ) { assert ( this code is not compiled ) ; } "
C X X _ S U P P O R T S _ M O D U L E S )
set ( CMAKE_REQUIRED_FLAGS ${ OLD_CMAKE_REQUIRED_FLAGS } )
if ( CXX_SUPPORTS_MODULES )
append ( "${module_flags}" CMAKE_CXX_FLAGS )
else ( )
message ( FATAL_ERROR "LLVM_ENABLE_MODULES is not supported by this compiler" )
endif ( )
endif ( LLVM_COMPILER_IS_GCC_COMPATIBLE AND LLVM_ENABLE_MODULES )
2011-02-04 04:57:36 +08:00
2017-11-30 02:05:32 +08:00
if ( MSVC )
if ( NOT CLANG_CL )
set ( msvc_warning_flags
# Disabled warnings.
- w d 4 1 4 1 # Suppress ''modifier' : used more than once' (because of __forceinline combined with inline)
- w d 4 1 4 6 # Suppress 'unary minus operator applied to unsigned type, result still unsigned'
- w d 4 2 4 4 # Suppress ''argument' : conversion from 'type1' to 'type2', possible loss of data'
- w d 4 2 6 7 # Suppress ''var' : conversion from 'size_t' to 'type', possible loss of data'
- w d 4 2 9 1 # Suppress ''declaration' : no matching operator delete found; memory will not be freed if initialization throws an exception'
- w d 4 3 5 1 # Suppress 'new behavior: elements of array 'array' will be default initialized'
- w d 4 4 5 6 # Suppress 'declaration of 'var' hides local variable'
- w d 4 4 5 7 # Suppress 'declaration of 'var' hides function parameter'
- w d 4 4 5 8 # Suppress 'declaration of 'var' hides class member'
- w d 4 4 5 9 # Suppress 'declaration of 'var' hides global declaration'
- w d 4 5 0 3 # Suppress ''identifier' : decorated name length exceeded, name was truncated'
- w d 4 6 2 4 # Suppress ''derived class' : destructor could not be generated because a base class destructor is inaccessible'
- w d 4 7 2 2 # Suppress 'function' : destructor never returns, potential memory leak
- w d 4 1 0 0 # Suppress 'unreferenced formal parameter'
- w d 4 1 2 7 # Suppress 'conditional expression is constant'
- w d 4 5 1 2 # Suppress 'assignment operator could not be generated'
- w d 4 5 0 5 # Suppress 'unreferenced local function has been removed'
- w d 4 6 1 0 # Suppress '<class> can never be instantiated'
- w d 4 5 1 0 # Suppress 'default constructor could not be generated'
- w d 4 7 0 2 # Suppress 'unreachable code'
2019-09-04 00:11:37 +08:00
- w d 4 2 4 5 # Suppress ''conversion' : conversion from 'type1' to 'type2', signed/unsigned mismatch'
2017-11-30 02:05:32 +08:00
- w d 4 7 0 6 # Suppress 'assignment within conditional expression'
- w d 4 3 1 0 # Suppress 'cast truncates constant value'
- w d 4 7 0 1 # Suppress 'potentially uninitialized local variable'
- w d 4 7 0 3 # Suppress 'potentially uninitialized local pointer variable'
- w d 4 3 8 9 # Suppress 'signed/unsigned mismatch'
- w d 4 6 1 1 # Suppress 'interaction between '_setjmp' and C++ object destruction is non-portable'
- w d 4 8 0 5 # Suppress 'unsafe mix of type <type> and type <type> in operation'
- w d 4 2 0 4 # Suppress 'nonstandard extension used : non-constant aggregate initializer'
- w d 4 5 7 7 # Suppress 'noexcept used with no exception handling mode specified; termination on exception is not guaranteed'
- w d 4 0 9 1 # Suppress 'typedef: ignored on left of '' when no variable is declared'
# C4592 is disabled because of false positives in Visual Studio 2015
# Update 1. Re-evaluate the usefulness of this diagnostic with Update 2.
- w d 4 5 9 2 # Suppress ''var': symbol will be dynamically initialized (implementation limitation)
- w d 4 3 1 9 # Suppress ''operator' : zero extending 'type' to 'type' of greater size'
2018-11-21 04:50:04 +08:00
# C4709 is disabled because of a bug with Visual Studio 2017 as of
# v15.8.8. Re-evaluate the usefulness of this diagnostic when the bug
# is fixed.
- w d 4 7 0 9 # Suppress comma operator within array index expression
2017-11-30 02:05:32 +08:00
2019-08-20 19:20:05 +08:00
# Ideally, we'd like this warning to be enabled, but even MSVC 2019 doesn't
2019-07-31 19:06:05 +08:00
# support the 'aligned' attribute in the way that clang sources requires (for
# any code that uses the LLVM_ALIGNAS macro), so this is must be disabled to
# avoid unwanted alignment warnings.
- w d 4 3 2 4 # Suppress 'structure was padded due to __declspec(align())'
2017-11-30 02:05:32 +08:00
# Promoted warnings.
- w 1 4 0 6 2 # Promote 'enumerator in switch of enum is not handled' to level 1 warning.
# Promoted warnings to errors.
- w e 4 2 3 8 # Promote 'nonstandard extension used : class rvalue used as lvalue' to error.
)
endif ( NOT CLANG_CL )
2017-03-17 01:05:16 +08:00
# Enable warnings
if ( LLVM_ENABLE_WARNINGS )
# Put /W4 in front of all the -we flags. cl.exe doesn't care, but for
# clang-cl having /W4 after the -we flags will re-enable the warnings
# disabled by -we.
set ( msvc_warning_flags "/W4 ${msvc_warning_flags}" )
# CMake appends /W3 by default, and having /W3 followed by /W4 will result in
# cl : Command line warning D9025 : overriding '/W3' with '/W4'. Since this is
# a command line warning and not a compiler warning, it cannot be suppressed except
# by fixing the command line.
string ( REGEX REPLACE " /W[0-4]" "" CMAKE_C_FLAGS "${CMAKE_C_FLAGS}" )
string ( REGEX REPLACE " /W[0-4]" "" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}" )
if ( LLVM_ENABLE_PEDANTIC )
# No MSVC equivalent available
endif ( LLVM_ENABLE_PEDANTIC )
endif ( LLVM_ENABLE_WARNINGS )
foreach ( flag ${ msvc_warning_flags } )
append ( "${flag}" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
endforeach ( flag )
2017-11-30 02:05:32 +08:00
endif ( MSVC )
2017-03-17 01:05:16 +08:00
if ( LLVM_ENABLE_WARNINGS AND ( LLVM_COMPILER_IS_GCC_COMPATIBLE OR CLANG_CL ) )
2017-11-30 02:05:32 +08:00
# Don't add -Wall for clang-cl, because it maps -Wall to -Weverything for
# MSVC compatibility. /W4 is added above instead.
if ( NOT CLANG_CL )
append ( "-Wall" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
endif ( )
2018-05-31 21:41:04 +08:00
append ( "-Wextra -Wno-unused-parameter -Wwrite-strings" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2017-03-17 01:05:16 +08:00
append ( "-Wcast-qual" CMAKE_CXX_FLAGS )
# Turn off missing field initializer warnings for gcc to avoid noise from
# false positives with empty {}. Turn them on otherwise (they're off by
# default for clang).
check_cxx_compiler_flag ( "-Wmissing-field-initializers" CXX_SUPPORTS_MISSING_FIELD_INITIALIZERS_FLAG )
if ( CXX_SUPPORTS_MISSING_FIELD_INITIALIZERS_FLAG )
if ( CMAKE_COMPILER_IS_GNUCXX )
append ( "-Wno-missing-field-initializers" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
else ( )
append ( "-Wmissing-field-initializers" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
endif ( )
endif ( )
if ( LLVM_ENABLE_PEDANTIC AND LLVM_COMPILER_IS_GCC_COMPATIBLE )
append ( "-pedantic" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
append ( "-Wno-long-long" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2021-03-19 19:47:43 +08:00
# GCC warns about redundant toplevel semicolons (enabled by -pedantic
# above), while Clang doesn't. Enable the corresponding Clang option to
# pick up on these even in builds with Clang.
add_flag_if_supported ( "-Wc++98-compat-extra-semi" CXX98_COMPAT_EXTRA_SEMI_FLAG )
2017-03-17 01:05:16 +08:00
endif ( )
2018-11-02 04:31:44 +08:00
add_flag_if_supported ( "-Wimplicit-fallthrough" IMPLICIT_FALLTHROUGH_FLAG )
2017-03-17 01:05:16 +08:00
add_flag_if_supported ( "-Wcovered-switch-default" COVERED_SWITCH_DEFAULT_FLAG )
append_if ( USE_NO_UNINITIALIZED "-Wno-uninitialized" CMAKE_CXX_FLAGS )
append_if ( USE_NO_MAYBE_UNINITIALIZED "-Wno-maybe-uninitialized" CMAKE_CXX_FLAGS )
2018-07-20 04:14:46 +08:00
# Disable -Wclass-memaccess, a C++-only warning from GCC 8 that fires on
# LLVM's ADT classes.
check_cxx_compiler_flag ( "-Wclass-memaccess" CXX_SUPPORTS_CLASS_MEMACCESS_FLAG )
append_if ( CXX_SUPPORTS_CLASS_MEMACCESS_FLAG "-Wno-class-memaccess" CMAKE_CXX_FLAGS )
2021-03-19 19:45:52 +08:00
# Disable -Wredundant-move and -Wpessimizing-move on GCC>=9. GCC wants to
# remove std::move in code like "A foo(ConvertibleToA a) {
# return std::move(a); }", but this code does not compile (or uses the copy
# constructor instead) on clang<=3.8. Clang also has a -Wredundant-move and
# -Wpessimizing-move, but they only fire when the types match exactly, so we
# can keep them here.
2019-11-29 21:44:28 +08:00
if ( CMAKE_CXX_COMPILER_ID STREQUAL "GNU" )
check_cxx_compiler_flag ( "-Wredundant-move" CXX_SUPPORTS_REDUNDANT_MOVE_FLAG )
append_if ( CXX_SUPPORTS_REDUNDANT_MOVE_FLAG "-Wno-redundant-move" CMAKE_CXX_FLAGS )
2021-03-19 19:45:52 +08:00
check_cxx_compiler_flag ( "-Wpessimizing-move" CXX_SUPPORTS_PESSIMIZING_MOVE_FLAG )
append_if ( CXX_SUPPORTS_PESSIMIZING_MOVE_FLAG "-Wno-pessimizing-move" CMAKE_CXX_FLAGS )
2019-11-29 21:44:28 +08:00
endif ( )
2018-09-04 20:03:49 +08:00
# The LLVM libraries have no stable C++ API, so -Wnoexcept-type is not useful.
check_cxx_compiler_flag ( "-Wnoexcept-type" CXX_SUPPORTS_NOEXCEPT_TYPE_FLAG )
append_if ( CXX_SUPPORTS_NOEXCEPT_TYPE_FLAG "-Wno-noexcept-type" CMAKE_CXX_FLAGS )
2021-09-08 14:36:47 +08:00
# Check if -Wnon-virtual-dtor warns for a class marked final, when it has a
# friend declaration. If it does, don't add -Wnon-virtual-dtor. The case is
# considered unhelpful (https://gcc.gnu.org/PR102168).
set ( OLD_CMAKE_REQUIRED_FLAGS ${ CMAKE_REQUIRED_FLAGS } )
set ( CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} -Werror=non-virtual-dtor" )
CHECK_CXX_SOURCE_COMPILES ( " class f {};
c l a s s b a s e { f r i e n d f ; p u b l i c : v i r t u a l v o i d anchor ( ) ; p r o t e c t e d : ~ base ( ) ; } ;
i n t main ( ) { r e t u r n 0 ; } "
C X X _ W O N T _ W A R N _ O N _ F I N A L _ N O N V I R T U A L D T O R )
set ( CMAKE_REQUIRED_FLAGS ${ OLD_CMAKE_REQUIRED_FLAGS } )
append_if ( CXX_WONT_WARN_ON_FINAL_NONVIRTUALDTOR "-Wnon-virtual-dtor" CMAKE_CXX_FLAGS )
2021-09-01 02:19:04 +08:00
append ( "-Wdelete-non-virtual-dtor" CMAKE_CXX_FLAGS )
2017-03-17 01:05:16 +08:00
2020-07-23 08:44:52 +08:00
# Enable -Wsuggest-override if it's available, and only if it doesn't
# suggest adding 'override' to functions that are already marked 'final'
# (which means it is disabled for GCC < 9.2).
check_cxx_compiler_flag ( "-Wsuggest-override" CXX_SUPPORTS_SUGGEST_OVERRIDE_FLAG )
if ( CXX_SUPPORTS_SUGGEST_OVERRIDE_FLAG )
set ( OLD_CMAKE_REQUIRED_FLAGS ${ CMAKE_REQUIRED_FLAGS } )
set ( CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} -Werror=suggest-override" )
CHECK_CXX_SOURCE_COMPILES ( " class base {public: virtual void anchor( ) ; } ;
c l a s s d e r i v e d : b a s e { p u b l i c : v o i d anchor ( ) f i n a l ; } ;
i n t main ( ) { r e t u r n 0 ; } "
C X X _ W S U G G E S T _ O V E R R I D E _ A L L O W S _ O N L Y _ F I N A L )
set ( CMAKE_REQUIRED_FLAGS ${ OLD_CMAKE_REQUIRED_FLAGS } )
append_if ( CXX_WSUGGEST_OVERRIDE_ALLOWS_ONLY_FINAL "-Wsuggest-override" CMAKE_CXX_FLAGS )
endif ( )
2017-03-17 01:05:16 +08:00
# Check if -Wcomment is OK with an // comment ending with '\' if the next
# line is also a // comment.
set ( OLD_CMAKE_REQUIRED_FLAGS ${ CMAKE_REQUIRED_FLAGS } )
set ( CMAKE_REQUIRED_FLAGS "${CMAKE_REQUIRED_FLAGS} -Werror -Wcomment" )
CHECK_C_SOURCE_COMPILES ( "// \\\\\\n//\\nint main() {return 0;}"
C _ W C O M M E N T _ A L L O W S _ L I N E _ W R A P )
set ( CMAKE_REQUIRED_FLAGS ${ OLD_CMAKE_REQUIRED_FLAGS } )
if ( NOT C_WCOMMENT_ALLOWS_LINE_WRAP )
append ( "-Wno-comment" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
endif ( )
# Enable -Wstring-conversion to catch misuse of string literals.
add_flag_if_supported ( "-Wstring-conversion" STRING_CONVERSION_FLAG )
2021-05-08 05:16:47 +08:00
# Prevent bugs that can happen with llvm's brace style.
add_flag_if_supported ( "-Wmisleading-indentation" MISLEADING_INDENTATION_FLAG )
2017-03-17 01:05:16 +08:00
endif ( LLVM_ENABLE_WARNINGS AND ( LLVM_COMPILER_IS_GCC_COMPATIBLE OR CLANG_CL ) )
2017-04-13 04:43:11 +08:00
if ( LLVM_COMPILER_IS_GCC_COMPATIBLE AND NOT LLVM_ENABLE_WARNINGS )
append ( "-w" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
endif ( )
2013-03-26 15:49:46 +08:00
macro ( append_common_sanitizer_flags )
2015-08-15 00:48:34 +08:00
if ( NOT MSVC )
# Append -fno-omit-frame-pointer and turn on debug info to get better
# stack traces.
add_flag_if_supported ( "-fno-omit-frame-pointer" FNO_OMIT_FRAME_POINTER )
if ( NOT uppercase_CMAKE_BUILD_TYPE STREQUAL "DEBUG" AND
2015-08-26 00:06:40 +08:00
N O T u p p e r c a s e _ C M A K E _ B U I L D _ T Y P E S T R E Q U A L " R E L W I T H D E B I N F O " )
2015-08-15 00:48:34 +08:00
add_flag_if_supported ( "-gline-tables-only" GLINE_TABLES_ONLY )
endif ( )
# Use -O1 even in debug mode, otherwise sanitizers slowdown is too large.
2018-05-18 00:55:29 +08:00
if ( uppercase_CMAKE_BUILD_TYPE STREQUAL "DEBUG" AND LLVM_OPTIMIZE_SANITIZED_BUILDS )
2015-08-15 00:48:34 +08:00
add_flag_if_supported ( "-O1" O1 )
endif ( )
2022-05-31 22:13:24 +08:00
else ( )
2015-08-15 00:48:34 +08:00
# Always ask the linker to produce symbols with asan.
2019-05-21 11:01:01 +08:00
append ( "/Z7" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2022-05-31 22:13:24 +08:00
append ( "/debug" CMAKE_EXE_LINKER_FLAGS CMAKE_MODULE_LINKER_FLAGS CMAKE_SHARED_LINKER_FLAGS )
# Not compatible with /INCREMENTAL link.
foreach ( flags_opt_to_scrub
C M A K E _ E X E _ L I N K E R _ F L A G S C M A K E _ M O D U L E _ L I N K E R _ F L A G S C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
string ( REGEX REPLACE "(^| )/INCREMENTAL($| )" " /INCREMENTAL:NO "
" $ { f l a g s _ o p t _ t o _ s c r u b } " " $ { $ { f l a g s _ o p t _ t o _ s c r u b } } " )
endforeach ( )
if ( LLVM_HOST_TRIPLE MATCHES "i[2-6]86-.*" )
# Keep frame pointers around.
append ( "/Oy-" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
endif ( )
2013-09-02 17:15:01 +08:00
endif ( )
2013-03-26 15:49:46 +08:00
endmacro ( )
# Turn on sanitizers if necessary.
if ( LLVM_USE_SANITIZER )
if ( LLVM_ON_UNIX )
if ( LLVM_USE_SANITIZER STREQUAL "Address" )
append_common_sanitizer_flags ( )
2014-07-09 14:27:05 +08:00
append ( "-fsanitize=address" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2019-06-04 17:04:53 +08:00
elseif ( LLVM_USE_SANITIZER STREQUAL "HWAddress" )
append_common_sanitizer_flags ( )
append ( "-fsanitize=hwaddress" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2013-03-26 15:49:46 +08:00
elseif ( LLVM_USE_SANITIZER MATCHES "Memory(WithOrigins)?" )
append_common_sanitizer_flags ( )
2014-07-09 14:27:05 +08:00
append ( "-fsanitize=memory" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2013-03-26 15:49:46 +08:00
if ( LLVM_USE_SANITIZER STREQUAL "MemoryWithOrigins" )
2014-07-09 14:27:05 +08:00
append ( "-fsanitize-memory-track-origins" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2013-03-26 15:49:46 +08:00
endif ( )
2014-08-29 08:50:36 +08:00
elseif ( LLVM_USE_SANITIZER STREQUAL "Undefined" )
append_common_sanitizer_flags ( )
2020-10-15 10:09:50 +08:00
append ( "${LLVM_UBSAN_FLAGS}" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2014-11-19 05:23:38 +08:00
elseif ( LLVM_USE_SANITIZER STREQUAL "Thread" )
append_common_sanitizer_flags ( )
append ( "-fsanitize=thread" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2020-04-18 01:15:58 +08:00
elseif ( LLVM_USE_SANITIZER STREQUAL "DataFlow" )
append ( "-fsanitize=dataflow" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2015-02-05 06:33:31 +08:00
elseif ( LLVM_USE_SANITIZER STREQUAL "Address;Undefined" OR
L L V M _ U S E _ S A N I T I Z E R S T R E Q U A L " U n d e f i n e d ; A d d r e s s " )
append_common_sanitizer_flags ( )
2020-10-15 10:09:50 +08:00
append ( "-fsanitize=address" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
append ( "${LLVM_UBSAN_FLAGS}" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2017-06-21 04:28:07 +08:00
elseif ( LLVM_USE_SANITIZER STREQUAL "Leaks" )
append_common_sanitizer_flags ( )
append ( "-fsanitize=leak" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2013-03-26 15:49:46 +08:00
else ( )
2015-09-01 13:45:07 +08:00
message ( FATAL_ERROR "Unsupported value of LLVM_USE_SANITIZER: ${LLVM_USE_SANITIZER}" )
2013-03-26 15:49:46 +08:00
endif ( )
2021-02-09 05:04:04 +08:00
elseif ( MINGW )
if ( LLVM_USE_SANITIZER STREQUAL "Address" )
append_common_sanitizer_flags ( )
append ( "-fsanitize=address" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
elseif ( LLVM_USE_SANITIZER STREQUAL "Undefined" )
append_common_sanitizer_flags ( )
append ( "${LLVM_UBSAN_FLAGS}" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
elseif ( LLVM_USE_SANITIZER STREQUAL "Address;Undefined" OR
L L V M _ U S E _ S A N I T I Z E R S T R E Q U A L " U n d e f i n e d ; A d d r e s s " )
append_common_sanitizer_flags ( )
append ( "-fsanitize=address" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
append ( "${LLVM_UBSAN_FLAGS}" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
else ( )
message ( FATAL_ERROR "This sanitizer not yet supported in a MinGW environment: ${LLVM_USE_SANITIZER}" )
endif ( )
2015-08-15 00:48:34 +08:00
elseif ( MSVC )
if ( LLVM_USE_SANITIZER STREQUAL "Address" )
append_common_sanitizer_flags ( )
2022-05-31 22:13:24 +08:00
append ( "/fsanitize=address" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
if ( NOT CLANG_CL )
# Not compatible with /RTC flags.
foreach ( flags_opt_to_scrub
C M A K E _ C X X _ F L A G S _ $ { u p p e r c a s e _ C M A K E _ B U I L D _ T Y P E } C M A K E _ C _ F L A G S _ $ { u p p e r c a s e _ C M A K E _ B U I L D _ T Y P E } )
string ( REGEX REPLACE "(^| )/RTC[1csu]*($| )" " "
" $ { f l a g s _ o p t _ t o _ s c r u b } " " $ { $ { f l a g s _ o p t _ t o _ s c r u b } } " )
endforeach ( )
endif ( )
if ( LINKER_IS_LLD_LINK )
if ( LLVM_HOST_TRIPLE MATCHES "i[2-6]86-.*" )
set ( arch "i386" )
else ( )
set ( arch "x86_64" )
endif ( )
if ( ${ LLVM_USE_CRT_${uppercase_CMAKE_BUILD_TYPE } } MATCHES "^(MT|MTd)$" )
append ( "/wholearchive:clang_rt.asan-${arch}.lib /wholearchive:clang_rt.asan_cxx-${arch}.lib"
C M A K E _ E X E _ L I N K E R _ F L A G S )
append ( "/wholearchive:clang_rt.asan_dll_thunk-${arch}.lib"
C M A K E _ M O D U L E _ L I N K E R _ F L A G S C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
else ( )
append ( "clang_rt.asan_dynamic-${arch}.lib /wholearchive:clang_rt.asan_dynamic_runtime_thunk-${arch}.lib"
C M A K E _ E X E _ L I N K E R _ F L A G S C M A K E _ M O D U L E _ L I N K E R _ F L A G S C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
endif ( )
endif ( )
2015-08-15 00:48:34 +08:00
else ( )
2015-09-01 13:45:07 +08:00
message ( FATAL_ERROR "This sanitizer not yet supported in the MSVC environment: ${LLVM_USE_SANITIZER}" )
2015-08-15 00:48:34 +08:00
endif ( )
2013-03-26 15:49:46 +08:00
else ( )
2015-09-01 13:45:07 +08:00
message ( FATAL_ERROR "LLVM_USE_SANITIZER is not supported on this platform." )
2013-03-26 15:49:46 +08:00
endif ( )
2017-01-18 05:04:23 +08:00
if ( LLVM_USE_SANITIZER MATCHES "(Undefined;)?Address(;Undefined)?" )
2017-01-19 03:01:58 +08:00
add_flag_if_supported ( "-fsanitize-address-use-after-scope"
F S A N I T I Z E _ U S E _ A F T E R _ S C O P E _ F L A G )
2017-01-18 05:04:23 +08:00
endif ( )
2015-01-28 01:59:28 +08:00
if ( LLVM_USE_SANITIZE_COVERAGE )
2017-08-23 08:40:58 +08:00
append ( "-fsanitize=fuzzer-no-link" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2015-01-28 01:59:28 +08:00
endif ( )
2018-07-20 18:12:31 +08:00
if ( LLVM_USE_SANITIZER MATCHES ".*Undefined.*" )
2021-11-25 21:18:08 +08:00
set ( IGNORELIST_FILE "${CMAKE_SOURCE_DIR}/utils/sanitizers/ubsan_ignorelist.txt" )
if ( EXISTS "${IGNORELIST_FILE}" )
# Use this option name version since -fsanitize-ignorelist is only
# accepted with clang 13.0 or newer.
append ( "-fsanitize-blacklist=${IGNORELIST_FILE}"
2018-07-20 18:12:31 +08:00
C M A K E _ C _ F L A G S C M A K E _ C X X _ F L A G S )
endif ( )
endif ( )
2013-03-26 15:49:46 +08:00
endif ( )
2020-02-28 13:01:08 +08:00
# Turn on -gsplit-dwarf if requested in debug builds.
if ( LLVM_USE_SPLIT_DWARF AND
( ( u p p e r c a s e _ C M A K E _ B U I L D _ T Y P E S T R E Q U A L " D E B U G " ) O R
( u p p e r c a s e _ C M A K E _ B U I L D _ T Y P E S T R E Q U A L " R E L W I T H D E B I N F O " ) ) )
# Limit to clang and gcc so far. Add compilers supporting this option.
if ( CMAKE_CXX_COMPILER_ID MATCHES "Clang" OR
C M A K E _ C X X _ C O M P I L E R _ I D S T R E Q U A L " G N U " )
add_compile_options ( -gsplit-dwarf )
2021-08-26 06:25:27 +08:00
include ( LLVMCheckLinkerFlag )
llvm_check_linker_flag ( CXX "-Wl,--gdb-index" LINKER_SUPPORTS_GDB_INDEX )
append_if ( LINKER_SUPPORTS_GDB_INDEX "-Wl,--gdb-index"
C M A K E _ E X E _ L I N K E R _ F L A G S C M A K E _ M O D U L E _ L I N K E R _ F L A G S C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
2020-02-28 13:01:08 +08:00
endif ( )
2013-07-31 05:44:10 +08:00
endif ( )
2017-03-21 12:03:24 +08:00
add_definitions ( -D__STDC_CONSTANT_MACROS )
add_definitions ( -D__STDC_FORMAT_MACROS )
add_definitions ( -D__STDC_LIMIT_MACROS )
2013-05-30 04:41:35 +08:00
2018-05-19 10:36:27 +08:00
# clang and gcc don't default-print colored diagnostics when invoked from Ninja.
2013-06-15 03:41:05 +08:00
if ( UNIX AND
2022-01-25 09:49:37 +08:00
C M A K E _ G E N E R A T O R M A T C H E S " N i n j a " A N D
2018-05-19 10:36:27 +08:00
( C M A K E _ C X X _ C O M P I L E R _ I D M A T C H E S " C l a n g " O R
( C M A K E _ C X X _ C O M P I L E R _ I D S T R E Q U A L " G N U " A N D
NOT ( CMAKE_CXX_COMPILER_VERSION VERSION_LESS 4.9 ) ) ) )
append ( "-fdiagnostics-color" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2013-05-30 04:41:35 +08:00
endif ( )
2014-01-28 17:43:55 +08:00
2017-01-12 06:55:35 +08:00
# lld doesn't print colored diagnostics when invoked from Ninja
2022-01-25 09:49:37 +08:00
if ( UNIX AND CMAKE_GENERATOR MATCHES "Ninja" )
2021-04-03 14:51:17 +08:00
include ( LLVMCheckLinkerFlag )
llvm_check_linker_flag ( CXX "-Wl,--color-diagnostics" LINKER_SUPPORTS_COLOR_DIAGNOSTICS )
2017-07-13 05:37:02 +08:00
append_if ( LINKER_SUPPORTS_COLOR_DIAGNOSTICS "-Wl,--color-diagnostics"
2017-01-12 06:55:35 +08:00
C M A K E _ E X E _ L I N K E R _ F L A G S C M A K E _ M O D U L E _ L I N K E R _ F L A G S C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
endif ( )
2014-01-28 17:43:55 +08:00
# Add flags for add_dead_strip().
# FIXME: With MSVS, consider compiling with /Gy and linking with /OPT:REF?
# But MinSizeRel seems to add that automatically, so maybe disable these
2019-10-31 02:56:20 +08:00
# flags instead if LLVM_NO_DEAD_STRIP is set.
2021-04-21 13:35:40 +08:00
if ( NOT CYGWIN AND NOT MSVC )
2015-04-06 22:34:43 +08:00
if ( NOT ${ CMAKE_SYSTEM_NAME } MATCHES "Darwin" AND
N O T u p p e r c a s e _ C M A K E _ B U I L D _ T Y P E S T R E Q U A L " D E B U G " )
2014-02-04 16:15:46 +08:00
check_c_compiler_flag ( "-Werror -fno-function-sections" C_SUPPORTS_FNO_FUNCTION_SECTIONS )
if ( C_SUPPORTS_FNO_FUNCTION_SECTIONS )
2020-01-15 23:42:12 +08:00
# Don't add -ffunction-sections if it can't be disabled with -fno-function-sections.
2014-02-04 16:15:46 +08:00
# Doing so will break sanitizers.
2014-07-09 11:38:19 +08:00
add_flag_if_supported ( "-ffunction-sections" FFUNCTION_SECTIONS )
2020-01-15 23:42:12 +08:00
elseif ( CMAKE_CXX_COMPILER_ID MATCHES "XL" )
append ( "-qfuncsect" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
2014-02-03 21:57:09 +08:00
endif ( )
2014-07-09 11:38:19 +08:00
add_flag_if_supported ( "-fdata-sections" FDATA_SECTIONS )
2014-01-28 17:43:55 +08:00
endif ( )
[windows] Add /Gw to compiler flags
This is like -fdata-sections, and it's not part of /O2 by default for some reason.
In the cmake build, reduces the size of clang.exe from 70,358,016 bytes to 69,982,720 bytes.
clang-format.exe goes from 3,703,296 bytes to 3,331,072 bytes.
Differential Revision: https://reviews.llvm.org/D74573
2020-02-15 04:15:00 +08:00
elseif ( MSVC )
if ( NOT uppercase_CMAKE_BUILD_TYPE STREQUAL "DEBUG" )
append ( "/Gw" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
endif ( )
2014-01-28 17:43:55 +08:00
endif ( )
2014-01-28 17:44:06 +08:00
if ( MSVC )
# Remove flags here, for exceptions and RTTI.
2014-02-01 01:32:36 +08:00
# Each target property or source property should be responsible to control
# them.
2014-01-28 17:44:06 +08:00
# CL.EXE complains to override flags like "/GR /GR-".
string ( REGEX REPLACE "(^| ) */EH[-cs]+ *( |$)" "\\1 \\2" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}" )
string ( REGEX REPLACE "(^| ) */GR-? *( |$)" "\\1 \\2" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}" )
endif ( )
2014-07-04 12:45:40 +08:00
2014-07-22 23:41:18 +08:00
# Provide public options to globally control RTTI and EH
option ( LLVM_ENABLE_EH "Enable Exception handling" OFF )
option ( LLVM_ENABLE_RTTI "Enable run time type information" OFF )
if ( LLVM_ENABLE_EH AND NOT LLVM_ENABLE_RTTI )
message ( FATAL_ERROR "Exception handling requires RTTI. You must set LLVM_ENABLE_RTTI to ON" )
endif ( )
2017-11-09 05:26:40 +08:00
option ( LLVM_ENABLE_IR_PGO "Build LLVM and tools with IR PGO instrumentation (deprecated)" Off )
2017-09-21 01:16:01 +08:00
mark_as_advanced ( LLVM_ENABLE_IR_PGO )
2017-11-09 05:26:40 +08:00
set ( LLVM_BUILD_INSTRUMENTED OFF CACHE STRING "Build LLVM and tools with PGO instrumentation. May be specified as IR or Frontend" )
2020-12-15 14:41:22 +08:00
set ( LLVM_VP_COUNTERS_PER_SITE "1.5" CACHE STRING "Value profile counters to use per site for IR PGO with Clang" )
mark_as_advanced ( LLVM_BUILD_INSTRUMENTED LLVM_VP_COUNTERS_PER_SITE )
2017-11-09 05:26:40 +08:00
string ( TOUPPER "${LLVM_BUILD_INSTRUMENTED}" uppercase_LLVM_BUILD_INSTRUMENTED )
2017-09-21 01:16:01 +08:00
if ( LLVM_BUILD_INSTRUMENTED )
2017-11-09 05:26:40 +08:00
if ( LLVM_ENABLE_IR_PGO OR uppercase_LLVM_BUILD_INSTRUMENTED STREQUAL "IR" )
2019-09-18 17:43:13 +08:00
append ( "-fprofile-generate=\" ${ LLVM_PROFILE_DATA_DIR } \""
2017-09-21 01:16:01 +08:00
C M A K E _ C X X _ F L A G S
2019-09-18 17:43:13 +08:00
C M A K E _ C _ F L A G S )
if ( NOT LINKER_IS_LLD_LINK )
append ( "-fprofile-generate=\" ${ LLVM_PROFILE_DATA_DIR } \""
C M A K E _ E X E _ L I N K E R _ F L A G S
C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
endif ( )
2020-12-10 07:04:55 +08:00
# Set this to avoid running out of the value profile node section
# under clang in dynamic linking mode.
if ( CMAKE_CXX_COMPILER_ID MATCHES "Clang" AND
C M A K E _ C X X _ C O M P I L E R _ V E R S I O N V E R S I O N _ G R E A T E R _ E Q U A L 1 1 A N D
L L V M _ L I N K _ L L V M _ D Y L I B )
2020-12-15 14:41:22 +08:00
append ( "-Xclang -mllvm -Xclang -vp-counters-per-site=${LLVM_VP_COUNTERS_PER_SITE}"
2020-12-10 07:04:55 +08:00
C M A K E _ C X X _ F L A G S
C M A K E _ C _ F L A G S )
endif ( )
2019-03-07 03:31:37 +08:00
elseif ( uppercase_LLVM_BUILD_INSTRUMENTED STREQUAL "CSIR" )
2019-09-18 17:43:13 +08:00
append ( "-fcs-profile-generate=\" ${ LLVM_CSPROFILE_DATA_DIR } \""
2019-03-07 03:31:37 +08:00
C M A K E _ C X X _ F L A G S
2019-09-18 17:43:13 +08:00
C M A K E _ C _ F L A G S )
if ( NOT LINKER_IS_LLD_LINK )
append ( "-fcs-profile-generate=\" ${ LLVM_CSPROFILE_DATA_DIR } \""
C M A K E _ E X E _ L I N K E R _ F L A G S
C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
endif ( )
2017-09-21 01:16:01 +08:00
else ( )
2019-09-18 17:43:13 +08:00
append ( "-fprofile-instr-generate=\" ${ LLVM_PROFILE_FILE_PATTERN } \""
2017-09-21 01:16:01 +08:00
C M A K E _ C X X _ F L A G S
2019-09-18 17:43:13 +08:00
C M A K E _ C _ F L A G S )
if ( NOT LINKER_IS_LLD_LINK )
append ( "-fprofile-instr-generate=\" ${ LLVM_PROFILE_FILE_PATTERN } \""
C M A K E _ E X E _ L I N K E R _ F L A G S
C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
endif ( )
2017-09-21 01:16:01 +08:00
endif ( )
endif ( )
2016-06-14 07:33:48 +08:00
[Windows] Autolink with basenames and add libdir to libpath
Prior to this change, for a few compiler-rt libraries such as ubsan and
the profile library, Clang would embed "-defaultlib:path/to/rt-arch.lib"
into the .drective section of every object compiled with
-finstr-profile-generate or -fsanitize=ubsan as appropriate.
These paths assume that the link step will run from the same working
directory as the compile step. There is also evidence that sometimes the
paths become absolute, such as when clang is run from a different drive
letter from the current working directory. This is fragile, and I'd like
to get away from having paths embedded in the object if possible. Long
ago it was suggested that we use this for ASan, and apparently I felt
the same way back then:
https://reviews.llvm.org/D4428#56536
This is also consistent with how all other autolinking usage works for
PS4, Mac, and Windows: they all use basenames, not paths.
To keep things working for people using the standard GCC driver
workflow, the driver now adds the resource directory to the linker
library search path when it calls the linker. This is enough to make
check-ubsan pass, and seems like a generally good thing.
Users that invoke the linker directly (most clang-cl users) will have to
add clang's resource library directory to their linker search path in
their build system. I'm not sure where I can document this. Ideally I'd
also do it in the MSBuild files, but I can't figure out where they go.
I'd like to start with this for now.
Reviewed By: hans
Differential Revision: https://reviews.llvm.org/D65543
2019-08-01 05:52:00 +08:00
# When using clang-cl with an instrumentation-based tool, add clang's library
# resource directory to the library search path. Because cmake invokes the
# linker directly, it isn't sufficient to pass -fsanitize=* to the linker.
if ( CLANG_CL AND ( LLVM_BUILD_INSTRUMENTED OR LLVM_USE_SANITIZER ) )
execute_process (
2021-03-18 16:24:49 +08:00
C O M M A N D $ { C M A K E _ C X X _ C O M P I L E R } / c l a n g : - p r i n t - l i b g c c - f i l e - n a m e / c l a n g : - - r t l i b = c o m p i l e r - r t
O U T P U T _ V A R I A B L E c l a n g _ c o m p i l e r _ r t _ f i l e
[Windows] Autolink with basenames and add libdir to libpath
Prior to this change, for a few compiler-rt libraries such as ubsan and
the profile library, Clang would embed "-defaultlib:path/to/rt-arch.lib"
into the .drective section of every object compiled with
-finstr-profile-generate or -fsanitize=ubsan as appropriate.
These paths assume that the link step will run from the same working
directory as the compile step. There is also evidence that sometimes the
paths become absolute, such as when clang is run from a different drive
letter from the current working directory. This is fragile, and I'd like
to get away from having paths embedded in the object if possible. Long
ago it was suggested that we use this for ASan, and apparently I felt
the same way back then:
https://reviews.llvm.org/D4428#56536
This is also consistent with how all other autolinking usage works for
PS4, Mac, and Windows: they all use basenames, not paths.
To keep things working for people using the standard GCC driver
workflow, the driver now adds the resource directory to the linker
library search path when it calls the linker. This is enough to make
check-ubsan pass, and seems like a generally good thing.
Users that invoke the linker directly (most clang-cl users) will have to
add clang's resource library directory to their linker search path in
their build system. I'm not sure where I can document this. Ideally I'd
also do it in the MSBuild files, but I can't figure out where they go.
I'd like to start with this for now.
Reviewed By: hans
Differential Revision: https://reviews.llvm.org/D65543
2019-08-01 05:52:00 +08:00
E R R O R _ V A R I A B L E c l a n g _ c l _ s t d e r r
O U T P U T _ S T R I P _ T R A I L I N G _ W H I T E S P A C E
E R R O R _ S T R I P _ T R A I L I N G _ W H I T E S P A C E
R E S U L T _ V A R I A B L E c l a n g _ c l _ e x i t _ c o d e )
if ( NOT "${clang_cl_exit_code}" STREQUAL "0" )
message ( FATAL_ERROR
" U n a b l e t o i n v o k e c l a n g - c l t o f i n d r e s o u r c e d i r : $ { c l a n g _ c l _ s t d e r r } " )
endif ( )
2021-03-18 16:24:49 +08:00
file ( TO_CMAKE_PATH "${clang_compiler_rt_file}" clang_compiler_rt_file )
get_filename_component ( clang_runtime_dir "${clang_compiler_rt_file}" DIRECTORY )
append ( "/libpath:${clang_runtime_dir}"
[Windows] Autolink with basenames and add libdir to libpath
Prior to this change, for a few compiler-rt libraries such as ubsan and
the profile library, Clang would embed "-defaultlib:path/to/rt-arch.lib"
into the .drective section of every object compiled with
-finstr-profile-generate or -fsanitize=ubsan as appropriate.
These paths assume that the link step will run from the same working
directory as the compile step. There is also evidence that sometimes the
paths become absolute, such as when clang is run from a different drive
letter from the current working directory. This is fragile, and I'd like
to get away from having paths embedded in the object if possible. Long
ago it was suggested that we use this for ASan, and apparently I felt
the same way back then:
https://reviews.llvm.org/D4428#56536
This is also consistent with how all other autolinking usage works for
PS4, Mac, and Windows: they all use basenames, not paths.
To keep things working for people using the standard GCC driver
workflow, the driver now adds the resource directory to the linker
library search path when it calls the linker. This is enough to make
check-ubsan pass, and seems like a generally good thing.
Users that invoke the linker directly (most clang-cl users) will have to
add clang's resource library directory to their linker search path in
their build system. I'm not sure where I can document this. Ideally I'd
also do it in the MSBuild files, but I can't figure out where they go.
I'd like to start with this for now.
Reviewed By: hans
Differential Revision: https://reviews.llvm.org/D65543
2019-08-01 05:52:00 +08:00
C M A K E _ E X E _ L I N K E R _ F L A G S
2020-07-01 22:17:00 +08:00
C M A K E _ M O D U L E _ L I N K E R _ F L A G S
[Windows] Autolink with basenames and add libdir to libpath
Prior to this change, for a few compiler-rt libraries such as ubsan and
the profile library, Clang would embed "-defaultlib:path/to/rt-arch.lib"
into the .drective section of every object compiled with
-finstr-profile-generate or -fsanitize=ubsan as appropriate.
These paths assume that the link step will run from the same working
directory as the compile step. There is also evidence that sometimes the
paths become absolute, such as when clang is run from a different drive
letter from the current working directory. This is fragile, and I'd like
to get away from having paths embedded in the object if possible. Long
ago it was suggested that we use this for ASan, and apparently I felt
the same way back then:
https://reviews.llvm.org/D4428#56536
This is also consistent with how all other autolinking usage works for
PS4, Mac, and Windows: they all use basenames, not paths.
To keep things working for people using the standard GCC driver
workflow, the driver now adds the resource directory to the linker
library search path when it calls the linker. This is enough to make
check-ubsan pass, and seems like a generally good thing.
Users that invoke the linker directly (most clang-cl users) will have to
add clang's resource library directory to their linker search path in
their build system. I'm not sure where I can document this. Ideally I'd
also do it in the MSBuild files, but I can't figure out where they go.
I'd like to start with this for now.
Reviewed By: hans
Differential Revision: https://reviews.llvm.org/D65543
2019-08-01 05:52:00 +08:00
C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
endif ( )
2019-03-07 03:31:37 +08:00
if ( LLVM_PROFDATA_FILE AND EXISTS ${ LLVM_PROFDATA_FILE } )
2019-09-18 17:43:13 +08:00
if ( "${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang" )
append ( "-fprofile-instr-use=\" ${ LLVM_PROFDATA_FILE } \""
C M A K E _ C X X _ F L A G S
C M A K E _ C _ F L A G S )
if ( NOT LINKER_IS_LLD_LINK )
append ( "-fprofile-instr-use=\" ${ LLVM_PROFDATA_FILE } \""
C M A K E _ E X E _ L I N K E R _ F L A G S
C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
endif ( )
else ( )
message ( FATAL_ERROR "LLVM_PROFDATA_FILE can only be specified when compiling with clang" )
endif ( )
2019-03-07 03:31:37 +08:00
endif ( )
2017-09-21 01:16:00 +08:00
option ( LLVM_BUILD_INSTRUMENTED_COVERAGE "Build LLVM and tools with Code Coverage instrumentation" Off )
2016-06-14 07:33:48 +08:00
mark_as_advanced ( LLVM_BUILD_INSTRUMENTED_COVERAGE )
2019-09-25 07:56:22 +08:00
append_if ( LLVM_BUILD_INSTRUMENTED_COVERAGE "-fprofile-instr-generate=\" ${ LLVM_PROFILE_FILE_PATTERN } \" -fcoverage-mapping "
2015-12-11 05:19:07 +08:00
C M A K E _ C X X _ F L A G S
C M A K E _ C _ F L A G S
C M A K E _ E X E _ L I N K E R _ F L A G S
C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
2017-11-09 05:26:40 +08:00
if ( LLVM_BUILD_INSTRUMENTED AND LLVM_BUILD_INSTRUMENTED_COVERAGE )
message ( FATAL_ERROR "LLVM_BUILD_INSTRUMENTED and LLVM_BUILD_INSTRUMENTED_COVERAGE cannot both be specified" )
endif ( )
2022-03-08 23:15:20 +08:00
set ( LLVM_THINLTO_CACHE_PATH "${PROJECT_BINARY_DIR}/lto.cache" CACHE STRING "Set ThinLTO cache path. This can be used when building LLVM from several different directiories." )
2020-05-25 15:28:17 +08:00
if ( LLVM_ENABLE_LTO AND LLVM_ON_WIN32 AND NOT LINKER_IS_LLD_LINK AND NOT MINGW )
2017-03-02 03:22:18 +08:00
message ( FATAL_ERROR "When compiling for Windows, LLVM_ENABLE_LTO requires using lld as the linker (point CMAKE_LINKER at lld-link.exe)" )
endif ( )
2016-02-09 05:01:24 +08:00
if ( uppercase_LLVM_ENABLE_LTO STREQUAL "THIN" )
2017-03-02 03:22:18 +08:00
append ( "-flto=thin" CMAKE_CXX_FLAGS CMAKE_C_FLAGS )
if ( NOT LINKER_IS_LLD_LINK )
append ( "-flto=thin" CMAKE_EXE_LINKER_FLAGS CMAKE_SHARED_LINKER_FLAGS )
endif ( )
2017-03-16 00:28:43 +08:00
# If the linker supports it, enable the lto cache. This improves initial build
# time a little since we re-link a lot of the same objects, and significantly
# improves incremental build time.
# FIXME: We should move all this logic into the clang driver.
if ( APPLE )
2022-03-08 23:15:20 +08:00
append ( "-Wl,-cache_path_lto,${LLVM_THINLTO_CACHE_PATH}"
2017-03-16 00:28:43 +08:00
C M A K E _ E X E _ L I N K E R _ F L A G S C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
2020-05-25 15:28:17 +08:00
elseif ( ( UNIX OR MINGW ) AND LLVM_USE_LINKER STREQUAL "lld" )
2022-03-08 23:15:20 +08:00
append ( "-Wl,--thinlto-cache-dir=${LLVM_THINLTO_CACHE_PATH}"
2017-03-16 00:28:43 +08:00
C M A K E _ E X E _ L I N K E R _ F L A G S C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
elseif ( LLVM_USE_LINKER STREQUAL "gold" )
2022-03-08 23:15:20 +08:00
append ( "-Wl,--plugin-opt,cache-dir=${LLVM_THINLTO_CACHE_PATH}"
2017-03-16 00:28:43 +08:00
C M A K E _ E X E _ L I N K E R _ F L A G S C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
2019-11-08 18:46:24 +08:00
elseif ( LINKER_IS_LLD_LINK )
2022-03-08 23:15:20 +08:00
append ( "/lldltocache:${LLVM_THINLTO_CACHE_PATH}"
2019-11-08 18:46:24 +08:00
C M A K E _ E X E _ L I N K E R _ F L A G S C M A K E _ S H A R E D _ L I N K E R _ F L A G S )
2017-03-16 00:28:43 +08:00
endif ( )
2016-02-09 05:01:24 +08:00
elseif ( uppercase_LLVM_ENABLE_LTO STREQUAL "FULL" )
2017-03-02 03:22:18 +08:00
append ( "-flto=full" CMAKE_CXX_FLAGS CMAKE_C_FLAGS )
if ( NOT LINKER_IS_LLD_LINK )
append ( "-flto=full" CMAKE_EXE_LINKER_FLAGS CMAKE_SHARED_LINKER_FLAGS )
endif ( )
2016-02-09 05:01:24 +08:00
elseif ( LLVM_ENABLE_LTO )
2017-03-02 03:22:18 +08:00
append ( "-flto" CMAKE_CXX_FLAGS CMAKE_C_FLAGS )
if ( NOT LINKER_IS_LLD_LINK )
append ( "-flto" CMAKE_EXE_LINKER_FLAGS CMAKE_SHARED_LINKER_FLAGS )
endif ( )
2016-02-09 05:01:24 +08:00
endif ( )
2016-02-04 15:28:30 +08:00
2020-05-09 01:45:44 +08:00
# Set an AIX default for LLVM_EXPORT_SYMBOLS_FOR_PLUGINS based on whether we are
# doing dynamic linking (see below).
set ( LLVM_EXPORT_SYMBOLS_FOR_PLUGINS_AIX_default OFF )
if ( NOT ( BUILD_SHARED_LIBS OR LLVM_LINK_LLVM_DYLIB ) )
set ( LLVM_EXPORT_SYMBOLS_FOR_PLUGINS_AIX_default ON )
endif ( )
2016-05-26 19:16:43 +08:00
# This option makes utils/extract_symbols.py be used to determine the list of
2020-05-09 01:45:44 +08:00
# symbols to export from LLVM tools. This is necessary when on AIX or when using
# MSVC if you want to allow plugins. On AIX we don't show this option, and we
# enable it by default except when the LLVM libraries are set up for dynamic
# linking (due to incompatibility). With MSVC, note that the plugin has to
# explicitly link against (exactly one) tool so we can't unilaterally turn on
2016-05-26 19:16:43 +08:00
# LLVM_ENABLE_PLUGINS when it's enabled.
2020-05-09 01:45:44 +08:00
CMAKE_DEPENDENT_OPTION ( LLVM_EXPORT_SYMBOLS_FOR_PLUGINS
" E x p o r t s y m b o l s f r o m L L V M t o o l s s o t h a t p l u g i n s c a n i m p o r t t h e m " O F F
" N O T $ { C M A K E _ S Y S T E M _ N A M E } M A T C H E S A I X " $ { L L V M _ E X P O R T _ S Y M B O L S _ F O R _ P L U G I N S _ A I X _ d e f a u l t } )
2016-05-26 19:16:43 +08:00
if ( BUILD_SHARED_LIBS AND LLVM_EXPORT_SYMBOLS_FOR_PLUGINS )
message ( FATAL_ERROR "BUILD_SHARED_LIBS not compatible with LLVM_EXPORT_SYMBOLS_FOR_PLUGINS" )
endif ( )
if ( LLVM_LINK_LLVM_DYLIB AND LLVM_EXPORT_SYMBOLS_FOR_PLUGINS )
message ( FATAL_ERROR "LLVM_LINK_LLVM_DYLIB not compatible with LLVM_EXPORT_SYMBOLS_FOR_PLUGINS" )
endif ( )
2018-10-16 05:14:19 +08:00
# By default we should enable LLVM_ENABLE_IDE only for multi-configuration
# generators. This option disables optional build system features that make IDEs
# less usable.
set ( LLVM_ENABLE_IDE_default OFF )
if ( CMAKE_CONFIGURATION_TYPES )
set ( LLVM_ENABLE_IDE_default ON )
endif ( )
option ( LLVM_ENABLE_IDE
" D i s a b l e o p t i o n a l b u i l d s y s t e m f e a t u r e s t h a t c a u s e p r o b l e m s f o r I D E g e n e r a t o r s "
$ { L L V M _ E N A B L E _ I D E _ d e f a u l t } )
if ( CMAKE_CONFIGURATION_TYPES AND NOT LLVM_ENABLE_IDE )
message ( WARNING "Disabling LLVM_ENABLE_IDE on multi-configuration generators is not recommended." )
endif ( )
2018-01-12 12:01:41 +08:00
2017-03-21 12:03:24 +08:00
function ( get_compile_definitions )
get_directory_property ( top_dir_definitions DIRECTORY ${ CMAKE_SOURCE_DIR } COMPILE_DEFINITIONS )
foreach ( definition ${ top_dir_definitions } )
if ( DEFINED result )
string ( APPEND result " -D${definition}" )
else ( )
set ( result "-D${definition}" )
endif ( )
endforeach ( )
set ( LLVM_DEFINITIONS "${result}" PARENT_SCOPE )
endfunction ( )
get_compile_definitions ( )
2018-03-06 03:38:16 +08:00
2018-03-08 03:32:36 +08:00
option ( LLVM_FORCE_ENABLE_STATS "Enable statistics collection for builds that wouldn't normally enable it" OFF )
2019-02-20 02:18:31 +08:00
2019-02-20 03:45:03 +08:00
check_symbol_exists ( os_signpost_interval_begin "os/signpost.h" macos_signposts_available )
if ( macos_signposts_available )
check_cxx_source_compiles (
" #include <os/signpost.h>
i n t main ( ) { os_signpost_interval_begin ( nullptr, 0, \"\", \"\"); return 0; } "
m a c o s _ s i g n p o s t s _ u s a b l e )
if ( macos_signposts_usable )
set ( LLVM_ENABLE_SUPPORT_XCODE_SIGNPOSTS "WITH_ASSERTS" CACHE STRING
" E n a b l e s u p p o r t f o r X c o d e s i g n p o s t s . C a n b e W I T H _ A S S E R T S , F O R C E _ O N , F O R C E _ O F F " )
string ( TOUPPER "${LLVM_ENABLE_SUPPORT_XCODE_SIGNPOSTS}"
u p p e r c a s e _ L L V M _ E N A B L E _ S U P P O R T _ X C O D E _ S I G N P O S T S )
if ( uppercase_LLVM_ENABLE_SUPPORT_XCODE_SIGNPOSTS STREQUAL "WITH_ASSERTS" )
if ( LLVM_ENABLE_ASSERTIONS )
set ( LLVM_SUPPORT_XCODE_SIGNPOSTS 1 )
endif ( )
elseif ( uppercase_LLVM_ENABLE_SUPPORT_XCODE_SIGNPOSTS STREQUAL "FORCE_ON" )
2019-02-20 02:18:31 +08:00
set ( LLVM_SUPPORT_XCODE_SIGNPOSTS 1 )
2019-02-20 03:45:03 +08:00
elseif ( uppercase_LLVM_ENABLE_SUPPORT_XCODE_SIGNPOSTS STREQUAL "FORCE_OFF" )
# We don't need to do anything special to turn off signposts.
elseif ( NOT DEFINED LLVM_ENABLE_SUPPORT_XCODE_SIGNPOSTS )
# Treat LLVM_ENABLE_SUPPORT_XCODE_SIGNPOSTS like "FORCE_OFF" when it has not been
# defined.
else ( )
message ( FATAL_ERROR "Unknown value for LLVM_ENABLE_SUPPORT_XCODE_SIGNPOSTS:"
" \ " $ { L L V M _ E N A B L E _ S U P P O R T _ X C O D E _ S I G N P O S T S } \ " ! " )
2019-02-20 02:18:31 +08:00
endif ( )
endif ( )
endif ( )
2019-05-31 09:34:51 +08:00
2020-03-12 01:59:12 +08:00
set ( LLVM_SOURCE_PREFIX "" CACHE STRING "Use prefix for sources" )
2019-05-31 09:34:51 +08:00
option ( LLVM_USE_RELATIVE_PATHS_IN_DEBUG_INFO "Use relative paths in debug info" OFF )
if ( LLVM_USE_RELATIVE_PATHS_IN_DEBUG_INFO )
check_c_compiler_flag ( "-fdebug-prefix-map=foo=bar" SUPPORTS_FDEBUG_PREFIX_MAP )
if ( LLVM_ENABLE_PROJECTS_USED )
get_filename_component ( source_root "${LLVM_MAIN_SRC_DIR}/.." ABSOLUTE )
else ( )
set ( source_root "${LLVM_MAIN_SRC_DIR}" )
endif ( )
file ( RELATIVE_PATH relative_root "${source_root}" "${CMAKE_BINARY_DIR}" )
append_if ( SUPPORTS_FDEBUG_PREFIX_MAP "-fdebug-prefix-map=${CMAKE_BINARY_DIR}=${relative_root}" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
append_if ( SUPPORTS_FDEBUG_PREFIX_MAP "-fdebug-prefix-map=${source_root}/=${LLVM_SOURCE_PREFIX}" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
add_flag_if_supported ( "-no-canonical-prefixes" NO_CANONICAL_PREFIXES )
endif ( )
2020-03-12 01:59:12 +08:00
option ( LLVM_USE_RELATIVE_PATHS_IN_FILES "Use relative paths in sources and debug info" OFF )
if ( LLVM_USE_RELATIVE_PATHS_IN_FILES )
check_c_compiler_flag ( "-ffile-prefix-map=foo=bar" SUPPORTS_FFILE_PREFIX_MAP )
if ( LLVM_ENABLE_PROJECTS_USED )
get_filename_component ( source_root "${LLVM_MAIN_SRC_DIR}/.." ABSOLUTE )
else ( )
set ( source_root "${LLVM_MAIN_SRC_DIR}" )
endif ( )
file ( RELATIVE_PATH relative_root "${source_root}" "${CMAKE_BINARY_DIR}" )
append_if ( SUPPORTS_FFILE_PREFIX_MAP "-ffile-prefix-map=${CMAKE_BINARY_DIR}=${relative_root}" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
append_if ( SUPPORTS_FFILE_PREFIX_MAP "-ffile-prefix-map=${source_root}/=${LLVM_SOURCE_PREFIX}" CMAKE_C_FLAGS CMAKE_CXX_FLAGS )
add_flag_if_supported ( "-no-canonical-prefixes" NO_CANONICAL_PREFIXES )
endif ( )
2021-03-16 00:33:31 +08:00
if ( LLVM_INCLUDE_TESTS )
# Lit test suite requires at least python 3.6
set ( LLVM_MINIMUM_PYTHON_VERSION 3.6 )
else ( )
# FIXME: it is unknown if this is the actual minimum bound
set ( LLVM_MINIMUM_PYTHON_VERSION 3.0 )
endif ( )