Fix stray whitespace in external memory tests
[platform/upstream/VK-GL-CTS.git] / CMakeLists.txt
index da4b5bf..aee9d32 100644 (file)
@@ -1,10 +1,15 @@
 # dEQP cmake file
 
-cmake_minimum_required(VERSION 2.6)
+cmake_minimum_required(VERSION 2.8)
 
 # dEQP Target.
 set(DEQP_TARGET "default" CACHE STRING "dEQP Target (default, android...)")
 
+if (DEFINED DEQP_TARGET_TOOLCHAIN)
+       # \note Toolchain must be included before project() command
+       include(targets/${DEQP_TARGET}/${DEQP_TARGET_TOOLCHAIN}.cmake NO_POLICY_SCOPE)
+endif ()
+
 project(dEQP-Core-${DEQP_TARGET})
 
 include(framework/delibs/cmake/Defs.cmake NO_POLICY_SCOPE)
@@ -15,29 +20,21 @@ add_definitions(-DDE_ASSERT_FAILURE_CALLBACK)
 # dEQP-specific configuration. Target file should override these.
 set(DEQP_TARGET_NAME           "UNKNOWN")              # Target name
 
-set(DEQP_SUPPORT_GLES1         OFF)                    # Is GLESv1 supported
-set(DEQP_GLES1_LIBRARIES       )                               # GLESv1 libraries
-
-set(DEQP_SUPPORT_GLES2         OFF)                    # Is GLESv2 supported
 set(DEQP_GLES2_LIBRARIES       )                               # GLESv2 libraries. If empty, run-time linking is used
-
-set(DEQP_SUPPORT_GLES3         OFF)                    # Is GLESv3 supported
 set(DEQP_GLES3_LIBRARIES       )                               # GLESv3 libraries. If empty, run-time linking is used
+set(DEQP_EGL_LIBRARIES         )                               # EGL libraries
 
-set(DEQP_SUPPORT_VG                    OFF)                    # Is VG supported
+# Legacy APIs that don't use run-time loading
+set(DEQP_SUPPORT_GLES1         OFF)                    # Is GLESv1 supported
+set(DEQP_GLES1_LIBRARIES       )                               # GLESv1 libraries
+set(DEQP_SUPPORT_VG                    OFF)                    # Is OpenVG supported
 set(DEQP_VG_LIBRARIES          )                               # VG libraries
 
-set(DEQP_SUPPORT_EGL           OFF)                    # Is EGL supported
-set(DEQP_EGL_LIBRARIES         )                               # EGL libraries
-
-set(DEQP_SUPPORT_GLX           OFF)                    # Is GLX supported
-set(DEQP_SUPPORT_WGL           OFF)                    # Is WGL supported
+set(DEQP_SUPPORT_WGL           OFF)
+set(DEQP_SUPPORT_GLX           OFF)                    # Is GLX supported \todo [2016-10-12 pyry] X11 specific - move to framework/platform/
 
 set(DEQP_PLATFORM_LIBRARIES    )                               # Other platform libraries
 
-set(DEQP_SUPPORT_OPENGL                OFF)                    # Is OpenGL supported on platform
-                                                                                       # \note OpenGL is always loaded on run-time
-
 set(DEQP_PLATFORM_COPY_LIBRARIES       )               # Libraries / binaries that need to be copied to binary directory
 
 # Delibs include directories
@@ -66,8 +63,14 @@ endif ()
 include_directories(${ZLIB_INCLUDE_PATH})
 
 # libpng
-find_path(PNG_INCLUDE_PATH     png.h)
-find_library(PNG_LIBRARY       png)
+#
+# The FindPNG module defines PNG_INCLUDE_DIRS and PNG_LIBRARIES. But dEQP's
+# CMake files expect the non-standard PNG_INCLUDE_PATH and PNG_LIBRARY. Set the
+# non-standard variables here to retain compatibility with dEQP's existing
+# CMake files.
+include(FindPNG)
+set(PNG_INCLUDE_PATH ${PNG_INCLUDE_DIRS})
+set(PNG_LIBRARY ${PNG_LIBRARIES})
 
 if (NOT PNG_INCLUDE_PATH OR NOT PNG_LIBRARY)
        message(STATUS "System version of libpng not found, using external/libpng")
