2024-02-01 22:54:06 -05:00
|
|
|
# TODO: This currently assumes libstdc++, later on we should *probably* set this with some detection
|
|
|
|
# also TODO: Use a list so that this isn't one giant line (list JOIN should help.)
|
2024-02-02 05:34:37 -05:00
|
|
|
set(NANOSM_CORE_COMPILE_ARGS "-Wall -Wformat=2 -Wimplicit-fallthrough")
|
2024-02-01 22:54:06 -05:00
|
|
|
set(NANOSM_CORE_LINKER_ARGS "-fuse-ld=${NANOSM_LINKER}")
|
|
|
|
|
|
|
|
if("${CMAKE_BUILD_TYPE}" STREQUAL "Release") # OR "${CMAKE_BUILD_TYPE}" STREQUAL "RelWithDebInfo"
|
|
|
|
# If on Release use link-time optimizations.
|
|
|
|
# On clang we use ThinLTO for even better build performance.
|
|
|
|
if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
|
|
|
|
set(NANOSM_CORE_COMPILE_ARGS "${NANOSM_CORE_COMPILE_ARGS} -flto=thin")
|
|
|
|
set(NANOSM_CORE_LINKER_ARGS "${NANOSM_CORE_LINKER_ARGS} -flto=thin")
|
|
|
|
else()
|
|
|
|
set(NANOSM_CORE_COMPILE_ARGS "${NANOSM_CORE_COMPILE_ARGS} -flto")
|
|
|
|
set(NANOSM_CORE_LINKER_ARGS "${NANOSM_CORE_LINKER_ARGS} -flto")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
set(_NANOSM_CORE_WANTED_SANITIZERS "")
|
|
|
|
|
|
|
|
if("asan" IN_LIST NANOSM_SANITIZERS)
|
|
|
|
# Error if someone's trying to mix asan and tsan together since they aren't compatible.
|
|
|
|
if("tsan" IN_LIST NANOSM_SANITIZERS)
|
|
|
|
message(FATAL_ERROR "ASAN and TSAN cannot be used together.")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
message(STATUS "Enabling ASAN because it was in NANOSM_SANITIZERS")
|
|
|
|
list(APPEND _NANOSM_CORE_WANTED_SANITIZERS "address")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if("tsan" IN_LIST NANOSM_SANITIZERS)
|
|
|
|
if("asan" IN_LIST NANOSM_SANITIZERS)
|
|
|
|
message(FATAL_ERROR "ASAN and TSAN cannot be used together.")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
message(STATUS "Enabling TSAN because it was in NANOSM_SANITIZERS")
|
|
|
|
list(APPEND _NANOSM_CORE_WANTED_SANITIZERS "thread")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if("ubsan" IN_LIST NANOSM_SANITIZERS)
|
|
|
|
message(STATUS "Enabling UBSAN because it was in NANOSM_SANITIZERS")
|
|
|
|
list(APPEND _NANOSM_CORE_WANTED_SANITIZERS "undefined")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
list(LENGTH _NANOSM_CORE_WANTED_SANITIZERS _NANOSM_CORE_WANTED_SANITIZERS_LENGTH)
|
|
|
|
if(NOT _NANOSM_CORE_WANTED_SANITIZERS_LENGTH EQUAL 0)
|
|
|
|
list(JOIN _NANOSM_CORE_WANTED_SANITIZERS "," _NANOSM_CORE_WANTED_SANITIZERS_ARG)
|
|
|
|
message(STATUS "Enabled sanitizers: ${_NANOSM_CORE_WANTED_SANITIZERS_ARG}")
|
|
|
|
set(NANOSM_CORE_COMPILE_ARGS "${NANOSM_CORE_COMPILE_ARGS} -fsanitize=${_NANOSM_CORE_WANTED_SANITIZERS_ARG}")
|
|
|
|
set(NANOSM_CORE_LINKER_ARGS "${NANOSM_CORE_LINKER_ARGS} -fsanitize=${_NANOSM_CORE_WANTED_SANITIZERS_ARG}")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# Set core CMake toolchain variables so that they get applied to all projects.
|
|
|
|
# A bit nasty, but /shrug, this way our third party libraries can be mostly sanitized/etc as well.
|
|
|
|
# We do NOT do this for CMake compiler features however.
|
|
|
|
|
|
|
|
set(CMAKE_C_FLAGS "${NANOSM_CORE_COMPILE_ARGS}")
|
|
|
|
set(CMAKE_CXX_FLAGS "${NANOSM_CORE_COMPILE_ARGS}")
|
|
|
|
|
|
|
|
set(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS} -O0 -g3")
|
|
|
|
set(CMAKE_C_FLAGS_RELWITHDEBINFO "${CMAKE_C_FLAGS} -O3 -g3")
|
2024-02-01 23:20:42 -05:00
|
|
|
set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS} -O3 -s")
|
2024-02-01 22:54:06 -05:00
|
|
|
|
|
|
|
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS} -O0 -g3")
|
|
|
|
set(CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS} -O3 -g3")
|
2024-02-01 23:20:42 -05:00
|
|
|
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS} -O3 -s")
|
2024-02-01 22:54:06 -05:00
|
|
|
|
|
|
|
set(CMAKE_EXE_LINKER_FLAGS "${NANOSM_CORE_LINKER_ARGS} -Wl,-z,noexecstack,-z,relro,-z,now")
|