-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathCMakeLists.txt
111 lines (95 loc) · 3.56 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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
# Copyright (C) 2014, GreenSocs ltd.
#
# CMakeLists.txt
#
# KONRAD Frederic <[email protected]>
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or (at
# your option) any later version.
#
# This program is distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, see <http://www.gnu.org/licenses>.
#
# Linking GreenSocs code, statically or dynamically with other modules
# is making a combined work based on GreenSocs code. Thus, the terms and
# conditions of the GNU General Public License cover the whole
# combination.
#
# In addition, as a special exception, the copyright holders, GreenSocs
# Ltd, give you permission to combine GreenSocs code with free software
# programs or libraries that are released under the GNU LGPL, under the
# OSCI license, under the OCP TLM Kit Research License Agreement or
# under the OVP evaluation license.You may copy and distribute such a
# system following the terms of the GNU GPL and the licenses of the
# other code concerned.
#
# Note that people who make modified versions of GreenSocs code are not
# obligated to grant this special exception for their modified versions;
# it is their choice whether to do so. The GNU General Public License
# gives permission to release a modified version without this exception;
# this exception also makes it possible to release a modified version
# which carries forward this exception.
CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
PROJECT(SIMPLECPU)
LIST(APPEND CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake)
FIND_PACKAGE(SystemC)
if(SystemC_FOUND)
INCLUDE_DIRECTORIES(${SystemC_INCLUDE_DIRS})
LINK_DIRECTORIES(${SystemC_LIBRARY_DIRS})
else()
MESSAGE(FATAL_ERROR "SystemC library not found.")
endif()
FIND_PACKAGE(TLM)
if(TLM_FOUND)
INCLUDE_DIRECTORIES(${TLM_INCLUDE_DIRS})
else()
MESSAGE( FATAL_ERROR "TLM library not found." )
endif()
FIND_PACKAGE(GREENLIB)
if(GREENLIB_FOUND)
INCLUDE_DIRECTORIES(${GREENLIB_INCLUDE_DIRS})
LINK_DIRECTORIES(${GREENLIB_LIBRARY_DIRS})
else()
MESSAGE(FATAL_ERROR "GreenLib not found.")
endif()
FIND_PACKAGE(TLM2C)
if(TLM2C_FOUND)
INCLUDE_DIRECTORIES(${TLM2C_INCLUDE_DIRS})
LINK_DIRECTORIES(${TLM2C_LIBRARY_DIRS})
else()
MESSAGE(FATAL_ERROR "TLM2C not found.")
endif()
set (INCLUDE_DIRS ${INCLUDE_DIRS} include)
INCLUDE_DIRECTORIES(${INCLUDE_DIRS})
set(CMAKE_CXX_FLAGS "-Wall -Werror -DSC_INCLUDE_DYNAMIC_PROCESSES")
if(MINGW)
add_library(simplecpu STATIC src/simpleCPU.cpp
src/tlm2CSCBridge.cpp
src/thread_safe_event.cpp)
else()
add_library(simplecpu SHARED src/simpleCPU.cpp
src/tlm2CSCBridge.cpp
src/thread_safe_event.cpp)
endif()
set(SIMPLECPU_LINK_LIBRARIES pthread
tlm2c)
if(NOT MINGW)
list(APPEND SIMPLECPU_LINK_LIBRARIES dl)
endif()
target_link_libraries(simplecpu ${SIMPLECPU_LINK_LIBRARIES})
# Installation paths
INSTALL(DIRECTORY include/SimpleCPU
DESTINATION include
)
# Not sure it's the right destination? Maybe we want lib64 in case of 64bits?
INSTALL(TARGETS simplecpu DESTINATION lib)
# Make tests
ENABLE_TESTING()
ADD_SUBDIRECTORY(test)