72 lines
2.6 KiB
CMake
72 lines
2.6 KiB
CMake
# Copyright (c) 2020, Technische Universität Kaiserslautern
|
|
# All rights reserved.
|
|
#
|
|
# Redistribution and use in source and binary forms, with or without
|
|
# modification, are permitted provided that the following conditions are
|
|
# met:
|
|
#
|
|
# 1. Redistributions of source code must retain the above copyright notice,
|
|
# this list of conditions and the following disclaimer.
|
|
#
|
|
# 2. Redistributions in binary form must reproduce the above copyright
|
|
# notice, this list of conditions and the following disclaimer in the
|
|
# documentation and/or other materials provided with the distribution.
|
|
#
|
|
# 3. Neither the name of the copyright holder nor the names of its
|
|
# contributors may be used to endorse or promote products derived from
|
|
# this software without specific prior written permission.
|
|
#
|
|
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
|
|
# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
|
|
# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER
|
|
# OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
|
# EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
# PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
|
|
# PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
|
|
# LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
|
|
# NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
#
|
|
# Authors:
|
|
# Matthias Jung
|
|
# Lukas Steiner
|
|
|
|
cmake_minimum_required(VERSION 3.10)
|
|
|
|
# Project Name
|
|
project(DRAMSysSimulator)
|
|
|
|
# Configuration:
|
|
set(CMAKE_CXX_STANDARD 11 CACHE STRING "C++ Version")
|
|
set(DCMAKE_SH="CMAKE_SH-NOTFOUND")
|
|
|
|
if(DEFINED ENV{COVERAGE} AND $ENV{COVERAGE} STREQUAL "true")
|
|
set(GCC_COVERAGE_COMPILE_FLAGS "-g -O0 -coverage -fprofile-arcs -ftest-coverage")
|
|
set(GCC_COVERAGE_LINK_FLAGS "-coverage -lgcov")
|
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${GCC_COVERAGE_COMPILE_FLAGS}")
|
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} ${GCC_COVERAGE_LINK_FLAGS}")
|
|
endif()
|
|
|
|
if(EXISTS ${CMAKE_CURRENT_LIST_DIR}/../library/src/simulation/DRAMSysRecordable.cpp)
|
|
add_definitions(-DRECORDING)
|
|
endif()
|
|
|
|
add_executable(DRAMSys
|
|
main.cpp
|
|
ExampleInitiator.h
|
|
MemoryManager.cpp
|
|
StlPlayer.h
|
|
TraceGenerator.h
|
|
TracePlayer.cpp
|
|
TracePlayerListener.h
|
|
TraceSetup.cpp)
|
|
|
|
target_include_directories(DRAMSys
|
|
PUBLIC ../library/src/
|
|
)
|
|
|
|
target_link_libraries(DRAMSys
|
|
PRIVATE DRAMSysLibrary
|
|
)
|