forked from machineware-gmbh/vcml
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFindSystemC.cmake
93 lines (82 loc) · 4.09 KB
/
FindSystemC.cmake
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
##############################################################################
# #
# Copyright 2018 Jan Henrik Weinstock #
# #
# Licensed under the Apache License, Version 2.0 (the "License"); #
# you may not use this file except in compliance with the License. #
# You may obtain a copy of the License at #
# #
# http://www.apache.org/licenses/LICENSE-2.0 #
# #
# Unless required by applicable law or agreed to in writing, software #
# distributed under the License is distributed on an "AS IS" BASIS, #
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. #
# See the License for the specific language governing permissions and #
# limitations under the License. #
# #
##############################################################################
if(NOT DEFINED SystemC_FIND_QUIET AND NOT DEFINED ENV{SYSTEMC_HOME})
message(WARNING "SYSTEMC_HOME not defined")
endif()
set(SYSTEMC_HOME $ENV{SYSTEMC_HOME})
find_path(SYSTEMC_INCLUDE_DIR NAMES systemc
HINTS ${SYSTEMC_HOME}/include)
if(DEFINED ENV{TARGET_ARCH})
set(SYSTEMC_TARGET_ARCH $ENV{TARGET_ARCH})
elseif(DEFINED TARGET_ARCH)
set(SYSTEMC_TARGET_ARCH ${TARGET_ARCH})
else()
if(CMAKE_SIZEOF_VOID_P EQUAL 8)
set(SYSTEMC_TARGET_ARCH "linux64")
else()
set(SYSTEMC_TARGET_ARCH "linux")
endif()
if (NOT DEFINED SystemC_FIND_QUIET)
message(WARNING "TARGET_ARCH not defined, guessing "
\"${SYSTEMC_TARGET_ARCH}\")
endif()
endif()
find_library(SYSTEMC_LIBRARY NAMES libsystemc.a systemc libSnpsVP.so
HINTS ${SYSTEMC_HOME}/lib-${SYSTEMC_TARGET_ARCH}
${SYSTEMC_HOME}/lib
${SYSTEMC_HOME}/libso-gcc-6.2.0-64
${SYSTEMC_HOME}/libso-gcc-5.2.0-64)
set(SYSTEMC_VERSION "")
set(SYSTEMC_LIBRARIES ${SYSTEMC_LIBRARY})
set(SYSTEMC_INCLUDE_DIRS ${SYSTEMC_INCLUDE_DIR})
if(EXISTS ${SYSTEMC_INCLUDE_DIR}/tlm/)
list(APPEND SYSTEMC_INCLUDE_DIRS ${SYSTEMC_INCLUDE_DIR}/tlm)
endif()
set(_sysc_ver_file "${SYSTEMC_INCLUDE_DIR}/sysc/kernel/sc_ver.h")
if(EXISTS ${_sysc_ver_file})
file(STRINGS ${_sysc_ver_file} _systemc_ver REGEX
"^#[\t ]*define[\t ]+SC_VERSION_(MAJOR|MINOR|PATCH)[\t ]+([0-9]+)$")
foreach(VPART MAJOR MINOR PATCH)
foreach(VLINE ${_systemc_ver})
if(VLINE MATCHES
"^#[\t ]*define[\t ]+SC_VERSION_${VPART}[\t ]+([0-9]+)$")
set(SYSTEMC_VERSION_${VPART} ${CMAKE_MATCH_1})
if(SYSTEMC_VERSION)
string(APPEND SYSTEMC_VERSION .${CMAKE_MATCH_1})
else()
set(SYSTEMC_VERSION ${CMAKE_MATCH_1})
endif()
endif()
endforeach()
endforeach()
endif()
include(FindPackageHandleStandardArgs)
FIND_PACKAGE_HANDLE_STANDARD_ARGS(SystemC
REQUIRED_VARS SYSTEMC_LIBRARY SYSTEMC_INCLUDE_DIR
VERSION_VAR SYSTEMC_VERSION)
mark_as_advanced(SYSTEMC_INCLUDE_DIR SYSTEMC_LIBRARY)
#message(STATUS "SYSTEMC_FOUND " ${SYSTEMC_FOUND})
#message(STATUS "SYSTEMC_HOME " ${SYSTEMC_HOME})
#message(STATUS "SYSTEMC_TARGET_ARCH " ${SYSTEMC_TARGET_ARCH})
#message(STATUS "SYSTEMC_INCLUDE_DIRS " ${SYSTEMC_INCLUDE_DIRS})
#message(STATUS "SYSTEMC_LIBRARY " ${SYSTEMC_LIBRARY})
#message(STATUS "SYSTEMC_LIBRARIES " ${SYSTEMC_LIBRARIES})
#message(STATUS "SYSTEMC_VERSION_MAJOR " ${SYSTEMC_VERSION_MAJOR})
#message(STATUS "SYSTEMC_VERSION_MINOR " ${SYSTEMC_VERSION_MINOR})
#message(STATUS "SYSTEMC_VERSION_PATCH " ${SYSTEMC_VERSION_PATCH})
#message(STATUS "SYSTEMC_VERSION " ${SYSTEMC_VERSION})