@@ -86,78 +89,54 @@ include_directories(${PNG_INCLUDE_PATH})
 message(STATUS "DEQP_TARGET_NAME        = ${DEQP_TARGET_NAME}")
 message(STATUS "DEQP_SUPPORT_GLES1      = ${DEQP_SUPPORT_GLES1}")
 message(STATUS "DEQP_GLES1_LIBRARIES    = ${DEQP_GLES1_LIBRARIES}")
-message(STATUS "DEQP_SUPPORT_GLES2      = ${DEQP_SUPPORT_GLES2}")
 message(STATUS "DEQP_GLES2_LIBRARIES    = ${DEQP_GLES2_LIBRARIES}")
-message(STATUS "DEQP_SUPPORT_GLES3      = ${DEQP_SUPPORT_GLES3}")
 message(STATUS "DEQP_GLES3_LIBRARIES    = ${DEQP_GLES3_LIBRARIES}")
+message(STATUS "DEQP_GLES31_LIBRARIES   = ${DEQP_GLES31_LIBRARIES}")
+message(STATUS "DEQP_GLES32_LIBRARIES   = ${DEQP_GLES32_LIBRARIES}")
 message(STATUS "DEQP_SUPPORT_VG         = ${DEQP_SUPPORT_VG}")
 message(STATUS "DEQP_VG_LIBRARIES       = ${DEQP_VG_LIBRARIES}")
-message(STATUS "DEQP_SUPPORT_EGL        = ${DEQP_SUPPORT_EGL}")
 message(STATUS "DEQP_EGL_LIBRARIES      = ${DEQP_EGL_LIBRARIES}")
-message(STATUS "DEQP_SUPPORT_OPENGL     = ${DEQP_SUPPORT_OPENGL}")
 message(STATUS "DEQP_PLATFORM_LIBRARIES = ${DEQP_PLATFORM_LIBRARIES}")
-message(STATUS "DEQP_SUPPORT_WGL        = ${DEQP_SUPPORT_WGL}")
-message(STATUS "DEQP_SUPPORT_GLX        = ${DEQP_SUPPORT_GLX}")
 
 # Defines
 add_definitions(-DDEQP_TARGET_NAME="${DEQP_TARGET_NAME}")
 
-if (DEQP_SUPPORT_GLES1)
-       add_definitions(-DDEQP_SUPPORT_GLES1=1)
-endif ()
-
-if (DEQP_SUPPORT_GLES2)
-       add_definitions(-DDEQP_SUPPORT_GLES2=1)
-endif ()
-
-if (DEQP_SUPPORT_GLES3)
-       add_definitions(-DDEQP_SUPPORT_GLES3=1)
-endif ()
-
-if (DEQP_SUPPORT_VG)
-       add_definitions(-DDEQP_SUPPORT_VG=1)
-endif ()
-
-if (DEQP_SUPPORT_EGL)
-       add_definitions(-DDEQP_SUPPORT_EGL=1)
-endif ()
-
-if (DEQP_SUPPORT_OPENGL)
-       add_definitions(-DDEQP_SUPPORT_OPENGL=1)
+# Entry points loaded directly by linking to libGL*?
+if (DEFINED DEQP_GLES2_LIBRARIES)
+       add_definitions(-DDEQP_GLES2_DIRECT_LINK=1)
 endif ()
 
-if (DEQP_SUPPORT_WGL)
-       add_definitions(-DDEQP_SUPPORT_WGL=1)
+if (DEFINED DEQP_GLES3_LIBRARIES)
+       add_definitions(-DDEQP_GLES3_DIRECT_LINK=1)
 endif ()
 
