2017-12-21 07:45:38 +08:00
|
|
|
#
|
2021-01-12 19:56:17 +08:00
|
|
|
# Copyright (C) 2018-2021 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
|
|
|
|
|
|
|
set(IGDRCL_SRCS_cloc
|
2020-08-19 18:18:18 +08:00
|
|
|
${OCLOC_DIRECTORY}/source/decoder/binary_decoder.cpp
|
|
|
|
${OCLOC_DIRECTORY}/source/decoder/binary_encoder.cpp
|
|
|
|
${OCLOC_DIRECTORY}/source/offline_compiler.cpp
|
|
|
|
${OCLOC_DIRECTORY}/source/ocloc_fatbinary.cpp
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
set(IGDRCL_SRCS_offline_compiler_mock
|
2020-08-19 18:18:18 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/decoder/mock/mock_decoder.h
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/decoder/mock/mock_encoder.h
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/decoder/mock/mock_iga_wrapper.h
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/mock/mock_argument_helper.h
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/mock/mock_offline_compiler.h
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/mock/mock_sip_ocloc_tests.cpp
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
|
|
|
|
2020-02-07 21:06:50 +08:00
|
|
|
set(CLOC_LIB_SRCS_UTILITIES
|
2020-08-19 18:18:18 +08:00
|
|
|
${OCLOC_DIRECTORY}/source/utilities/safety_caller.h
|
|
|
|
${OCLOC_DIRECTORY}/source/utilities//get_current_dir.h
|
2019-05-14 22:47:35 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
if(WIN32)
|
2020-02-07 21:06:50 +08:00
|
|
|
list(APPEND CLOC_LIB_SRCS_UTILITIES
|
2020-08-19 18:18:18 +08:00
|
|
|
${OCLOC_DIRECTORY}/source/utilities/windows/safety_caller_windows.cpp
|
|
|
|
${OCLOC_DIRECTORY}/source/utilities/windows/safety_guard_windows.h
|
|
|
|
${OCLOC_DIRECTORY}/source/utilities/windows/seh_exception.cpp
|
|
|
|
${OCLOC_DIRECTORY}/source/utilities/windows/seh_exception.h
|
|
|
|
${OCLOC_DIRECTORY}/source/utilities/windows/get_current_dir_windows.cpp
|
2019-05-14 22:47:35 +08:00
|
|
|
)
|
|
|
|
else()
|
2020-02-07 21:06:50 +08:00
|
|
|
list(APPEND CLOC_LIB_SRCS_UTILITIES
|
2020-08-19 18:18:18 +08:00
|
|
|
${OCLOC_DIRECTORY}/source/utilities/linux/safety_caller_linux.cpp
|
|
|
|
${OCLOC_DIRECTORY}/source/utilities/linux/safety_guard_linux.h
|
|
|
|
${OCLOC_DIRECTORY}/source/utilities/linux/get_current_dir_linux.cpp
|
2019-05-14 22:47:35 +08:00
|
|
|
)
|
|
|
|
endif()
|
|
|
|
|
2021-05-21 18:22:13 +08:00
|
|
|
get_property(NEO_CORE_tests_compiler_mocks GLOBAL PROPERTY NEO_CORE_tests_compiler_mocks)
|
2020-02-06 00:28:17 +08:00
|
|
|
|
2017-12-21 07:45:38 +08:00
|
|
|
set(IGDRCL_SRCS_offline_compiler_tests
|
2020-08-19 18:18:18 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/CMakeLists.txt
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/decoder/decoder_tests.cpp
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/decoder/encoder_tests.cpp
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/environment.h
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/main.cpp
|
2020-08-26 18:53:38 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/ocloc_api_tests.cpp
|
2020-08-19 18:18:18 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/ocloc_fatbinary_tests.cpp
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/ocloc_fatbinary_tests.h
|
2021-05-20 23:26:42 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/ocloc_tests_configuration.cpp
|
2020-08-19 18:18:18 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/ocloc_validator_tests.cpp
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/offline_compiler_tests.cpp
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/offline_compiler_tests.h
|
|
|
|
${NEO_SHARED_DIRECTORY}/helpers/abort.cpp
|
|
|
|
${NEO_SHARED_DIRECTORY}/helpers/file_io.cpp
|
|
|
|
${NEO_SHARED_DIRECTORY}/memory_manager/deferred_deleter.cpp
|
|
|
|
${NEO_SHARED_DIRECTORY}/memory_manager/deferred_deleter.h
|
2021-05-21 18:22:13 +08:00
|
|
|
${NEO_SHARED_TEST_DIRECTORY}/common/mocks/mock_compilers.cpp
|
|
|
|
${NEO_SHARED_TEST_DIRECTORY}/common/mocks/mock_compilers.h
|
2021-01-12 19:56:17 +08:00
|
|
|
${NEO_SHARED_TEST_DIRECTORY}/unit_test/device_binary_format/zebin_tests.h
|
2021-01-21 20:10:13 +08:00
|
|
|
${NEO_SHARED_TEST_DIRECTORY}/common/helpers/test_files.cpp
|
2020-08-19 18:18:18 +08:00
|
|
|
${IGDRCL_SRCS_cloc}
|
|
|
|
${IGDRCL_SRCS_offline_compiler_mock}
|
2021-05-21 18:22:13 +08:00
|
|
|
${NEO_CORE_tests_compiler_mocks}
|
2020-08-19 18:18:18 +08:00
|
|
|
${CLOC_LIB_SRCS_LIB}
|
|
|
|
${CLOC_LIB_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
|
2020-08-19 18:18:18 +08:00
|
|
|
${NEO_SHARED_DIRECTORY}/os_interface/windows/os_thread_win.cpp
|
2018-05-22 23:23:39 +08:00
|
|
|
)
|
|
|
|
else()
|
|
|
|
list(APPEND IGDRCL_SRCS_offline_compiler_tests
|
2020-08-19 18:18:18 +08:00
|
|
|
${NEO_SHARED_DIRECTORY}/os_interface/linux/os_thread_linux.cpp
|
2021-02-23 21:03:54 +08:00
|
|
|
${NEO_SHARED_DIRECTORY}/os_interface/linux/sys_calls_linux.cpp
|
|
|
|
${OCLOC_DIRECTORY}/source/linux/os_library_ocloc_helper.cpp
|
2018-05-22 23:23:39 +08:00
|
|
|
)
|
|
|
|
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
|
2020-08-19 18:18:18 +08:00
|
|
|
$<TARGET_PROPERTY:ocloc_lib,INCLUDE_DIRECTORIES>
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
2020-02-07 21:06:50 +08:00
|
|
|
target_compile_definitions(ocloc_tests PUBLIC MOCKABLE_VIRTUAL=virtual $<TARGET_PROPERTY:ocloc_lib,INTERFACE_COMPILE_DEFINITIONS>)
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2020-01-26 02:18:48 +08:00
|
|
|
target_link_libraries(ocloc_tests gmock-gtest)
|
2018-02-21 07:31:41 +08:00
|
|
|
|
2019-05-14 22:47:35 +08:00
|
|
|
if(WIN32)
|
2020-08-19 18:18:18 +08:00
|
|
|
target_link_libraries(ocloc_tests dbghelp)
|
2019-05-14 22:47:35 +08:00
|
|
|
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()
|
|
|
|
|
2020-02-07 21:06:50 +08:00
|
|
|
get_property(CLOC_LIB_FOLDER TARGET ocloc_lib PROPERTY FOLDER)
|
|
|
|
get_property(CLOC_LIB_COMPILE_FLAGS TARGET ocloc_lib PROPERTY COMPILE_FLAGS)
|
|
|
|
set_property(TARGET ocloc_tests PROPERTY FOLDER ${CLOC_LIB_FOLDER})
|
|
|
|
set_property(TARGET ocloc_tests APPEND_STRING PROPERTY COMPILE_FLAGS ${CLOC_LIB_COMPILE_FLAGS})
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2020-02-07 21:06:50 +08:00
|
|
|
string(TOLOWER ${DEFAULT_TESTED_PLATFORM} CLOC_LIB_DEFAULT_DEVICE)
|
2017-12-21 07:45:38 +08:00
|
|
|
|
2018-11-19 23:29:16 +08:00
|
|
|
add_custom_target(run_ocloc_tests ALL
|
2020-08-19 18:18:18 +08:00
|
|
|
DEPENDS ocloc_tests
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
2021-09-22 10:50:42 +08:00
|
|
|
if(NOT NEO_DISABLE_BUILTINS_COMPILATION)
|
|
|
|
add_dependencies(run_unit_tests run_ocloc_tests)
|
|
|
|
add_dependencies(unit_tests ocloc_tests)
|
|
|
|
endif()
|
2020-12-10 22:28:23 +08:00
|
|
|
|
2018-04-18 00:11:50 +08:00
|
|
|
macro(macro_for_each_platform)
|
2020-02-07 21:06:50 +08:00
|
|
|
if("${PLATFORM_IT_LOWER}" STREQUAL "${CLOC_LIB_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})
|
2020-11-18 21:54:34 +08:00
|
|
|
list(GET ${PLATFORM_TYPE}_${GEN_TYPE}_REVISIONS 0 REVISION_ID)
|
|
|
|
get_family_name_with_type(${GEN_TYPE} ${PLATFORM_TYPE})
|
|
|
|
add_dependencies(run_ocloc_tests prepare_test_kernels_${family_name_with_type}_${REVISION_ID})
|
2020-12-10 22:28:23 +08:00
|
|
|
add_dependencies(unit_tests prepare_test_kernels_${family_name_with_type}_${REVISION_ID})
|
2020-11-18 21:54:34 +08:00
|
|
|
neo_copy_test_files(copy_test_files_${family_name_with_type}_${REVISION_ID} ${family_name_with_type})
|
|
|
|
add_dependencies(run_ocloc_tests copy_test_files_${family_name_with_type}_${REVISION_ID})
|
2020-12-10 22:28:23 +08:00
|
|
|
add_dependencies(unit_tests copy_test_files_${family_name_with_type}_${REVISION_ID})
|
2020-11-18 21:54:34 +08:00
|
|
|
set(run_tests_cmd ocloc_tests --device ${CLOC_LIB_DEFAULT_DEVICE} --family_type ${family_name_with_type} --rev_id ${REVISION_ID})
|
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
|
|
|
|
2020-02-07 21:06:50 +08:00
|
|
|
set_property(TARGET run_ocloc_tests PROPERTY FOLDER ${CLOC_LIB_FOLDER})
|
2018-03-08 18:42:23 +08:00
|
|
|
|
|
|
|
if(WIN32)
|
2017-12-21 07:45:38 +08:00
|
|
|
add_custom_command(
|
2020-08-19 18:18:18 +08:00
|
|
|
TARGET run_ocloc_tests
|
|
|
|
POST_BUILD
|
|
|
|
COMMAND echo deleting offline compiler files and directories...
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_LIB_DEFAULT_DEVICE}/copybuffer_${CLOC_LIB_DEFAULT_DEVICE}.bc
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_LIB_DEFAULT_DEVICE}/copybuffer_${CLOC_LIB_DEFAULT_DEVICE}.gen
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_LIB_DEFAULT_DEVICE}/copybuffer_${CLOC_LIB_DEFAULT_DEVICE}.bin
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove_directory ${TargetDir}/${CLOC_LIB_DEFAULT_DEVICE}/offline_compiler_test
|
|
|
|
COMMAND ${run_tests_cmd}
|
|
|
|
WORKING_DIRECTORY ${TargetDir}
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
|
|
|
else()
|
|
|
|
add_custom_command(
|
2020-08-19 18:18:18 +08:00
|
|
|
TARGET run_ocloc_tests
|
|
|
|
POST_BUILD
|
|
|
|
COMMAND echo deleting offline compiler files and directories...
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_LIB_DEFAULT_DEVICE}/*.bc
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_LIB_DEFAULT_DEVICE}/*.gen
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_LIB_DEFAULT_DEVICE}/*.ll
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove ${TargetDir}/${CLOC_LIB_DEFAULT_DEVICE}/*.bin
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E remove_directory "${TargetDir}/offline_compiler_test"
|
|
|
|
COMMAND ${run_tests_cmd}
|
|
|
|
WORKING_DIRECTORY ${TargetDir}
|
2017-12-21 07:45:38 +08:00
|
|
|
)
|
|
|
|
endif()
|
2018-06-22 23:38:00 +08:00
|
|
|
|
|
|
|
add_subdirectories()
|
2019-10-09 20:24:46 +08:00
|
|
|
create_project_source_tree(ocloc_tests)
|