forked from etri/nest-compiler
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCMakeLists.txt
73 lines (56 loc) · 2.5 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
cmake_minimum_required(VERSION 3.5)
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/cmake/modules")
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/glow/cmake/modules")
project(NESTC C CXX)
option(NESTC_WITH_EVTA "Build the VTA backend" OFF)
option(NESTC_USE_VTASIM "Build the VTASIM" ON)
option(NESTC_VTA_RUN_ON_AARCH64 "Run VTA on AArch64" OFF)
include(CTest)
include(NESTCTestSupport)
set(CMAKE_CXX_STANDARD 14)
set(CXX_STANDARD_REQUIRED ON)
set(CMAKE_CXX_EXTENSIONS OFF)
set(CMAKE_POSITION_INDEPENDENT_CODE ON)
set(NESTC_ROOT_DIR ${CMAKE_CURRENT_SOURCE_DIR})
set(NESTC_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR})
if(EXISTS ${NESTC_ROOT_DIR}/glow/tools/loader/Loader.h)
message(STATUS "Delete ${NESTC_ROOT_DIR}/glow/tools/loader/Loader.h")
execute_process(COMMAND ${CMAKE_COMMAND} -E remove -f ${NESTC_ROOT_DIR}/glow/tools/loader/Loader.h)
endif()
if(EXISTS ${NESTC_ROOT_DIR}/glow/tools/ClassGen/NodeBuilder.h)
message(STATUS "Delete ${NESTC_ROOT_DIR}/glow/tools/ClassGen/NodeBuilder.h")
execute_process(COMMAND ${CMAKE_COMMAND} -E remove -f ${NESTC_ROOT_DIR}/glow/tools/ClassGen/NodeBuilder.h)
endif()
if(EXISTS ${NESTC_ROOT_DIR}/glow/tools/ClassGen/MemberType.h)
message(STATUS "Delete ${NESTC_ROOT_DIR}/glow/tools/ClassGen/MemberType.h")
execute_process(COMMAND ${CMAKE_COMMAND} -E remove -f ${NESTC_ROOT_DIR}/glow/tools/ClassGen/MemberType.h)
endif()
execute_process(COMMAND ${CMAKE_COMMAND} -E copy_directory ${NESTC_ROOT_DIR}/cmake/glow ${NESTC_ROOT_DIR}/glow)
if (NESTC_WITH_EVTA)
add_definitions(-DNESTC_WITH_VTAINTERPRETER=1)
set(NESTC_WITH_VTA ON)
else()
option(NESTC_WITH_VTAINTERPRETER "Build the VTAInterpreter backend" OFF)
set(NESTC_WITH_VTA OFF)
endif()
if (NESTC_WITH_EVTA)
message("NESTC WITH EVTA in graph cmake")
add_definitions(-DGLOW_WITH_VTA)
endif()
include_directories(BEFORE
${NESTC_ROOT_DIR}/
${NESTC_ROOT_DIR}/include
${NESTC_ROOT_DIR}/include/tools/loader
${NESTC_ROOT_DIR}/tools/ClassGen/
)
message(STATUS "START CMAKE TVM")
SET(USE_LLVM ON)
add_subdirectory(tvm)
message(STATUS "START CMAKE GLOW")
add_subdirectory(glow)
get_property(NESTC_TEST_DEPENDS GLOBAL PROPERTY NESTC_TEST_DEPENDS)
get_property(ZCU102_TEST_DEPENDS GLOBAL PROPERTY ZCU102_TEST_DEPENDS)
add_custom_target(check_nestc COMMAND ${CMAKE_CTEST_COMMAND} -L NESTC
DEPENDS ${NESTC_TEST_DEPENDS} USES_TERMINAL)
add_custom_target(check_zcu102 COMMAND ${CMAKE_CTEST_COMMAND} -L ZCU102
DEPENDS ${ZCU102_TEST_DEPENDS} USES_TERMINAL)