2017-12-21 07:45:38 +08:00
|
|
|
#
|
2019-05-14 22:47:35 +08:00
|
|
|
# Copyright (C) 2018-2019 Intel Corporation
|
2017-12-21 07:45:38 +08:00
|
|
|
#
|
2018-09-18 15:11:08 +08:00
|
|
|
# SPDX-License-Identifier: MIT
|
2017-12-21 07:45:38 +08:00
|
|
|
#
|
|
|
|
|
2018-11-19 23:29:16 +08:00
|
|
|
project(ocloc_tests)
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2019-05-14 22:47:35 +08:00
|
|
|
|
2017-12-21 07:45:38 +08:00
|
|
|
set(IGDRCL_SRCS_cloc
|
2018-08-20 18:55:55 +08:00
|
|
|
${IGDRCL_SOURCE_DIR}/offline_compiler/decoder/binary_decoder.cpp
|
|
|
|
${IGDRCL_SOURCE_DIR}/offline_compiler/decoder/binary_encoder.cpp
|
|
|
|
${IGDRCL_SOURCE_DIR}/offline_compiler/offline_compiler.cpp
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
set(IGDRCL_SRCS_offline_compiler_mock
|
2018-08-20 18:55:55 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/decoder/mock/mock_decoder.h
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/decoder/mock/mock_encoder.h
|
2019-06-27 03:19:34 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/decoder/mock/mock_iga_wrapper.h
|
2018-08-20 18:55:55 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/mock/mock_offline_compiler.h
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
|
|
|
|
2019-05-14 22:47:35 +08:00
|
|
|
set(CLOC_SRCS_UTILITIES
|
|
|
|
${IGDRCL_SOURCE_DIR}/offline_compiler/utilities/safety_caller.h
|
|
|
|
)
|
|
|
|
|
|
|
|
if(WIN32)
|
|
|
|
list(APPEND CLOC_SRCS_UTILITIES
|
|
|
|
${IGDRCL_SOURCE_DIR}/offline_compiler/utilities/windows/safety_caller_windows.cpp
|
|
|
|
${IGDRCL_SOURCE_DIR}/offline_compiler/utilities/windows/safety_guard_windows.h
|
|
|
|
${IGDRCL_SOURCE_DIR}/offline_compiler/utilities/windows/seh_exception.cpp
|
|
|
|
${IGDRCL_SOURCE_DIR}/offline_compiler/utilities/windows/seh_exception.h
|
|
|
|
)
|
|
|
|
else()
|
|
|
|
list(APPEND CLOC_SRCS_UTILITIES
|
|
|
|
${IGDRCL_SOURCE_DIR}/offline_compiler/utilities/linux/safety_caller_linux.cpp
|
|
|
|
${IGDRCL_SOURCE_DIR}/offline_compiler/utilities/linux/safety_guard_linux.h
|
|
|
|
)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
|
|
|
2017-12-21 07:45:38 +08:00
|
|
|
set(IGDRCL_SRCS_offline_compiler_tests
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/CMakeLists.txt
|
2018-08-20 18:55:55 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/decoder/decoder_tests.cpp
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/decoder/encoder_tests.cpp
|
2017-12-21 07:45:38 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/environment.h
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/main.cpp
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/offline_compiler_tests.cpp
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/offline_compiler_tests.h
|
2019-09-05 15:35:56 +08:00
|
|
|
${IGDRCL_SOURCE_DIR}/core/helpers/abort.cpp
|
2017-12-21 07:45:38 +08:00
|
|
|
${IGDRCL_SOURCE_DIR}/runtime/helpers/file_io.cpp
|
|
|
|
${IGDRCL_SOURCE_DIR}/runtime/memory_manager/deferred_deleter.cpp
|
|
|
|
${IGDRCL_SOURCE_DIR}/runtime/memory_manager/deferred_deleter.h
|
|
|
|
${IGDRCL_SOURCE_DIR}/unit_tests/helpers/test_files.cpp
|
|
|
|
${IGDRCL_SRCS_cloc}
|
|
|
|
${IGDRCL_SRCS_offline_compiler_mock}
|
|
|
|
${CLOC_SRCS_LIB}
|
2019-05-14 22:47:35 +08:00
|
|
|
${CLOC_SRCS_UTILITIES}
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
|
|
|
|
2018-05-22 23:23:39 +08:00
|
|
|
if(WIN32)
|
|
|
|
list(APPEND IGDRCL_SRCS_offline_compiler_tests
|
|
|
|
${IGDRCL_SOURCE_DIR}/runtime/os_interface/windows/os_thread_win.cpp
|
|
|
|
)
|
|
|
|
else()
|
|
|
|
list(APPEND IGDRCL_SRCS_offline_compiler_tests
|
|
|
|
${IGDRCL_SOURCE_DIR}/runtime/os_interface/linux/os_thread_linux.cpp
|
|
|
|
)
|
|
|
|
endif()
|
|
|
|
|
2017-12-21 07:45:38 +08:00
|
|
|
link_directories(${CMAKE_RUNTIME_OUTPUT_DIRECTORY})
|
2018-02-21 07:31:41 +08:00
|
|
|
|
2018-11-19 23:29:16 +08:00
|
|
|
add_executable(ocloc_tests ${IGDRCL_SRCS_offline_compiler_tests})
|
2018-02-21 07:31:41 +08:00
|
|
|
|
2018-11-19 23:29:16 +08:00
|
|
|
target_include_directories(ocloc_tests PRIVATE
|
|
|
|
$<TARGET_PROPERTY:ocloc,INCLUDE_DIRECTORIES>
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
2018-11-19 23:29:16 +08:00
|
|
|
target_compile_definitions(ocloc_tests PUBLIC MOCKABLE_VIRTUAL=virtual $<TARGET_PROPERTY:ocloc,INTERFACE_COMPILE_DEFINITIONS>)
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-11-19 23:29:16 +08:00
|
|
|
target_link_libraries(ocloc_tests igdrcl_mocks gmock-gtest elflib)
|
2018-02-21 07:31:41 +08:00
|
|
|
|
2019-05-14 22:47:35 +08:00
|
|
|
if(WIN32)
|
|
|
|
target_link_libraries(ocloc_tests dbghelp)
|
|
|
|
endif()
|
|
|
|
|
2017-12-21 07:45:38 +08:00
|
|
|
if(UNIX)
|
2018-11-19 23:29:16 +08:00
|
|
|
target_link_libraries(ocloc_tests dl pthread)
|
2017-12-21 07:45:38 +08:00
|
|
|
endif()
|
|
|
|
|
2018-11-19 23:29:16 +08:00
|
|
|
get_property(CLOC_FOLDER TARGET ocloc PROPERTY FOLDER)
|
|
|
|
get_property(CLOC_COMPILE_FLAGS TARGET ocloc PROPERTY COMPILE_FLAGS)
|
|
|
|
set_property(TARGET ocloc_tests PROPERTY FOLDER ${CLOC_FOLDER})
|
|
|
|
set_property(TARGET ocloc_tests APPEND_STRING PROPERTY COMPILE_FLAGS ${CLOC_COMPILE_FLAGS})
|
2017-12-21 07:45:38 +08:00
|
|
|
|
|
|
|
string(TOLOWER ${DEFAULT_TESTED_PLATFORM} CLOC_DEFAULT_DEVICE)
|
|
|
|
|
2018-11-19 23:29:16 +08:00
|
|
|
add_custom_target(run_ocloc_tests ALL
|
|
|
|
DEPENDS ocloc_tests
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
2018-04-18 00:11:50 +08:00
|
|
|
macro(macro_for_each_platform)
|
|
|
|
if("${PLATFORM_IT_LOWER}" STREQUAL "${CLOC_DEFAULT_DEVICE}")
|
2019-07-24 17:43:29 +08:00
|
|
|
foreach(PLATFORM_TYPE ${PLATFORM_TYPES})
|
2018-04-18 00:11:50 +08:00
|
|
|
if(${PLATFORM_IT}_IS_${PLATFORM_TYPE})
|
|
|
|
get_family_name_with_type(${GEN_TYPE} ${PLATFORM_TYPE})
|
2018-11-19 23:29:16 +08:00
|
|
|
add_dependencies(run_ocloc_tests test_kernels_${family_name_with_type})
|
2018-08-20 18:55:55 +08:00
|
|
|
neo_copy_test_files(copy_test_files_${family_name_with_type} ${family_name_with_type})
|
2018-11-19 23:29:16 +08:00
|
|
|
add_dependencies(run_ocloc_tests copy_test_files_${family_name_with_type})
|
|
|
|
set(run_tests_cmd ocloc_tests --device ${CLOC_DEFAULT_DEVICE} --family_type ${family_name_with_type})
|
2018-04-18 00:11:50 +08:00
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
endif()
|
|
|
|
endmacro()
|
|
|
|
macro(macro_for_each_gen)
|
|
|
|
apply_macro_for_each_platform()
|
|
|
|
endmacro()
|
|
|
|
apply_macro_for_each_gen("TESTED")
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-11-19 23:29:16 +08:00
|
|
|
set_property(TARGET run_ocloc_tests PROPERTY FOLDER ${CLOC_FOLDER})
|
2018-03-08 18:42:23 +08:00
|
|
|
|
|
|
|
if(WIN32)
|
2017-12-21 07:45:38 +08:00
|
|
|
add_custom_command(
|
2018-11-19 23:29:16 +08:00
|
|
|
TARGET run_ocloc_tests
|
2017-12-21 07:45:38 +08:00
|
|
|
POST_BUILD
|
|
|
|
COMMAND echo deleting offline compiler files and directories...
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_DEFAULT_DEVICE}/copybuffer_${CLOC_DEFAULT_DEVICE}.bc
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_DEFAULT_DEVICE}/copybuffer_${CLOC_DEFAULT_DEVICE}.gen
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_DEFAULT_DEVICE}/copybuffer_${CLOC_DEFAULT_DEVICE}.bin
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove_directory ${TargetDir}/${CLOC_DEFAULT_DEVICE}/offline_compiler_test
|
2018-04-18 00:11:50 +08:00
|
|
|
COMMAND ${run_tests_cmd}
|
2018-03-08 22:34:27 +08:00
|
|
|
WORKING_DIRECTORY ${TargetDir}
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
|
|
|
else()
|
|
|
|
add_custom_command(
|
2018-11-19 23:29:16 +08:00
|
|
|
TARGET run_ocloc_tests
|
2017-12-21 07:45:38 +08:00
|
|
|
POST_BUILD
|
|
|
|
COMMAND echo deleting offline compiler files and directories...
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_DEFAULT_DEVICE}/*.bc
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_DEFAULT_DEVICE}/*.gen
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_DEFAULT_DEVICE}/*.ll
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_DEFAULT_DEVICE}/*.bin
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove_directory "${TargetDir}/offline_compiler_test"
|
2018-04-18 00:11:50 +08:00
|
|
|
COMMAND ${run_tests_cmd}
|
2018-03-06 17:54:29 +08:00
|
|
|
WORKING_DIRECTORY ${TargetDir}
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
|
|
|
endif()
|
2018-06-22 23:38:00 +08:00
|
|
|
|
|
|
|
add_subdirectories()
|
2018-11-19 23:29:16 +08:00
|
|
|
create_project_source_tree(ocloc_tests ${IGDRCL_SOURCE_DIR}/runtime ${IGDRCL_SOURCE_DIR}/unit_tests ${IGDRCL_SOURCE_DIR})
|