217 lines
8.3 KiB
CMake
217 lines
8.3 KiB
CMake
cmake_minimum_required(VERSION 3.12)
|
|
###############################################################################
|
|
#
|
|
###############################################################################
|
|
project(dbt-rise-tgc VERSION 1.0.0)
|
|
|
|
include(GNUInstallDirs)
|
|
|
|
find_package(elfio QUIET)
|
|
find_package(Boost COMPONENTS coroutine)
|
|
find_package(jsoncpp)
|
|
|
|
if(WITH_LLVM)
|
|
if(DEFINED ENV{LLVM_HOME})
|
|
find_path (LLVM_DIR LLVM-Config.cmake $ENV{LLVM_HOME}/lib/cmake/llvm)
|
|
endif(DEFINED ENV{LLVM_HOME})
|
|
find_package(LLVM REQUIRED CONFIG)
|
|
message(STATUS "Found LLVM ${LLVM_PACKAGE_VERSION}")
|
|
message(STATUS "Using LLVMConfig.cmake in: ${LLVM_DIR}")
|
|
llvm_map_components_to_libnames(llvm_libs support core mcjit x86codegen x86asmparser)
|
|
endif()
|
|
|
|
#Mac needed variables (adapt for your needs - http://www.cmake.org/Wiki/CMake_RPATH_handling#Mac_OS_X_and_the_RPATH)
|
|
#set(CMAKE_MACOSX_RPATH ON)
|
|
#set(CMAKE_SKIP_BUILD_RPATH FALSE)
|
|
#set(CMAKE_BUILD_WITH_INSTALL_RPATH FALSE)
|
|
#set(CMAKE_INSTALL_RPATH "${CMAKE_INSTALL_PREFIX}/lib")
|
|
#set(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE)
|
|
|
|
add_subdirectory(softfloat)
|
|
|
|
set(LIB_SOURCES
|
|
src/iss/plugin/instruction_count.cpp
|
|
src/iss/arch/tgc_c.cpp
|
|
src/vm/interp/vm_tgc_c.cpp
|
|
src/vm/fp_functions.cpp
|
|
)
|
|
|
|
# library files
|
|
if(TARGET ${CORE_NAME}_cpp)
|
|
list(APPEND LIB_SOURCES ${${CORE_NAME}_OUTPUT_FILES})
|
|
else()
|
|
FILE(GLOB GEN_SOURCES
|
|
${CMAKE_CURRENT_SOURCE_DIR}/src-gen/iss/arch/*.cpp
|
|
${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/interp/vm_*.cpp
|
|
)
|
|
list(APPEND LIB_SOURCES ${GEN_SOURCES})
|
|
endif()
|
|
|
|
if(TARGET RapidJSON OR TARGET RapidJSON::RapidJSON)
|
|
list(APPEND LIB_SOURCES src/iss/plugin/cycle_estimate.cpp src/iss/plugin/pctrace.cpp)
|
|
endif()
|
|
|
|
if(WITH_LLVM)
|
|
FILE(GLOB LLVM_GEN_SOURCES
|
|
${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/llvm/vm_*.cpp
|
|
)
|
|
list(APPEND LIB_SOURCES ${LLVM_GEN_SOURCES})
|
|
endif()
|
|
|
|
if(WITH_TCC)
|
|
FILE(GLOB TCC_GEN_SOURCES
|
|
${CMAKE_CURRENT_SOURCE_DIR}/src/vm/tcc/vm_*.cpp
|
|
)
|
|
list(APPEND LIB_SOURCES ${TCC_GEN_SOURCES})
|
|
endif()
|
|
|
|
# Define the library
|
|
add_library(${PROJECT_NAME} ${LIB_SOURCES})
|
|
# list code gen dependencies
|
|
if(TARGET ${CORE_NAME}_cpp)
|
|
add_dependencies(${PROJECT_NAME} ${CORE_NAME}_cpp)
|
|
endif()
|
|
|
|
if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
|
|
target_compile_options(${PROJECT_NAME} PRIVATE -Wno-shift-count-overflow)
|
|
elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC")
|
|
target_compile_options(${PROJECT_NAME} PRIVATE /wd4293)
|
|
endif()
|
|
target_include_directories(${PROJECT_NAME} PUBLIC src)
|
|
target_include_directories(${PROJECT_NAME} PUBLIC src-gen)
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC softfloat scc-util Boost::coroutine)
|
|
if(TARGET jsoncpp::jsoncpp)
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC jsoncpp::jsoncpp)
|
|
else()
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC jsoncpp)
|
|
endif()
|
|
if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU" AND BUILD_SHARED_LIBS)
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC -Wl,--whole-archive dbt-rise-core -Wl,--no-whole-archive)
|
|
else()
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC dbt-rise-core)
|
|
endif()
|
|
if(TARGET elfio::elfio)
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC elfio::elfio)
|
|
else()
|
|
message(FATAL_ERROR "No elfio library found, maybe a find_package() call is missing")
|
|
endif()
|
|
if(TARGET lz4::lz4)
|
|
target_compile_definitions(${PROJECT_NAME} PUBLIC WITH_LZ4)
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC lz4::lz4)
|
|
endif()
|
|
if(TARGET RapidJSON::RapidJSON)
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC RapidJSON::RapidJSON)
|
|
elseif(TARGET RapidJSON)
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC RapidJSON)
|
|
endif()
|
|
|
|
|
|
set_target_properties(${PROJECT_NAME} PROPERTIES
|
|
VERSION ${PROJECT_VERSION}
|
|
FRAMEWORK FALSE
|
|
)
|
|
install(TARGETS ${PROJECT_NAME} COMPONENT ${PROJECT_NAME}
|
|
EXPORT ${PROJECT_NAME}Targets # for downstream dependencies
|
|
ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} # static lib
|
|
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} # binaries
|
|
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} # shared lib
|
|
FRAMEWORK DESTINATION ${CMAKE_INSTALL_LIBDIR} # for mac
|
|
PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME} # headers for mac (note the different component -> different package)
|
|
INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} # headers
|
|
)
|
|
install(DIRECTORY ${CMAKE_CURRENT_SOURCE_DIR}/incl/iss COMPONENT ${PROJECT_NAME}
|
|
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} # target directory
|
|
FILES_MATCHING # install only matched files
|
|
PATTERN "*.h" # select header files
|
|
)
|
|
###############################################################################
|
|
#
|
|
###############################################################################
|
|
project(tgc-sim)
|
|
find_package(Boost COMPONENTS program_options thread REQUIRED)
|
|
|
|
add_executable(${PROJECT_NAME} src/main.cpp)
|
|
if(TARGET ${CORE_NAME}_cpp)
|
|
list(APPEND TGC_SOURCES ${${CORE_NAME}_OUTPUT_FILES})
|
|
else()
|
|
FILE(GLOB TGC_SOURCES
|
|
${CMAKE_CURRENT_SOURCE_DIR}/src-gen/iss/arch/*.cpp
|
|
${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/interp/vm_*.cpp
|
|
)
|
|
list(APPEND TGC_SOURCES ${GEN_SOURCES})
|
|
endif()
|
|
|
|
foreach(F IN LISTS TGC_SOURCES)
|
|
if (${F} MATCHES ".*/arch/([^/]*)\.cpp")
|
|
string(REGEX REPLACE ".*/([^/]*)\.cpp" "\\1" CORE_NAME_LC ${F})
|
|
string(TOUPPER ${CORE_NAME_LC} CORE_NAME)
|
|
target_compile_definitions(${PROJECT_NAME} PRIVATE CORE_${CORE_NAME})
|
|
endif()
|
|
endforeach()
|
|
|
|
if(WITH_LLVM)
|
|
target_compile_definitions(${PROJECT_NAME} PRIVATE WITH_LLVM)
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC ${llvm_libs})
|
|
endif()
|
|
if(WITH_TCC)
|
|
target_compile_definitions(${PROJECT_NAME} PRIVATE WITH_TCC)
|
|
endif()
|
|
# Links the target exe against the libraries
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC dbt-rise-tgc)
|
|
if(TARGET Boost::program_options)
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC Boost::program_options)
|
|
else()
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC ${BOOST_program_options_LIBRARY})
|
|
endif()
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC ${CMAKE_DL_LIBS})
|
|
if (Tcmalloc_FOUND)
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC ${Tcmalloc_LIBRARIES})
|
|
endif(Tcmalloc_FOUND)
|
|
|
|
install(TARGETS tgc-sim
|
|
EXPORT ${PROJECT_NAME}Targets # for downstream dependencies
|
|
ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} # static lib
|
|
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} # binaries
|
|
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} # shared lib
|
|
FRAMEWORK DESTINATION ${CMAKE_INSTALL_LIBDIR} # for mac
|
|
PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME} # headers for mac (note the different component -> different package)
|
|
INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} # headers
|
|
)
|
|
###############################################################################
|
|
#
|
|
###############################################################################
|
|
if(TARGET scc-sysc)
|
|
project(dbt-rise-tgc_sc VERSION 1.0.0)
|
|
add_library(${PROJECT_NAME} src/sysc/core_complex.cpp)
|
|
target_compile_definitions(${PROJECT_NAME} PUBLIC WITH_SYSTEMC)
|
|
target_compile_definitions(${PROJECT_NAME} PRIVATE CORE_${CORE_NAME})
|
|
foreach(F IN LISTS TGC_SOURCES)
|
|
if (${F} MATCHES ".*/arch/([^/]*)\.cpp")
|
|
string(REGEX REPLACE ".*/([^/]*)\.cpp" "\\1" CORE_NAME_LC ${F})
|
|
string(TOUPPER ${CORE_NAME_LC} CORE_NAME)
|
|
target_compile_definitions(${PROJECT_NAME} PRIVATE CORE_${CORE_NAME})
|
|
endif()
|
|
endforeach()
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC dbt-rise-tgc scc-sysc)
|
|
if(WITH_LLVM)
|
|
target_link_libraries(${PROJECT_NAME} PUBLIC ${llvm_libs})
|
|
endif()
|
|
|
|
set(LIB_HEADERS ${CMAKE_CURRENT_SOURCE_DIR}/src/sysc/core_complex.h)
|
|
set_target_properties(${PROJECT_NAME} PROPERTIES
|
|
VERSION ${PROJECT_VERSION}
|
|
FRAMEWORK FALSE
|
|
PUBLIC_HEADER "${LIB_HEADERS}" # specify the public headers
|
|
)
|
|
install(TARGETS ${PROJECT_NAME} COMPONENT ${PROJECT_NAME}
|
|
EXPORT ${PROJECT_NAME}Targets # for downstream dependencies
|
|
ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} # static lib
|
|
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} # binaries
|
|
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} # shared lib
|
|
FRAMEWORK DESTINATION ${CMAKE_INSTALL_LIBDIR} # for mac
|
|
PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/sysc # headers for mac (note the different component -> different package)
|
|
INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} # headers
|
|
)
|
|
endif()
|
|
|