-
Notifications
You must be signed in to change notification settings - Fork 62
/
Copy pathCMakeLists.txt
54 lines (42 loc) · 1.65 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
project(main)
INCLUDE("${esesc_SOURCE_DIR}/CMake.common")
INCLUDE_DIRECTORIES(${suc_SOURCE_DIR})
INCLUDE_DIRECTORIES(${emulint_SOURCE_DIR})
INCLUDE_DIRECTORIES(${core_SOURCE_DIR})
INCLUDE_DIRECTORIES(${mem_SOURCE_DIR})
INCLUDE_DIRECTORIES(${net_SOURCE_DIR})
INCLUDE_DIRECTORIES(${rst_SOURCE_DIR})
INCLUDE_DIRECTORIES(${mcpat_SOURCE_DIR})
INCLUDE_DIRECTORIES(${peq_SOURCE_DIR})
INCLUDE_DIRECTORIES(${pwrmodel_SOURCE_DIR})
INCLUDE_DIRECTORIES(${sesctherm_SOURCE_DIR})
INCLUDE_DIRECTORIES(${sampler_SOURCE_DIR})
INCLUDE_DIRECTORIES(${qemuint_SOURCE_DIR})
INCLUDE_DIRECTORIES(${gpuint_SOURCE_DIR})
INCLUDE_DIRECTORIES(${scqemu_SOURCE_DIR})
INCLUDE_DIRECTORIES(${migdb_SOURCE_DIR})
FILE(GLOB main_SOURCE *.cpp)
FILE(GLOB main_HEADER *.h)
SOURCE_GROUP("Source Files" FILES ${main_SOURCE})
SOURCE_GROUP("Header Files" FILES ${main_HEADER})
##########################
# esesc and mainbench
SET(EXELIST "esesc" "lsqtest" "qemumain" "qemumin" "membench" "netBench" "cachebench")
FOREACH(EXE ${EXELIST})
FILE(GLOB exec_SOURCE "${EXE}.cpp")
IF(EXE MATCHES "esesc")
ADD_EXECUTABLE(${EXE} ${exec_SOURCE})
ELSE(EXE MATCHES "esesc")
ADD_EXECUTABLE(${EXE} EXCLUDE_FROM_ALL ${exec_SOURCE})
ENDIF(EXE MATCHES "esesc")
LIST(REMOVE_ITEM main_SOURCE ${exec_SOURCE})
ENDFOREACH(EXE)
###############################
ADD_LIBRARY(main ${main_SOURCE} ${main_HEADER})
FOREACH(EXE ${EXELIST})
add_dependencies(${EXE} qemu)
TARGET_LINK_LIBRARIES(${EXE} ${CMAKE_QEMU_OBJS})
TARGET_LINK_LIBRARIES(${EXE} main sampler mem net core pwrmodel mcpat sesctherm peq)
TARGET_LINK_LIBRARIES(${EXE} qemuint emulint suc)
TARGET_LINK_LIBRARIES(${EXE} ${CMAKE_QEMU_LIBS})
ENDFOREACH(EXE)