-
Notifications
You must be signed in to change notification settings - Fork 22
/
CMakeLists.txt
140 lines (118 loc) · 4.61 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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
# RevCPU Top-Level CMake
# Copyright (C) 2017-2023 Tactical Computing Laboratories, LLC
# All Rights Reserved
# See LICENSE in the top level directory for licensing details
# Prevent in-source builds
if(${CMAKE_SOURCE_DIR} STREQUAL ${CMAKE_BINARY_DIR})
message(FATAL_ERROR "DO NOT BUILD in-tree.")
endif()
# Minimum required version of CMake and project information
cmake_minimum_required(VERSION 3.19)
project(revcpu CXX)
# Options for enabling tests
option(CTEST_BLAS_REQUIRED_TESTS "Enable tests which require BLAS headers" OFF)
option(CTEST_MULTILIB_TESTS "Enable 32-bit tests" ON)
# SST Setup
# TODO: Update when SST supports coherent CMake support
execute_process(COMMAND sst-config --prefix
OUTPUT_VARIABLE SST_INSTALL_DIR
OUTPUT_STRIP_TRAILING_WHITESPACE
)
set(SST_INCLUDE_DIR "${SST_INSTALL_DIR}/include")
if(NOT (EXISTS "${SST_INSTALL_DIR}"))
message(FATAL_ERROR " SST_INSTALL_DIR (${SST_INSTALL_DIR}) is invalid.")
endif()
include_directories(SST_SRC ${SST_INSTALL_DIR})
# SST Configuration Sanity Check
find_program(SST sst)
find_program(SST_CONFIG sst-config)
if(NOT SST OR NOT SST_CONFIG)
message(FATAL_ERROR "No SST binary or sst-config binary found in path")
endif()
# SST Environment Derivation
execute_process(COMMAND sst-config --CXX
OUTPUT_VARIABLE CXX
OUTPUT_STRIP_TRAILING_WHITESPACE
)
execute_process(COMMAND sst-config --ELEMENT_CXXFLAGS
OUTPUT_VARIABLE SST_CXXFLAGS
OUTPUT_STRIP_TRAILING_WHITESPACE
)
set(CXXFLAGS "${SST_CXXFLAGS} -fno-stack-protector")
execute_process(COMMAND sst-config --ELEMENT_LDFLAGS
OUTPUT_VARIABLE SST_LDFLAGS
OUTPUT_STRIP_TRAILING_WHITESPACE
)
set(LDFLAGS "${SST_LDFLAGS} -fno-stack-protector")
# Tracer Configuration
option(REV_TRACER "Enable tracer compilation" ON)
message (REV_TRACER="${REV_TRACER}")
if(REV_TRACER)
option(REV_USE_SPIKE "Link to spike disasm static library" OFF)
if(REV_USE_SPIKE)
find_program(SPIKE spike)
cmake_path(GET SPIKE PARENT_PATH spike_dir)
find_library(DISASM_LIB disasm HINT "${spike_dir}/../lib")
include_directories("${spike_dir}/../include")
link_directories("${spike_dir}/../lib")
link_libraries("disasm")
add_compile_definitions("REV_USE_SPIKE")
endif()
else()
# requires cmake 3.12
add_compile_definitions(NO_REV_TRACER)
endif()
# Compiler Options
if ("${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang")
set(WERROR_FLAG "")
set(FP_MODE_FLAG "-ffp-model=strict")
else()
set(WERROR_FLAG "-Werror")
set(FP_MODE_FLAG "-frounding-math")
endif()
set(CMAKE_CXX_FLAGS "-std=c++17 ${FP_MODE_FLAG} -O2 -Wall -Wextra ${WERROR_FLAG} -Wvla -Wuninitialized -Wfloat-conversion -Wdouble-promotion -Wno-unused-parameter -Wno-deprecated-declarations ${CMAKE_CXX_FLAGS} -I./ ${LDFLAGS} ${REVCPU_COMPILER_MACROS}")
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} -O0 -Wall ${REVCPU_COMPILER_MACROS}")
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} -O3 -Wall ${REVCPU_COMPILER_MACROS}")
# Find SST packages
find_package(SST REQUIRED CONFIG)
message(STATUS "Found SST execute_process(COMMAND sst --version)")
include_directories(${SST_INCLUDE_DIRS})
add_definitions(${SST_DEFINITIONS})
# Find Doxygen packages
option(BUILD_DOCUMENTATION "Create and install the doxygen-ized API documentation (requires Doxygen)" ${DOXYGEN_FOUND})
if(BUILD_DOCUMENTATION)
find_package(Doxygen)
if(NOT DOXYGEN_FOUND)
message(FATAL_ERROR "Doxygen is required to build the documentation.")
endif()
set(doxyfile ${CMAKE_CURRENT_SOURCE_DIR}/doxygen/RevCPU.conf)
add_custom_target(doc
COMMAND ${DOXYGEN_EXECUTABLE} ${doxyfile}
COMMAND ${BASH_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/scripts/cleanmanpages.sh ${CMAKE_CURRENT_SOURCE_DIR}/doxygen/man/man3
WORKING_DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}
COMMENT "Generating API documentation with Doxygen"
VERBATIM)
install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/doxygen/html DESTINATION share/doc)
endif()
# Testing
option(REV_ENABLE_TESTING "Enable Testing" ON)
if(REV_ENABLE_TESTING)
enable_testing()
endif()
# RevCPU Paths
set(REVCPU_INCLUDE_PATH "${CMAKE_CURRENT_SOURCE_DIR}/include" CACHE PATH "RevCPU include path")
set(INSTRUCTIONS_PATH "${CMAKE_CURRENT_SOURCE_DIR}/include/insns" CACHE PATH "Instructions path")
# Include Directories
include_directories(
${REVCPU_INCLUDE_PATH}
${CMAKE_SOURCE_DIR}/common/include
${SST_INCLUDE_DIRS}
)
# Subdirectories
add_subdirectory(src)
add_subdirectory(common)
add_subdirectory(test)
# Custom Commands
add_custom_target(uninstall COMMAND "${CMAKE_CURRENT_SOURCE_DIR}/scripts/uninstall.sh")
# EOF