aboutsummaryrefslogtreecommitdiff
path: root/cmake/utils.cmake
diff options
context:
space:
mode:
Diffstat (limited to 'cmake/utils.cmake')
-rw-r--r--cmake/utils.cmake115
1 files changed, 115 insertions, 0 deletions
diff --git a/cmake/utils.cmake b/cmake/utils.cmake
new file mode 100644
index 0000000..57b939f
--- /dev/null
+++ b/cmake/utils.cmake
@@ -0,0 +1,115 @@
+include(CheckCXXCompilerFlag)
+
+# Adds compiler options for all targets
+function(libhevc_add_compile_options)
+ if(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "aarch64")
+ add_compile_options(-march=armv8-a)
+ elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "aarch32")
+ add_compile_options(-march=armv7-a -mfpu=neon)
+ else()
+ add_compile_options(-msse4.2 -mno-avx)
+ endif()
+
+ set(CMAKE_REQUIRED_FLAGS -fsanitize=fuzzer-no-link)
+ check_cxx_compiler_flag(-fsanitize=fuzzer-no-link
+ COMPILER_HAS_SANITIZE_FUZZER)
+ unset(CMAKE_REQUIRED_FLAGS)
+
+ if(DEFINED SANITIZE)
+ set(CMAKE_REQUIRED_FLAGS -fsanitize=${SANITIZE})
+ check_cxx_compiler_flag(-fsanitize=${SANITIZE} COMPILER_HAS_SANITIZER)
+ unset(CMAKE_REQUIRED_FLAGS)
+
+ if(NOT COMPILER_HAS_SANITIZER)
+ message(
+ FATAL_ERROR "ERROR: Compiler doesn't support -fsanitize=${SANITIZE}")
+ return()
+ endif()
+ add_compile_options(-fno-omit-frame-pointer -fsanitize=${SANITIZE})
+ endif()
+
+endfunction()
+
+# Adds defintions for all targets
+function(libhevc_add_definitions)
+ add_definitions(-DPROFILE_ENABLE -DMD5_DISABLE)
+
+ if(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "aarch64")
+ add_definitions(-DARMV8 -DDEFAULT_ARCH=D_ARCH_ARMV8_GENERIC)
+ elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "aarch32")
+ add_definitions(-DARMV7 -DDEFAULT_ARCH=D_ARCH_ARM_A9Q)
+ else()
+ add_definitions(-DX86 -DX86_LINUX=1 -DDISABLE_AVX2
+ -DDEFAULT_ARCH=D_ARCH_X86_SSE42)
+ endif()
+endfunction()
+
+# Adds libraries needed for executables
+function(libhevc_set_link_libraries)
+ link_libraries(Threads::Threads m)
+endfunction()
+
+# cmake-format: off
+# Adds a target for an executable
+#
+# Arguments:
+# NAME: Name of the executatble
+# LIB: Library that executable depends on
+# SOURCES: Source files
+#
+# Optional Arguments:
+# INCLUDES: Include paths
+# LIBS: Additional libraries
+# FUZZER: flag to specify if the target is a fuzzer binary
+# cmake-format: on
+
+function(libhevc_add_executable NAME LIB)
+ set(multi_value_args SOURCES INCLUDES LIBS)
+ set(optional_args FUZZER)
+ cmake_parse_arguments(ARG "${optional_args}" "${single_value_args}"
+ "${multi_value_args}" ${ARGN})
+
+ # Check if compiler supports -fsanitize=fuzzer. If not, skip building fuzzer
+ # binary
+ if(ARG_FUZZER)
+ if(NOT COMPILER_HAS_SANITIZE_FUZZER)
+ message("Compiler doesn't support -fsanitize=fuzzer. Skipping ${NAME}")
+ return()
+ endif()
+ endif()
+
+ add_executable(${NAME} ${ARG_SOURCES})
+ target_include_directories(${NAME} PRIVATE ${ARG_INCLUDES})
+ add_dependencies(${NAME} ${LIB} ${ARG_LIBS})
+
+ target_link_libraries(${NAME} ${LIB} ${ARG_LIBS})
+ if(ARG_FUZZER)
+ target_compile_options(${NAME}
+ PRIVATE $<$<COMPILE_LANGUAGE:CXX>:-std=c++17>)
+ if(DEFINED ENV{LIB_FUZZING_ENGINE})
+ set_target_properties(${NAME} PROPERTIES LINK_FLAGS
+ $ENV{LIB_FUZZING_ENGINE})
+ elseif(DEFINED SANITIZE)
+ set_target_properties(${NAME} PROPERTIES LINK_FLAGS
+ -fsanitize=fuzzer,${SANITIZE})
+ else()
+ set_target_properties(${NAME} PROPERTIES LINK_FLAGS -fsanitize=fuzzer)
+ endif()
+ else()
+ if(DEFINED SANITIZE)
+ set_target_properties(${NAME} PROPERTIES LINK_FLAGS
+ -fsanitize=${SANITIZE})
+ endif()
+ endif()
+endfunction()
+
+# cmake-format: off
+# Adds a target for a fuzzer binary
+# Calls libhevc_add_executable with all arguments with FUZZER set to 1
+# Arguments:
+# Refer to libhevc_add_executable's arguments
+# cmake-format: on
+
+function(libhevc_add_fuzzer NAME LIB)
+ libhevc_add_executable(${NAME} ${LIB} FUZZER 1 ${ARGV})
+endfunction()