Clean up and refactor CMakeLists
This commit is contained in:
138
CMakeLists.txt
138
CMakeLists.txt
@@ -31,6 +31,7 @@
|
|||||||
# Authors:
|
# Authors:
|
||||||
# Thomas Psota
|
# Thomas Psota
|
||||||
# Lukas Steiner
|
# Lukas Steiner
|
||||||
|
# Derek Christ
|
||||||
|
|
||||||
###############################################
|
###############################################
|
||||||
### DRAMSys ###
|
### DRAMSys ###
|
||||||
@@ -39,126 +40,74 @@ cmake_minimum_required(VERSION 3.21)
|
|||||||
|
|
||||||
set(PROJECT_NAME "DRAMSys")
|
set(PROJECT_NAME "DRAMSys")
|
||||||
|
|
||||||
project(${PROJECT_NAME} VERSION "5.0")
|
project(${PROJECT_NAME} VERSION 5.0)
|
||||||
|
|
||||||
### Compiler settings ###
|
|
||||||
set(CMAKE_CXX_STANDARD 17 CACHE STRING "C++ Standard")
|
|
||||||
message(STATUS "CMAKE_CXX_STANDARD: ${CMAKE_CXX_STANDARD}")
|
|
||||||
if(NOT CMAKE_BUILD_TYPE)
|
|
||||||
set(CMAKE_BUILD_TYPE Release)
|
|
||||||
endif()
|
|
||||||
message(STATUS "CMAKE_BUILD_TYPE: ${CMAKE_BUILD_TYPE}")
|
|
||||||
|
|
||||||
### CMake settings ###
|
|
||||||
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_LIST_DIR}/cmake")
|
|
||||||
include(diagnostics_print)
|
|
||||||
include(enable_extensions)
|
|
||||||
include(FetchContent)
|
|
||||||
|
|
||||||
if(ENABLE_COVERAGE)
|
|
||||||
include(coverage)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
if(POLICY CMP0135)
|
if(POLICY CMP0135)
|
||||||
cmake_policy(SET CMP0135 NEW)
|
cmake_policy(SET CMP0135 NEW)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Check if standalone build or being included as submodule
|
list(APPEND CMAKE_MODULE_PATH "${CMAKE_CURRENT_LIST_DIR}/cmake")
|
||||||
get_directory_property(DRAMSYS_IS_SUBMODULE PARENT_DIRECTORY)
|
include(FetchContent)
|
||||||
|
include(enable_extensions)
|
||||||
|
|
||||||
set_property(GLOBAL PROPERTY USE_FOLDERS ON)
|
if(DRAMSYS_ENABLE_COVERAGE)
|
||||||
set(CMAKE_EXPORT_COMPILE_COMMANDS ON)
|
include(coverage)
|
||||||
|
|
||||||
### Project settings ###
|
|
||||||
message(STATUS "CMAKE_SOURCE_DIR: ${CMAKE_SOURCE_DIR}")
|
|
||||||
message(STATUS "CMAKE_BINARY_DIR: ${CMAKE_BINARY_DIR}")
|
|
||||||
message(STATUS "" )
|
|
||||||
|
|
||||||
if(NOT DRAMSYS_IS_SUBMODULE)
|
|
||||||
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
|
|
||||||
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
|
|
||||||
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
### DRAMSys directories ###
|
### Project settings ###
|
||||||
set(DRAMSYS_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/src")
|
|
||||||
set(DRAMSYS_LIBRARY_DIR "${CMAKE_CURRENT_SOURCE_DIR}/lib")
|
|
||||||
set(DRAMSYS_TESTS_DIR "${CMAKE_CURRENT_SOURCE_DIR}/tests")
|
|
||||||
set(DRAMSYS_RESOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/configs")
|
|
||||||
set(DRAMSYS_EXTENSIONS_DIR "${CMAKE_CURRENT_SOURCE_DIR}/extensions")
|
|
||||||
|
|
||||||
### Build options ###
|
|
||||||
option(BUILD_SHARED_LIBS "Build shared libraries" OFF)
|
|
||||||
|
|
||||||
option(DRAMSYS_VERBOSE_CMAKE_OUTPUT "Show detailed CMake output" OFF)
|
|
||||||
option(DRAMSYS_BUILD_TESTS "Build DRAMSys unit tests" OFF)
|
option(DRAMSYS_BUILD_TESTS "Build DRAMSys unit tests" OFF)
|
||||||
option(DRAMSYS_BUILD_BENCHMARKS "Build DRAMSys benchmarks" OFF)
|
option(DRAMSYS_BUILD_BENCHMARKS "Build DRAMSys benchmarks" OFF)
|
||||||
option(DRAMSYS_BUILD_CLI "Build DRAMSys Command Line Tool" ON)
|
option(DRAMSYS_BUILD_CLI "Build DRAMSys Command Line Tool" ON)
|
||||||
option(DRAMSYS_BUILD_TRACE_ANALYZER "Build DRAMSys Trace Analyzer" OFF)
|
option(DRAMSYS_BUILD_TRACE_ANALYZER "Build DRAMSys Trace Analyzer" OFF)
|
||||||
option(DRAMSYS_WITH_DRAMPOWER "Build with DRAMPower support enabled." OFF)
|
option(DRAMSYS_WITH_DRAMPOWER "Build with DRAMPower support enabled." ON)
|
||||||
option(DRAMSYS_USE_EXTERNAL_SYSTEMC "Use an external SystemC installation." OFF)
|
|
||||||
|
# TODO: Remove as soon as DRAMPower is updated
|
||||||
|
set(DRAMSYS_SHARED_LIBS OFF)
|
||||||
|
|
||||||
|
if(DEFINED DRAMSYS_SHARED_LIBS)
|
||||||
|
set(BUILD_SHARED_LIBS ${DRAMSYS_SHARED_LIBS})
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if (PROJECT_IS_TOP_LEVEL)
|
||||||
|
set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
|
||||||
|
set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
|
||||||
|
set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/lib)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
### DRAMSys directories ###
|
||||||
|
set(DRAMSYS_SOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/src")
|
||||||
|
set(DRAMSYS_LIBRARY_DIR "${CMAKE_CURRENT_SOURCE_DIR}/lib")
|
||||||
|
set(DRAMSYS_TESTS_DIR "${CMAKE_CURRENT_SOURCE_DIR}/tests")
|
||||||
|
set(DRAMSYS_RESOURCE_DIR "${CMAKE_CURRENT_SOURCE_DIR}/configs")
|
||||||
|
set(DRAMSYS_EXTENSIONS_DIR "${CMAKE_CURRENT_SOURCE_DIR}/extensions")
|
||||||
|
|
||||||
###############################################
|
###############################################
|
||||||
### Library Settings ###
|
### Library Settings ###
|
||||||
###############################################
|
###############################################
|
||||||
|
|
||||||
### Detect OS threading library ###
|
|
||||||
find_package(Threads)
|
|
||||||
|
|
||||||
### nlohmann_json ###
|
### nlohmann_json ###
|
||||||
FetchContent_Declare(nlohmann_json URL https://github.com/nlohmann/json/releases/download/v3.11.3/json.tar.xz)
|
add_subdirectory(${DRAMSYS_LIBRARY_DIR})
|
||||||
FetchContent_MakeAvailable(nlohmann_json)
|
|
||||||
|
|
||||||
### sqlite3 ###
|
if (NOT TARGET nlohmann_json::nlohmann_json)
|
||||||
add_subdirectory(${DRAMSYS_LIBRARY_DIR}/sqlite3)
|
FetchContent_Declare(nlohmann_json URL https://github.com/nlohmann/json/releases/download/v3.11.3/json.tar.xz)
|
||||||
|
FetchContent_MakeAvailable(nlohmann_json)
|
||||||
### GoogleTest ###
|
endif ()
|
||||||
if(DRAMSYS_BUILD_TESTS)
|
|
||||||
FetchContent_Declare(
|
|
||||||
googletest
|
|
||||||
GIT_REPOSITORY https://github.com/google/googletest
|
|
||||||
GIT_TAG release-1.12.1)
|
|
||||||
|
|
||||||
# For Windows: Prevent overriding the parent project's compiler/linker settings
|
|
||||||
set(gtest_force_shared_crt ON CACHE BOOL "" FORCE)
|
|
||||||
FetchContent_MakeAvailable(googletest)
|
|
||||||
set_target_properties(gmock PROPERTIES FOLDER lib/gtest)
|
|
||||||
set_target_properties(gmock_main PROPERTIES FOLDER lib/gtest)
|
|
||||||
set_target_properties(gtest PROPERTIES FOLDER lib/gtest)
|
|
||||||
set_target_properties(gtest_main PROPERTIES FOLDER lib/gtest)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
### GoogleBenchmark ###
|
|
||||||
if(DRAMSYS_BUILD_BENCHMARKS)
|
|
||||||
set(BENCHMARK_ENABLE_TESTING OFF)
|
|
||||||
|
|
||||||
FetchContent_Declare(
|
|
||||||
benchmark
|
|
||||||
URL https://github.com/google/benchmark/archive/refs/tags/v1.8.3.zip
|
|
||||||
)
|
|
||||||
|
|
||||||
FetchContent_MakeAvailable(benchmark)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
### SystemC ###
|
### SystemC ###
|
||||||
if (DRAMSYS_USE_EXTERNAL_SYSTEMC)
|
if (NOT TARGET SystemC::systemc) # TODO ist das wirklich so korrekt?
|
||||||
list(APPEND CMAKE_PREFIX_PATH $ENV{SYSTEMC_HOME} /opt/systemc)
|
set(DISABLE_COPYRIGHT_MESSAGE True)
|
||||||
find_package(systemc NAMES SystemCLanguage)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
FetchContent_Declare(
|
FetchContent_Declare(
|
||||||
systemc
|
systemc
|
||||||
GIT_REPOSITORY https://github.com/accellera-official/systemc.git
|
GIT_REPOSITORY https://github.com/accellera-official/systemc.git
|
||||||
GIT_TAG 2.3.4)
|
GIT_TAG 2.3.4)
|
||||||
|
|
||||||
set(DISABLE_COPYRIGHT_MESSAGE True)
|
|
||||||
|
|
||||||
# Allow populating of a user-set SystemC package
|
|
||||||
if (NOT TARGET SystemC::systemc)
|
|
||||||
FetchContent_MakeAvailable(systemc)
|
FetchContent_MakeAvailable(systemc)
|
||||||
|
|
||||||
# Set include directories to SYSTEM to suppress warnings
|
# Set include directories to SYSTEM to suppress warnings
|
||||||
set_target_properties(systemc PROPERTIES SYSTEM TRUE)
|
set_target_properties(systemc PROPERTIES SYSTEM TRUE)
|
||||||
|
else()
|
||||||
|
find_package(systemc NAMES SystemCLanguage)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|
||||||
@@ -195,8 +144,7 @@ dramsys_enable_extensions()
|
|||||||
###############################################
|
###############################################
|
||||||
|
|
||||||
if(DRAMSYS_BUILD_TESTS)
|
if(DRAMSYS_BUILD_TESTS)
|
||||||
include(GoogleTest)
|
enable_testing()
|
||||||
include(CTest)
|
|
||||||
add_subdirectory(tests)
|
add_subdirectory(tests)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
|||||||
@@ -52,7 +52,7 @@
|
|||||||
"binaryDir": "${sourceDir}/build/coverage",
|
"binaryDir": "${sourceDir}/build/coverage",
|
||||||
"inherits": "ci-common",
|
"inherits": "ci-common",
|
||||||
"cacheVariables": {
|
"cacheVariables": {
|
||||||
"ENABLE_COVERAGE": "ON",
|
"DRAMSYS_ENABLE_COVERAGE": "ON",
|
||||||
"CMAKE_BUILD_TYPE": "Coverage",
|
"CMAKE_BUILD_TYPE": "Coverage",
|
||||||
"CMAKE_CXX_FLAGS_COVERAGE": "-Og -g --coverage -fkeep-static-functions",
|
"CMAKE_CXX_FLAGS_COVERAGE": "-Og -g --coverage -fkeep-static-functions",
|
||||||
"CMAKE_EXE_LINKER_FLAGS_COVERAGE": "--coverage",
|
"CMAKE_EXE_LINKER_FLAGS_COVERAGE": "--coverage",
|
||||||
|
|||||||
@@ -37,6 +37,15 @@
|
|||||||
|
|
||||||
project(benches_dramsys)
|
project(benches_dramsys)
|
||||||
|
|
||||||
|
set(BENCHMARK_ENABLE_TESTING OFF)
|
||||||
|
|
||||||
|
FetchContent_Declare(
|
||||||
|
benchmark
|
||||||
|
URL https://github.com/google/benchmark/archive/refs/tags/v1.8.3.zip
|
||||||
|
)
|
||||||
|
|
||||||
|
FetchContent_MakeAvailable(benchmark)
|
||||||
|
|
||||||
add_executable(${PROJECT_NAME}
|
add_executable(${PROJECT_NAME}
|
||||||
main.cpp
|
main.cpp
|
||||||
simulation.cpp
|
simulation.cpp
|
||||||
@@ -52,5 +61,3 @@ target_link_libraries(${PROJECT_NAME}
|
|||||||
SystemC::systemc
|
SystemC::systemc
|
||||||
benchmark
|
benchmark
|
||||||
)
|
)
|
||||||
|
|
||||||
build_source_group()
|
|
||||||
|
|||||||
@@ -1,32 +0,0 @@
|
|||||||
###############################################
|
|
||||||
### diagnostics_print ###
|
|
||||||
###############################################
|
|
||||||
###
|
|
||||||
### Prints different diagnostics and infos
|
|
||||||
### about the specified target
|
|
||||||
###
|
|
||||||
|
|
||||||
function( diagnostics_print target_name )
|
|
||||||
message(STATUS "${target_name} settings:")
|
|
||||||
message(STATUS "==============\n")
|
|
||||||
|
|
||||||
message(STATUS "Source Files:")
|
|
||||||
get_target_property(SOURCE_FILES ${target_name} SOURCES)
|
|
||||||
if(SOURCE_FILES)
|
|
||||||
message(STATUS "${SOURCE_FILES}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
message(STATUS "\nInclude Directories:")
|
|
||||||
get_target_property(HEADER_DIR ${target_name} INCLUDE_DIRECTORIES)
|
|
||||||
if(HEADER_DIR)
|
|
||||||
message(STATUS "${HEADER_DIR}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
message(STATUS "\nLink Libraries:")
|
|
||||||
get_target_property(LINKED_LIBS ${target_name} LINK_LIBRARIES)
|
|
||||||
if(LINKED_LIBS)
|
|
||||||
message(STATUS "${LINKED_LIBS}")
|
|
||||||
endif()
|
|
||||||
|
|
||||||
message(STATUS "\n")
|
|
||||||
endfunction()
|
|
||||||
1
lib/CMakeLists.txt
Normal file
1
lib/CMakeLists.txt
Normal file
@@ -0,0 +1 @@
|
|||||||
|
add_subdirectory(sqlite3)
|
||||||
@@ -105,6 +105,8 @@ target_link_libraries(${PROJECT_NAME}
|
|||||||
SQLite::SQLite3
|
SQLite::SQLite3
|
||||||
)
|
)
|
||||||
|
|
||||||
|
target_compile_features(${PROJECT_NAME} PUBLIC cxx_std_17)
|
||||||
|
|
||||||
if (DRAMSYS_WITH_DRAMPOWER)
|
if (DRAMSYS_WITH_DRAMPOWER)
|
||||||
target_link_libraries(${PROJECT_NAME} PUBLIC DRAMPower)
|
target_link_libraries(${PROJECT_NAME} PUBLIC DRAMPower)
|
||||||
target_compile_definitions(${PROJECT_NAME} PUBLIC DRAMPOWER)
|
target_compile_definitions(${PROJECT_NAME} PUBLIC DRAMPOWER)
|
||||||
|
|||||||
@@ -40,6 +40,8 @@
|
|||||||
|
|
||||||
project(DRAMSys_Simulator)
|
project(DRAMSys_Simulator)
|
||||||
|
|
||||||
|
find_package(Threads)
|
||||||
|
|
||||||
add_library(${PROJECT_NAME}
|
add_library(${PROJECT_NAME}
|
||||||
simulator/Cache.cpp
|
simulator/Cache.cpp
|
||||||
simulator/EccModule.cpp
|
simulator/EccModule.cpp
|
||||||
|
|||||||
@@ -1,5 +1,14 @@
|
|||||||
|
include(GoogleTest)
|
||||||
|
|
||||||
set(DRAMSYS_TEST_RESOURCES_DIR "${CMAKE_CURRENT_SOURCE_DIR}/resources")
|
set(DRAMSYS_TEST_RESOURCES_DIR "${CMAKE_CURRENT_SOURCE_DIR}/resources")
|
||||||
|
|
||||||
|
FetchContent_Declare(
|
||||||
|
googletest
|
||||||
|
GIT_REPOSITORY https://github.com/google/googletest
|
||||||
|
GIT_TAG release-1.12.1)
|
||||||
|
|
||||||
|
FetchContent_MakeAvailable(googletest)
|
||||||
|
|
||||||
add_subdirectory(tests_configuration)
|
add_subdirectory(tests_configuration)
|
||||||
add_subdirectory(tests_dramsys)
|
add_subdirectory(tests_dramsys)
|
||||||
add_subdirectory(tests_regression)
|
add_subdirectory(tests_regression)
|
||||||
|
|||||||
Reference in New Issue
Block a user