Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 1 | # dEQP cmake file |
| 2 | |
Chad Versace | b5cd0ad | 2017-11-03 09:36:30 -0700 | [diff] [blame] | 3 | # Module FindGit requires cmake >= 2.8.2 |
Alexander Galazin | 5b69511 | 2019-11-01 12:05:43 +0100 | [diff] [blame] | 4 | cmake_minimum_required(VERSION 3.10.2) |
Chad Versace | b5cd0ad | 2017-11-03 09:36:30 -0700 | [diff] [blame] | 5 | |
| 6 | find_package(Git) |
Alexander Galazin | b1e5e37 | 2019-04-23 21:09:43 +0200 | [diff] [blame] | 7 | find_package(PythonInterp 3) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 8 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 9 | # dEQP Target. |
| 10 | set(DEQP_TARGET "default" CACHE STRING "dEQP Target (default, android...)") |
| 11 | |
Pyry Haulos | 69bb2f6 | 2017-03-27 11:21:37 -0700 | [diff] [blame] | 12 | if (DEFINED DEQP_TARGET_TOOLCHAIN) |
| 13 | # \note Toolchain must be included before project() command |
Jesse Hall | ba94ca6 | 2017-08-04 14:24:10 -0700 | [diff] [blame] | 14 | include(targets/${DEQP_TARGET}/${DEQP_TARGET_TOOLCHAIN}.cmake NO_POLICY_SCOPE) |
Pyry Haulos | 69bb2f6 | 2017-03-27 11:21:37 -0700 | [diff] [blame] | 15 | endif () |
| 16 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 17 | project(dEQP-Core-${DEQP_TARGET}) |
| 18 | |
Pyry Haulos | eccd5bc | 2015-02-03 10:48:09 -0800 | [diff] [blame] | 19 | include(framework/delibs/cmake/Defs.cmake NO_POLICY_SCOPE) |
| 20 | include(framework/delibs/cmake/CFlags.cmake) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 21 | |
| 22 | add_definitions(-DDE_ASSERT_FAILURE_CALLBACK) |
| 23 | |
| 24 | # dEQP-specific configuration. Target file should override these. |
| 25 | set(DEQP_TARGET_NAME "UNKNOWN") # Target name |
| 26 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 27 | set(DEQP_GLES2_LIBRARIES ) # GLESv2 libraries. If empty, run-time linking is used |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 28 | set(DEQP_GLES3_LIBRARIES ) # GLESv3 libraries. If empty, run-time linking is used |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 29 | set(DEQP_EGL_LIBRARIES ) # EGL libraries |
| 30 | |
Pyry Haulos | d98514b | 2016-10-12 13:22:41 -0700 | [diff] [blame] | 31 | # Legacy APIs that don't use run-time loading |
| 32 | set(DEQP_SUPPORT_GLES1 OFF) # Is GLESv1 supported |
| 33 | set(DEQP_GLES1_LIBRARIES ) # GLESv1 libraries |
| 34 | set(DEQP_SUPPORT_VG OFF) # Is OpenVG supported |
| 35 | set(DEQP_VG_LIBRARIES ) # VG libraries |
| 36 | |
Pyry Haulos | cdeac44 | 2016-11-17 15:29:14 -0800 | [diff] [blame] | 37 | set(DEQP_SUPPORT_WGL OFF) |
Pyry Haulos | d98514b | 2016-10-12 13:22:41 -0700 | [diff] [blame] | 38 | set(DEQP_SUPPORT_GLX OFF) # Is GLX supported \todo [2016-10-12 pyry] X11 specific - move to framework/platform/ |
Jarkko Pöyry | 573d323 | 2015-02-24 21:05:42 -0800 | [diff] [blame] | 39 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 40 | set(DEQP_PLATFORM_LIBRARIES ) # Other platform libraries |
| 41 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 42 | set(DEQP_PLATFORM_COPY_LIBRARIES ) # Libraries / binaries that need to be copied to binary directory |
| 43 | |
| 44 | # Delibs include directories |
| 45 | include_directories( |
Pyry Haulos | eccd5bc | 2015-02-03 10:48:09 -0800 | [diff] [blame] | 46 | framework/delibs/debase |
| 47 | framework/delibs/decpp |
| 48 | framework/delibs/depool |
| 49 | framework/delibs/dethread |
| 50 | framework/delibs/deutil |
| 51 | framework/delibs/destream |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 52 | ) |
| 53 | |
| 54 | # Include target-specific definitions |
| 55 | include(targets/${DEQP_TARGET}/${DEQP_TARGET}.cmake) |
| 56 | |
Pyry Haulos | fe01ea4 | 2014-09-24 12:12:26 -0700 | [diff] [blame] | 57 | # zlib |
Thomas Spurden | 67b58ed | 2019-10-25 11:50:34 +0100 | [diff] [blame] | 58 | find_package(ZLIB) |
| 59 | # dEQP CMake compatibility (as for libpng) |
| 60 | set(ZLIB_INCLUDE_PATH ${ZLIB_INCLUDE_DIRS}) |
| 61 | set(ZLIB_LIBRARY ${ZLIB_LIBRARIES}) |
Pyry Haulos | fe01ea4 | 2014-09-24 12:12:26 -0700 | [diff] [blame] | 62 | |
| 63 | if (NOT ZLIB_INCLUDE_PATH OR NOT ZLIB_LIBRARY) |
| 64 | message(STATUS "System version of zlib not found, using external/zlib") |
| 65 | add_subdirectory(external/zlib) |
| 66 | # \note ZLIB_LIBRARY and ZLIB_INCLUDE_PATH are promoted from external/zlib/CMakeLists.txt |
| 67 | endif () |
| 68 | |
Chris Forbes | be3254c | 2019-02-13 14:59:20 -0800 | [diff] [blame] | 69 | if (EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/external/renderdoc/src/renderdoc_app.h") |
| 70 | message(STATUS "Renderdoc header found, integration enabled") |
| 71 | set(DEQP_HAVE_RENDERDOC_HEADER 1) |
| 72 | else () |
| 73 | message(STATUS "Renderdoc header not found, integration will not work") |
| 74 | endif () |
| 75 | |
Pyry Haulos | fe01ea4 | 2014-09-24 12:12:26 -0700 | [diff] [blame] | 76 | include_directories(${ZLIB_INCLUDE_PATH}) |
| 77 | |
| 78 | # libpng |
Chad Versace | df62859 | 2016-12-02 15:43:08 -0800 | [diff] [blame] | 79 | # |
| 80 | # The FindPNG module defines PNG_INCLUDE_DIRS and PNG_LIBRARIES. But dEQP's |
| 81 | # CMake files expect the non-standard PNG_INCLUDE_PATH and PNG_LIBRARY. Set the |
| 82 | # non-standard variables here to retain compatibility with dEQP's existing |
| 83 | # CMake files. |
Thomas Spurden | 67b58ed | 2019-10-25 11:50:34 +0100 | [diff] [blame] | 84 | find_package(PNG) |
Chad Versace | df62859 | 2016-12-02 15:43:08 -0800 | [diff] [blame] | 85 | set(PNG_INCLUDE_PATH ${PNG_INCLUDE_DIRS}) |
| 86 | set(PNG_LIBRARY ${PNG_LIBRARIES}) |
Pyry Haulos | fe01ea4 | 2014-09-24 12:12:26 -0700 | [diff] [blame] | 87 | |
| 88 | if (NOT PNG_INCLUDE_PATH OR NOT PNG_LIBRARY) |
| 89 | message(STATUS "System version of libpng not found, using external/libpng") |
| 90 | add_subdirectory(external/libpng) |
| 91 | # \note PNG_LIBRARY and PNG_INCLUDE_PATH are promoted from external/libpng/CMakeLists.txt |
| 92 | endif () |
| 93 | |
Pyry Haulos | 29ae4d1 | 2015-06-19 15:25:34 -0700 | [diff] [blame] | 94 | # glslang |
| 95 | add_subdirectory(external/glslang) |
| 96 | |
Andrew Woloszyn | 7485f0b | 2015-09-04 15:50:45 -0400 | [diff] [blame] | 97 | # spirv-tools |
| 98 | add_subdirectory(external/spirv-tools) |
| 99 | |
Paavo Pessi | 646ff42 | 2018-04-19 14:47:40 +0300 | [diff] [blame] | 100 | # spirv-headers |
Alexander Galazin | f620cc9 | 2018-07-20 12:51:58 +0200 | [diff] [blame] | 101 | set(SPIRV_INCLUDE_PATH "${PROJECT_SOURCE_DIR}/external/spirv-headers/src/include") |
| 102 | if (NOT EXISTS ${SPIRV_INCLUDE_PATH}) |
| 103 | message(FATAL_ERROR "SPIR-V headers not found, please run external/fetch_sources.py") |
| 104 | endif() |
| 105 | include_directories(${SPIRV_INCLUDE_PATH}) |
Paavo Pessi | 646ff42 | 2018-04-19 14:47:40 +0300 | [diff] [blame] | 106 | |
Dan Sinclair | 64a4105 | 2019-01-03 15:37:57 -0500 | [diff] [blame] | 107 | # Amber |
| 108 | add_subdirectory(external/amber) |
| 109 | include_directories(external/amber) |
| 110 | |
Cygan, Slawomir | 8b12641 | 2018-07-05 18:54:09 +0200 | [diff] [blame] | 111 | # RenderDoc API |
| 112 | include_directories(external/renderdoc/src) |
| 113 | |
Pyry Haulos | fe01ea4 | 2014-09-24 12:12:26 -0700 | [diff] [blame] | 114 | include_directories(${PNG_INCLUDE_PATH}) |
| 115 | |
James Jones | 0bb2308 | 2021-01-12 10:42:26 -0800 | [diff] [blame] | 116 | # DRM (Direct Rendering Manager) Headers |
| 117 | find_path(XF86DRM_H_PATH NAMES xf86drm.h) |
| 118 | find_path(DRM_H_PATH NAMES drm.h PATH_SUFFIXES libdrm drm) |
| 119 | |
| 120 | if (XF86DRM_H_PATH AND DRM_H_PATH) |
| 121 | include_directories(${XF86DRM_H_PATH}) |
| 122 | include_directories(${DRM_H_PATH}) |
| 123 | set(DEQP_SUPPORT_DRM ON CACHE BOOL "Build code requiring the Linux/Unix Direct Rendering Manager") |
| 124 | mark_as_advanced(XF86DRM_H_PATH) |
| 125 | mark_as_advanced(DRM_H_PATH) |
| 126 | else () |
| 127 | set(DEQP_SUPPORT_DRM OFF CACHE BOOL "Build code requiring the Linux/Unix Direct Rendering Manager") |
| 128 | endif () |
| 129 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 130 | message(STATUS "DEQP_TARGET_NAME = ${DEQP_TARGET_NAME}") |
| 131 | message(STATUS "DEQP_SUPPORT_GLES1 = ${DEQP_SUPPORT_GLES1}") |
| 132 | message(STATUS "DEQP_GLES1_LIBRARIES = ${DEQP_GLES1_LIBRARIES}") |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 133 | message(STATUS "DEQP_GLES2_LIBRARIES = ${DEQP_GLES2_LIBRARIES}") |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 134 | message(STATUS "DEQP_GLES3_LIBRARIES = ${DEQP_GLES3_LIBRARIES}") |
Pyry Haulos | 933ef4d | 2016-11-14 13:01:12 -0800 | [diff] [blame] | 135 | message(STATUS "DEQP_GLES31_LIBRARIES = ${DEQP_GLES31_LIBRARIES}") |
Pyry Haulos | bc24f75 | 2016-11-14 16:17:12 -0800 | [diff] [blame] | 136 | message(STATUS "DEQP_GLES32_LIBRARIES = ${DEQP_GLES32_LIBRARIES}") |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 137 | message(STATUS "DEQP_SUPPORT_VG = ${DEQP_SUPPORT_VG}") |
| 138 | message(STATUS "DEQP_VG_LIBRARIES = ${DEQP_VG_LIBRARIES}") |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 139 | message(STATUS "DEQP_EGL_LIBRARIES = ${DEQP_EGL_LIBRARIES}") |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 140 | message(STATUS "DEQP_PLATFORM_LIBRARIES = ${DEQP_PLATFORM_LIBRARIES}") |
James Jones | 0bb2308 | 2021-01-12 10:42:26 -0800 | [diff] [blame] | 141 | message(STATUS "DEQP_SUPPORT_DRM = ${DEQP_SUPPORT_DRM}") |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 142 | |
| 143 | # Defines |
| 144 | add_definitions(-DDEQP_TARGET_NAME="${DEQP_TARGET_NAME}") |
| 145 | |
Pyry Haulos | 933ef4d | 2016-11-14 13:01:12 -0800 | [diff] [blame] | 146 | # Entry points loaded directly by linking to libGL*? |
| 147 | if (DEFINED DEQP_GLES2_LIBRARIES) |
| 148 | add_definitions(-DDEQP_GLES2_DIRECT_LINK=1) |
| 149 | endif () |
| 150 | |
| 151 | if (DEFINED DEQP_GLES3_LIBRARIES) |
| 152 | add_definitions(-DDEQP_GLES3_DIRECT_LINK=1) |
| 153 | endif () |
| 154 | |
| 155 | if (DEFINED DEQP_GLES31_LIBRARIES) |
| 156 | add_definitions(-DDEQP_GLES31_DIRECT_LINK=1) |
| 157 | endif () |
| 158 | |
| 159 | if (DEFINED DEQP_GLES32_LIBRARIES) |
| 160 | add_definitions(-DDEQP_GLES32_DIRECT_LINK=1) |
| 161 | endif () |
| 162 | |
| 163 | if (DEFINED DEQP_EGL_LIBRARIES) |
| 164 | add_definitions(-DDEQP_EGL_DIRECT_LINK=1) |
| 165 | endif () |
| 166 | |
| 167 | # Legacy APIs that don't support run-time loading |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 168 | if (DEQP_SUPPORT_GLES1) |
| 169 | add_definitions(-DDEQP_SUPPORT_GLES1=1) |
Pyry Haulos | 933ef4d | 2016-11-14 13:01:12 -0800 | [diff] [blame] | 170 | |
| 171 | if (NOT DEFINED DEQP_GLES1_LIBRARIES) |
| 172 | message(FATAL_ERROR "Run-time loading of GLES1 is not supported (DEQP_GLES1_LIBRARIES is not set)") |
| 173 | endif () |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 174 | endif () |
| 175 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 176 | if (DEQP_SUPPORT_VG) |
| 177 | add_definitions(-DDEQP_SUPPORT_VG=1) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 178 | |
Pyry Haulos | 933ef4d | 2016-11-14 13:01:12 -0800 | [diff] [blame] | 179 | if (NOT DEFINED DEQP_VG_LIBRARIES) |
| 180 | message(FATAL_ERROR "Run-time loading of VG is not supported (DEQP_VG_LIBRARIES is not set)") |
| 181 | endif () |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 182 | endif () |
| 183 | |
James Jones | 0bb2308 | 2021-01-12 10:42:26 -0800 | [diff] [blame] | 184 | if (DEQP_SUPPORT_DRM) |
| 185 | add_definitions(-DDEQP_SUPPORT_DRM=1) |
| 186 | else () |
| 187 | add_definitions(-DDEQP_SUPPORT_DRM=0) |
| 188 | endif () |
| 189 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 190 | if (DE_COMPILER_IS_MSC) |
| 191 | # Don't nag about std::copy for example |
| 192 | set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -D_SCL_SECURE_NO_WARNINGS") |
| 193 | endif () |
| 194 | |
Jeff Bolz | 3c40ed9 | 2018-10-18 23:00:34 -0500 | [diff] [blame] | 195 | # Precompiled header macro. Parameters are source file list and filename for pch cpp file. |
| 196 | macro(PCH SRCS PCHCPP) |
Jeff Bolz | 3db647b | 2018-11-19 09:06:49 -0600 | [diff] [blame] | 197 | if(MSVC AND CMAKE_GENERATOR MATCHES "^Visual Studio") |
| 198 | set(PCH_NAME "$(IntDir)\\pch.pch") |
Jeff Bolz | 3c40ed9 | 2018-10-18 23:00:34 -0500 | [diff] [blame] | 199 | # make source files use/depend on PCH_NAME |
| 200 | set_source_files_properties(${${SRCS}} PROPERTIES COMPILE_FLAGS "/Yupch.h /FIpch.h /Fp${PCH_NAME}" OBJECT_DEPENDS "${PCH_NAME}") |
| 201 | # make PCHCPP file compile and generate PCH_NAME |
| 202 | set_source_files_properties(${PCHCPP} PROPERTIES COMPILE_FLAGS "/Ycpch.h /Fp${PCH_NAME}" OBJECT_OUTPUTS "${PCH_NAME}") |
| 203 | list(APPEND ${SRCS} "${PCHCPP}") |
| 204 | endif() |
| 205 | endmacro(PCH) |
| 206 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 207 | # delibs projects |
Pyry Haulos | eccd5bc | 2015-02-03 10:48:09 -0800 | [diff] [blame] | 208 | add_subdirectory(framework/delibs/debase) |
| 209 | add_subdirectory(framework/delibs/depool) |
| 210 | add_subdirectory(framework/delibs/dethread) |
| 211 | add_subdirectory(framework/delibs/destream) |
| 212 | add_subdirectory(framework/delibs/deutil) |
| 213 | add_subdirectory(framework/delibs/decpp) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 214 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 215 | # ExecServer |
| 216 | add_subdirectory(execserver) |
| 217 | |
| 218 | # Executor framework and tools |
| 219 | if (IS_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/executor) |
| 220 | add_subdirectory(executor) |
| 221 | endif () |
| 222 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 223 | # Test framework include directories |
| 224 | include_directories( |
| 225 | framework/common |
| 226 | framework/qphelper |
| 227 | framework/opengl |
| 228 | framework/opengl/wrapper |
| 229 | framework/referencerenderer |
| 230 | framework/opengl/simplereference |
| 231 | framework/randomshaders |
Pyry Haulos | 3c67e4f | 2014-12-19 15:45:39 -0800 | [diff] [blame] | 232 | framework/egl |
| 233 | framework/egl/wrapper |
Piotr Byszewski | e14df7f | 2020-03-03 14:51:54 +0100 | [diff] [blame] | 234 | framework/xexml |
Pyry Haulos | 846cc3c | 2015-06-29 14:28:58 -0700 | [diff] [blame] | 235 | external/vulkancts/framework/vulkan |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 236 | ) |
| 237 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 238 | if (DE_OS_IS_ANDROID OR DE_OS_IS_IOS) |
| 239 | # On Android deqp modules are compiled as libraries and linked into final .so |
| 240 | set(DEQP_MODULE_LIBRARIES ) |
| 241 | set(DEQP_MODULE_ENTRY_POINTS ) |
| 242 | endif () |
| 243 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 244 | # Macro for adding targets for copying binaries (usually target libraries) to the target destination dir |
| 245 | macro (target_copy_files target dep_name files) |
| 246 | if (NOT "${files}" STREQUAL "") |
| 247 | set(COPY_TARGETS ) |
| 248 | foreach (SRCNAME ${files}) |
| 249 | get_filename_component(BASENAME ${SRCNAME} NAME) |
| 250 | set(DSTNAME "${CMAKE_CURRENT_BINARY_DIR}/${BASENAME}") |
| 251 | add_custom_command(OUTPUT ${DSTNAME} |
| 252 | COMMAND ${CMAKE_COMMAND} -E copy_if_different ${SRCNAME} ${DSTNAME}) |
| 253 | set(COPY_TARGETS ${COPY_TARGETS} ${DSTNAME}) |
| 254 | endforeach () |
| 255 | |
| 256 | add_custom_target(${dep_name} ALL DEPENDS ${COPY_TARGETS}) |
| 257 | add_dependencies(${target} ${dep_name}) |
| 258 | endif () |
| 259 | endmacro (target_copy_files) |
| 260 | |
Pyry Haulos | a338d91 | 2016-11-15 13:54:58 -0800 | [diff] [blame] | 261 | set(MODULE_LIB_TARGET_POSTFIX "-package") |
| 262 | set(MODULE_DATA_TARGET_POSTFIX "-data") |
| 263 | |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 264 | # Macro for adding dEQP module |
Pyry Haulos | a338d91 | 2016-11-15 13:54:58 -0800 | [diff] [blame] | 265 | # This adds 3 targets: |
| 266 | # ${MODULE_NAME}-package: Static library that contains all SRCS and links to LIBS |
| 267 | # ${MODULE_NAME}-data: Custom target that is used for data file copies |
| 268 | # ${MODULE_NAME}: Executable binary (if supported by the platform) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 269 | macro (add_deqp_module MODULE_NAME SRCS LIBS ENTRY) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 270 | |
Pyry Haulos | a338d91 | 2016-11-15 13:54:58 -0800 | [diff] [blame] | 271 | # Library target |
| 272 | add_library("${MODULE_NAME}${MODULE_LIB_TARGET_POSTFIX}" STATIC ${SRCS}) |
| 273 | target_link_libraries("${MODULE_NAME}${MODULE_LIB_TARGET_POSTFIX}" ${LIBS}) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 274 | |
Pyry Haulos | a338d91 | 2016-11-15 13:54:58 -0800 | [diff] [blame] | 275 | set(DEQP_MODULE_LIBRARIES ${DEQP_MODULE_LIBRARIES} "${MODULE_NAME}${MODULE_LIB_TARGET_POSTFIX}") |
| 276 | set(DEQP_MODULE_ENTRY_POINTS ${DEQP_MODULE_ENTRY_POINTS} "${CMAKE_CURRENT_SOURCE_DIR}/${ENTRY}") |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 277 | |
Pyry Haulos | a338d91 | 2016-11-15 13:54:58 -0800 | [diff] [blame] | 278 | # Forward to parent scope |
| 279 | set(DEQP_MODULE_LIBRARIES ${DEQP_MODULE_LIBRARIES} PARENT_SCOPE) |
| 280 | set(DEQP_MODULE_ENTRY_POINTS ${DEQP_MODULE_ENTRY_POINTS} PARENT_SCOPE) |
| 281 | |
| 282 | if (NOT DE_OS_IS_ANDROID AND NOT DE_OS_IS_IOS) |
| 283 | # Executable target |
| 284 | add_executable(${MODULE_NAME} ${PROJECT_SOURCE_DIR}/framework/platform/tcuMain.cpp ${ENTRY}) |
| 285 | target_link_libraries(${MODULE_NAME} tcutil-platform "${MODULE_NAME}${MODULE_LIB_TARGET_POSTFIX}") |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 286 | target_copy_files(${MODULE_NAME} platform-libs-${MODULE_NAME} "${DEQP_PLATFORM_COPY_LIBRARIES}") |
| 287 | endif () |
| 288 | |
| 289 | # Data file target |
Pyry Haulos | a338d91 | 2016-11-15 13:54:58 -0800 | [diff] [blame] | 290 | add_custom_target("${MODULE_NAME}${MODULE_DATA_TARGET_POSTFIX}") |
| 291 | add_dependencies("${MODULE_NAME}${MODULE_LIB_TARGET_POSTFIX}" "${MODULE_NAME}${MODULE_DATA_TARGET_POSTFIX}") |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 292 | endmacro (add_deqp_module) |
| 293 | |
| 294 | # Macro for adding data dirs to module |
| 295 | macro (add_data_dir MODULE_NAME SRC_DIR DST_DIR) |
Pyry Haulos | a338d91 | 2016-11-15 13:54:58 -0800 | [diff] [blame] | 296 | if (DE_OS_IS_WIN32 OR DE_OS_IS_UNIX OR DE_OS_IS_OSX OR DE_OS_IS_QNX) |
| 297 | add_custom_command(TARGET "${MODULE_NAME}${MODULE_DATA_TARGET_POSTFIX}" POST_BUILD COMMAND ${CMAKE_COMMAND} -E copy_directory ${CMAKE_CURRENT_SOURCE_DIR}/${SRC_DIR} ${CMAKE_CURRENT_BINARY_DIR}/${DST_DIR}) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 298 | |
| 299 | elseif (DE_OS_IS_ANDROID) |
Pyry Haulos | a338d91 | 2016-11-15 13:54:58 -0800 | [diff] [blame] | 300 | add_custom_command(TARGET "${MODULE_NAME}${MODULE_DATA_TARGET_POSTFIX}" POST_BUILD COMMAND ${CMAKE_COMMAND} -E copy_directory ${CMAKE_CURRENT_SOURCE_DIR}/${SRC_DIR} ${CMAKE_BINARY_DIR}/assets/${DST_DIR}) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 301 | |
| 302 | elseif (DE_OS_IS_IOS) |
Pyry Haulos | a338d91 | 2016-11-15 13:54:58 -0800 | [diff] [blame] | 303 | add_custom_command(TARGET "${MODULE_NAME}${MODULE_DATA_TARGET_POSTFIX}" POST_BUILD COMMAND ${CMAKE_COMMAND} -E copy_directory ${CMAKE_CURRENT_SOURCE_DIR}/${SRC_DIR} ${CMAKE_BINARY_DIR}/\${CONFIGURATION}\${EFFECTIVE_PLATFORM_NAME}/deqp.app/${DST_DIR}) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 304 | endif () |
| 305 | endmacro (add_data_dir) |
| 306 | |
| 307 | # Macro for adding individual data files to module |
| 308 | macro (add_data_file MODULE_NAME SRC_FILE DST_FILE) |
Pyry Haulos | a338d91 | 2016-11-15 13:54:58 -0800 | [diff] [blame] | 309 | if (DE_OS_IS_WIN32 OR DE_OS_IS_UNIX OR DE_OS_IS_OSX OR DE_OS_IS_QNX) |
| 310 | add_custom_command(TARGET "${MODULE_NAME}${MODULE_DATA_TARGET_POSTFIX}" POST_BUILD COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_CURRENT_SOURCE_DIR}/${SRC_FILE} ${CMAKE_CURRENT_BINARY_DIR}/${DST_FILE}) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 311 | |
| 312 | elseif (DE_OS_IS_ANDROID) |
Pyry Haulos | a338d91 | 2016-11-15 13:54:58 -0800 | [diff] [blame] | 313 | add_custom_command(TARGET "${MODULE_NAME}${MODULE_DATA_TARGET_POSTFIX}" POST_BUILD COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_CURRENT_SOURCE_DIR}/${SRC_FILE} ${CMAKE_BINARY_DIR}/assets/${DST_FILE}) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 314 | |
| 315 | elseif (DE_OS_IS_IOS) |
Pyry Haulos | a338d91 | 2016-11-15 13:54:58 -0800 | [diff] [blame] | 316 | add_custom_command(TARGET "${MODULE_NAME}${MODULE_DATA_TARGET_POSTFIX}" POST_BUILD COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_CURRENT_SOURCE_DIR}/${SRC_FILE} ${CMAKE_BINARY_DIR}/\${CONFIGURATION}\${EFFECTIVE_PLATFORM_NAME}/deqp.app/${DST_FILE}) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 317 | endif () |
| 318 | endmacro (add_data_file) |
| 319 | |
| 320 | add_subdirectory(framework) |
Pyry Haulos | 846cc3c | 2015-06-29 14:28:58 -0700 | [diff] [blame] | 321 | add_subdirectory(external/vulkancts/framework/vulkan) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 322 | |
| 323 | if (DE_COMPILER_IS_MSC) |
| 324 | add_compile_options(/bigobj) # Required by glsBuiltinPrecisionTests.cpp |
| 325 | endif () |
| 326 | |
| 327 | add_subdirectory(modules) |
Pyry Haulos | 846cc3c | 2015-06-29 14:28:58 -0700 | [diff] [blame] | 328 | add_subdirectory(external/vulkancts/modules/vulkan) |
Pyry Haulos | 48087f5 | 2016-11-14 11:03:22 -0800 | [diff] [blame] | 329 | add_subdirectory(external/openglcts) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 330 | |
| 331 | # Single-binary targets |
| 332 | if (DE_OS_IS_ANDROID) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 333 | include_directories(executor) |
Piotr Byszewski | fa007c8 | 2021-10-13 14:17:14 +0200 | [diff] [blame] | 334 | include_directories(${PROJECT_BINARY_DIR}/external/vulkancts/framework/vulkan) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 335 | |
Pyry Haulos | cdeac44 | 2016-11-17 15:29:14 -0800 | [diff] [blame] | 336 | set(DEQP_SRCS |
| 337 | framework/platform/android/tcuAndroidMain.cpp |
| 338 | framework/platform/android/tcuAndroidJNI.cpp |
| 339 | framework/platform/android/tcuAndroidPlatformCapabilityQueryJNI.cpp |
| 340 | framework/platform/android/tcuTestLogParserJNI.cpp |
| 341 | ${DEQP_MODULE_ENTRY_POINTS} |
| 342 | ) |
| 343 | |
| 344 | set(DEQP_LIBS |
| 345 | tcutil-platform |
| 346 | xecore |
| 347 | ${DEQP_MODULE_LIBRARIES} |
| 348 | ) |
| 349 | |
| 350 | add_library(deqp SHARED ${DEQP_SRCS}) |
| 351 | target_link_libraries(deqp ${DEQP_LIBS}) |
| 352 | |
Chris Forbes | 651bd0d | 2018-06-13 23:23:02 -0700 | [diff] [blame] | 353 | # Separate out the debug information because it's enormous |
| 354 | add_custom_command(TARGET deqp POST_BUILD |
| 355 | COMMAND ${CMAKE_STRIP} --only-keep-debug -o $<TARGET_FILE:deqp>.debug $<TARGET_FILE:deqp> |
| 356 | COMMAND ${CMAKE_STRIP} -g $<TARGET_FILE:deqp>) |
| 357 | |
Pyry Haulos | cdeac44 | 2016-11-17 15:29:14 -0800 | [diff] [blame] | 358 | # Needed by OpenGL CTS that defines its own activity but depends on |
| 359 | # common Android support code. |
| 360 | target_include_directories(deqp PRIVATE framework/platform/android) |
Jarkko Poyry | 3c82736 | 2014-09-02 11:48:52 +0300 | [diff] [blame] | 361 | |
| 362 | elseif (DE_OS_IS_IOS) |
| 363 | # Code sign identity |
| 364 | set(DEQP_IOS_CODE_SIGN_IDENTITY "drawElements" CACHE STRING "Code sign identity for iOS build") |
| 365 | |
| 366 | set(MACOSX_BUNDLE_PRODUCT_NAME "\${PRODUCT_NAME}") |
| 367 | set(MACOSX_BUNDLE_GUI_IDENTIFIER "com.drawelements.\${PRODUCT_NAME:identifier}") |
| 368 | |
| 369 | include_directories(framework/platform/ios) |
| 370 | set(TESTERCORE_SRC_FILES |
| 371 | framework/platform/ios/tcuEAGLView.h |
| 372 | framework/platform/ios/tcuEAGLView.m |
| 373 | framework/platform/ios/tcuIOSAppDelegate.h |
| 374 | framework/platform/ios/tcuIOSAppDelegate.m |
| 375 | framework/platform/ios/tcuIOSViewController.h |
| 376 | framework/platform/ios/tcuIOSViewController.m |
| 377 | framework/platform/ios/tcuIOSMain.m |
| 378 | ) |
| 379 | set_source_files_properties(${TESTERCORE_SRC_FILES} COMPILE_FLAGS "-std=c99") |
| 380 | |
| 381 | add_executable(deqp MACOSX_BUNDLE ${TESTERCORE_SRC_FILES} ${DEQP_MODULE_ENTRY_POINTS}) |
| 382 | target_link_libraries(deqp tcutil-platform xscore ${DEQP_MODULE_LIBRARIES}) |
| 383 | set_target_properties(deqp PROPERTIES XCODE_ATTRIBUTE_TARGETED_DEVICE_FAMILY "1,2") |
| 384 | set_target_properties(deqp PROPERTIES XCODE_ATTRIBUTE_CODE_SIGN_IDENTITY "iPhone Developer: ${DEQP_IOS_CODE_SIGN_IDENTITY}") |
| 385 | endif () |