Clean up and refactor CMakeLists

This commit is contained in:
2024-11-11 17:00:25 +01:00
parent 91a09ad771
commit e1b8bbf12d
8 changed files with 67 additions and 130 deletions

View File

@@ -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()

View File

@@ -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",

View File

@@ -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()

View File

@@ -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
View File

@@ -0,0 +1 @@
add_subdirectory(sqlite3)

View File

@@ -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)

View File

@@ -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

View File

@@ -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)