-if (DEQP_SUPPORT_GLX)
-       add_definitions(-DDEQP_SUPPORT_GLX=1)
+if (DEFINED DEQP_GLES31_LIBRARIES)
+       add_definitions(-DDEQP_GLES31_DIRECT_LINK=1)
 endif ()
 
-# Check runtime linking support
-if (DEQP_SUPPORT_GLES1 AND NOT DEFINED DEQP_GLES1_LIBRARIES)
-       message(FATAL_ERROR "Run-time loading of GLES1 is not supported (DEQP_GLES1_LIBRARIES is not set)")
+if (DEFINED DEQP_GLES32_LIBRARIES)
+       add_definitions(-DDEQP_GLES32_DIRECT_LINK=1)
 endif ()
 
-if (DEQP_SUPPORT_GLES2 AND NOT DEFINED DEQP_GLES2_LIBRARIES)
-       add_definitions(-DDEQP_GLES2_RUNTIME_LOAD=1)
+if (DEFINED DEQP_EGL_LIBRARIES)
+       add_definitions(-DDEQP_EGL_DIRECT_LINK=1)
 endif ()
 
-if (DEQP_SUPPORT_GLES3 AND NOT DEFINED DEQP_GLES3_LIBRARIES)
-       add_definitions(-DDEQP_GLES3_RUNTIME_LOAD=1)
-endif ()
+# Legacy APIs that don't support run-time loading
+if (DEQP_SUPPORT_GLES1)
+       add_definitions(-DDEQP_SUPPORT_GLES1=1)
 
-if (DEQP_SUPPORT_VG AND NOT DEFINED DEQP_VG_LIBRARIES)
-       message(FATAL_ERROR "Run-time loading of VG is not supported (DEQP_VG_LIBRARIES is not set)")
+       if (NOT DEFINED DEQP_GLES1_LIBRARIES)
+               message(FATAL_ERROR "Run-time loading of GLES1 is not supported (DEQP_GLES1_LIBRARIES is not set)")
+       endif ()
 endif ()
 
-if (DEQP_SUPPORT_EGL AND NOT DEFINED DEQP_EGL_LIBRARIES)
-       add_definitions(-DDEQP_EGL_RUNTIME_LOAD=1)
-endif ()
+if (DEQP_SUPPORT_VG)
+       add_definitions(-DDEQP_SUPPORT_VG=1)
 
-# OpenGL is always loaded on run-time
-if (DEQP_SUPPORT_OPENGL)
-       add_definitions(-DDEQP_OPENGL_RUNTIME_LOAD=1)
+       if (NOT DEFINED DEQP_VG_LIBRARIES)
+               message(FATAL_ERROR "Run-time loading of VG is not supported (DEQP_VG_LIBRARIES is not set)")
+       endif ()
 endif ()
 
 if (DE_COMPILER_IS_MSC)
@@ -201,10 +180,6 @@ if (DE_OS_IS_ANDROID OR DE_OS_IS_IOS)
        set(DEQP_MODULE_ENTRY_POINTS )
 endif ()
 
-if (DE_OS_IS_WIN32)
-       include_directories(framework/platform/win32)
-endif ()
-
 # Macro for adding targets for copying binaries (usually target libraries) to the target destination dir
 macro (target_copy_files target dep_name files)
        if (NOT "${files}" STREQUAL "")
@@ -222,55 +197,62 @@ macro (target_copy_files target dep_name files)
        endif ()
 endmacro (target_copy_files)
 
+set(MODULE_LIB_TARGET_POSTFIX  "-package")
+set(MODULE_DATA_TARGET_POSTFIX "-data")
+
 # Macro for adding dEQP module
+# This adds 3 targets:
+#      ${MODULE_NAME}-package:         Static library that contains all SRCS and links to LIBS
+#      ${MODULE_NAME}-data:            Custom target that is used for data file copies
+#      ${MODULE_NAME}:                         Executable binary (if supported by the platform)
 macro (add_deqp_module MODULE_NAME SRCS LIBS ENTRY)
-       if (DE_OS_IS_ANDROID OR DE_OS_IS_IOS)
-               # Single-binary targets
-               add_library(${MODULE_NAME} STATIC ${SRCS})
-               target_link_libraries(${MODULE_NAME} ${LIBS})
-
-               set(DEQP_MODULE_LIBRARIES               ${DEQP_MODULE_LIBRARIES} ${MODULE_NAME})
-               set(DEQP_MODULE_ENTRY_POINTS    ${DEQP_MODULE_ENTRY_POINTS} "${CMAKE_CURRENT_SOURCE_DIR}/${ENTRY}")
-
-               # Forward to parent scope
-               set(DEQP_MODULE_LIBRARIES               ${DEQP_MODULE_LIBRARIES} PARENT_SCOPE)
-               set(DEQP_MODULE_ENTRY_POINTS    ${DEQP_MODULE_ENTRY_POINTS} PARENT_SCOPE)
-
-       else ()
-               # Separate binary per target
-               add_executable(${MODULE_NAME} ${CMAKE_SOURCE_DIR}/framework/platform/tcuMain.cpp ${ENTRY} ${SRCS})
-               target_link_libraries(${MODULE_NAME} tcutil-platform ${LIBS})
+
+       # Library target
+       add_library("${MODULE_NAME}${MODULE_LIB_TARGET_POSTFIX}" STATIC ${SRCS})
+       target_link_libraries("${MODULE_NAME}${MODULE_LIB_TARGET_POSTFIX}" ${LIBS})
+
+       set(DEQP_MODULE_LIBRARIES               ${DEQP_MODULE_LIBRARIES} "${MODULE_NAME}${MODULE_LIB_TARGET_POSTFIX}")
+       set(DEQP_MODULE_ENTRY_POINTS    ${DEQP_MODULE_ENTRY_POINTS} "${CMAKE_CURRENT_SOURCE_DIR}/${ENTRY}")
+
+       # Forward to parent scope
+       set(DEQP_MODULE_LIBRARIES               ${DEQP_MODULE_LIBRARIES} PARENT_SCOPE)
+       set(DEQP_MODULE_ENTRY_POINTS    ${DEQP_MODULE_ENTRY_POINTS} PARENT_SCOPE)
+
+       if (NOT DE_OS_IS_ANDROID AND NOT DE_OS_IS_IOS)
+               # Executable target
+               add_executable(${MODULE_NAME} ${PROJECT_SOURCE_DIR}/framework/platform/tcuMain.cpp ${ENTRY})
+               target_link_libraries(${MODULE_NAME} tcutil-platform "${MODULE_NAME}${MODULE_LIB_TARGET_POSTFIX}")
                target_copy_files(${MODULE_NAME} platform-libs-${MODULE_NAME} "${DEQP_PLATFORM_COPY_LIBRARIES}")
        endif ()
 
        # Data file target
-       add_custom_target(${MODULE_NAME}-data)
-       add_dependencies(${MODULE_NAME} ${MODULE_NAME}-data)
+       add_custom_target("${MODULE_NAME}${MODULE_DATA_TARGET_POSTFIX}")
+       add_dependencies("${MODULE_NAME}${MODULE_LIB_TARGET_POSTFIX}" "${MODULE_NAME}${MODULE_DATA_TARGET_POSTFIX}")
 endmacro (add_deqp_module)
 
 # Macro for adding data dirs to module
 macro (add_data_dir MODULE_NAME SRC_DIR DST_DIR)
-       if (DE_OS_IS_WIN32 OR DE_OS_IS_UNIX OR DE_OS_IS_OSX)
-               add_custom_command(TARGET ${MODULE_NAME}-data POST_BUILD COMMAND ${CMAKE_COMMAND} -E copy_directory ${CMAKE_CURRENT_SOURCE_DIR}/${SRC_DIR} ${CMAKE_CURRENT_BINARY_DIR}/${DST_DIR})
+       if (DE_OS_IS_WIN32 OR DE_OS_IS_UNIX OR DE_OS_IS_OSX OR DE_OS_IS_QNX)
+               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})
 
        elseif (DE_OS_IS_ANDROID)
-               add_custom_command(TARGET ${MODULE_NAME}-data POST_BUILD COMMAND ${CMAKE_COMMAND} -E copy_directory ${CMAKE_CURRENT_SOURCE_DIR}/${SRC_DIR} ${CMAKE_BINARY_DIR}/assets/${DST_DIR})
+               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})
 
        elseif (DE_OS_IS_IOS)
-               add_custom_command(TARGET ${MODULE_NAME}-data 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})
+               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})
        endif ()
 endmacro (add_data_dir)
 
 # Macro for adding individual data files to module
 macro (add_data_file MODULE_NAME SRC_FILE DST_FILE)
-       if (DE_OS_IS_WIN32 OR DE_OS_IS_UNIX OR DE_OS_IS_OSX)
-               add_custom_command(TARGET ${MODULE_NAME}-data POST_BUILD COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_CURRENT_SOURCE_DIR}/${SRC_FILE} ${CMAKE_CURRENT_BINARY_DIR}/${DST_FILE})
+       if (DE_OS_IS_WIN32 OR DE_OS_IS_UNIX OR DE_OS_IS_OSX OR DE_OS_IS_QNX)
+               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})
 
        elseif (DE_OS_IS_ANDROID)
-               add_custom_command(TARGET ${MODULE_NAME}-data POST_BUILD COMMAND ${CMAKE_COMMAND} -E copy_if_different ${CMAKE_CURRENT_SOURCE_DIR}/${SRC_FILE} ${CMAKE_BINARY_DIR}/assets/${DST_FILE})
+               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})
 
        elseif (DE_OS_IS_IOS)
-               add_custom_command(TARGET ${MODULE_NAME}-data 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})
+               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})
        endif ()
 endmacro (add_data_file)
 
@@ -283,13 +265,32 @@ endif ()
 
 add_subdirectory(modules)
 add_subdirectory(external/vulkancts/modules/vulkan)
+add_subdirectory(external/openglcts)
 
 # Single-binary targets
 if (DE_OS_IS_ANDROID)
        include_directories(executor)
 
-       add_library(deqp SHARED framework/platform/android/tcuAndroidMain.cpp framework/platform/android/tcuAndroidJNI.cpp framework/platform/android/tcuAndroidPlatformCapabilityQueryJNI.cpp framework/platform/android/tcuTestLogParserJNI.cpp ${DEQP_MODULE_ENTRY_POINTS})
-       target_link_libraries(deqp tcutil-platform xecore ${DEQP_MODULE_LIBRARIES})
+       set(DEQP_SRCS
+               framework/platform/android/tcuAndroidMain.cpp
+               framework/platform/android/tcuAndroidJNI.cpp
+               framework/platform/android/tcuAndroidPlatformCapabilityQueryJNI.cpp
+               framework/platform/android/tcuTestLogParserJNI.cpp
+               ${DEQP_MODULE_ENTRY_POINTS}
+               )
+
+       set(DEQP_LIBS
+               tcutil-platform
+               xecore
+               ${DEQP_MODULE_LIBRARIES}
+               )
+
+       add_library(deqp SHARED ${DEQP_SRCS})
+       target_link_libraries(deqp ${DEQP_LIBS})
+
+       # Needed by OpenGL CTS that defines its own activity but depends on
+       # common Android support code.
+       target_include_directories(deqp PRIVATE framework/platform/android)
 
 elseif (DE_OS_IS_IOS)
        # Code sign identity