DBT-RISE-TGC/CMakeLists.txt

230 lines
8.8 KiB
CMake
Raw Normal View History

2020-04-10 17:14:04 +02:00
cmake_minimum_required(VERSION 3.12)
###############################################################################
#
###############################################################################
2021-07-27 15:55:08 +02:00
project(dbt-rise-tgc VERSION 1.0.0)
include(GNUInstallDirs)
find_package(elfio QUIET)
2022-01-12 07:21:16 +01:00
find_package(Boost COMPONENTS coroutine)
2022-12-05 09:15:48 +01:00
find_package(jsoncpp)
2023-07-14 12:51:51 +02:00
if(TARGET tcc::tcc)
set(WITH_TCC ON)
endif()
if(WITH_LLVM)
2023-07-17 19:52:50 +02:00
if(DEFINED ENV{LLVM_HOME})
find_path (LLVM_DIR LLVM-Config.cmake $ENV{LLVM_HOME}/lib/cmake/llvm)
2023-07-17 19:57:09 +02:00
endif()
2023-07-17 19:52:50 +02:00
find_package(LLVM QUIET CONFIG)
if(LLVM_FOUND)
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)
2023-07-13 09:42:39 +02:00
else()
find_package(LLVM REQUIRED LLVMSupport LLVMCore LLVMMCJIT LLVMX86CodeGen LLVMX86AsmParser)
endif()
endif()
2019-06-18 21:20:43 +02:00
2019-06-11 21:22:07 +02:00
add_subdirectory(softfloat)
set(LIB_SOURCES
2022-05-21 11:55:24 +02:00
src/iss/plugin/instruction_count.cpp
src/iss/arch/tgc_c.cpp
src/vm/tcc/vm_tgc_c.cpp
2022-05-21 12:27:13 +02:00
src/vm/interp/vm_tgc_c.cpp
src/vm/fp_functions.cpp
)
if(WITH_TCC)
list(APPEND LIB_SOURCES src/vm/tcc/vm_tgc_c.cpp)
endif()
2023-07-29 17:55:37 +02:00
if(WITH_LLVM)
list(APPEND LIB_SOURCES src/vm/llvm/vm_tgc_c.cpp src/vm/llvm/fp_impl.cpp)
endif()
# library files
FILE(GLOB GEN_ISS_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/iss/arch/*.cpp)
FILE(GLOB GEN_VM_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/interp/vm_*.cpp)
list(APPEND LIB_SOURCES ${GEN_ISS_SOURCES} ${GEN_VM_SOURCES})
foreach(FILEPATH ${GEN_ISS_SOURCES})
get_filename_component(CORE ${FILEPATH} NAME_WE)
string(TOUPPER ${CORE} CORE)
list(APPEND LIB_DEFINES CORE_${CORE})
endforeach()
message("Core defines are ${LIB_DEFINES}")
2021-05-13 14:03:10 +02:00
if(WITH_LLVM)
FILE(GLOB LLVM_GEN_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/llvm/vm_*.cpp)
2022-05-21 12:27:13 +02:00
list(APPEND LIB_SOURCES ${LLVM_GEN_SOURCES})
2021-10-12 14:24:55 +02:00
endif()
if(WITH_TCC)
FILE(GLOB TCC_GEN_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/vm/tcc/vm_*.cpp)
2022-05-21 12:27:13 +02:00
list(APPEND LIB_SOURCES ${TCC_GEN_SOURCES})
endif()
2019-06-11 21:22:07 +02:00
if(TARGET RapidJSON OR TARGET RapidJSON::RapidJSON)
list(APPEND LIB_SOURCES src/iss/plugin/cycle_estimate.cpp src/iss/plugin/pctrace.cpp)
endif()
2019-06-11 21:22:07 +02:00
# Define the library
2021-10-10 19:06:41 +02:00
add_library(${PROJECT_NAME} ${LIB_SOURCES})
2021-10-10 19:56:33 +02:00
if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
2023-07-29 17:55:37 +02:00
target_compile_options(${PROJECT_NAME} PRIVATE -Wno-shift-count-overflow)
2021-10-10 19:56:33 +02:00
elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC")
target_compile_options(${PROJECT_NAME} PRIVATE /wd4293)
2021-10-10 19:06:41 +02:00
endif()
2022-05-21 11:55:24 +02:00
target_include_directories(${PROJECT_NAME} PUBLIC src)
2022-05-21 12:27:13 +02:00
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()
2022-09-28 19:37:47 +02:00
if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU" AND BUILD_SHARED_LIBS)
2022-04-09 14:55:36 +02:00
target_link_libraries(${PROJECT_NAME} PUBLIC -Wl,--whole-archive dbt-rise-core -Wl,--no-whole-archive)
2021-10-10 19:06:41 +02:00
else()
2022-04-09 14:55:36 +02:00
target_link_libraries(${PROJECT_NAME} PUBLIC dbt-rise-core)
2021-10-10 19:06:41 +02:00
endif()
2022-12-12 02:55:44 +01:00
if(TARGET elfio::elfio)
2021-07-26 12:03:40 +02:00
target_link_libraries(${PROJECT_NAME} PUBLIC elfio::elfio)
else()
message(FATAL_ERROR "No elfio library found, maybe a find_package() call is missing")
2021-07-26 12:03:40 +02:00
endif()
2022-05-07 17:22:06 +02:00
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)
2022-02-01 19:28:11 +01:00
target_link_libraries(${PROJECT_NAME} PUBLIC RapidJSON)
endif()
2023-07-29 17:55:37 +02:00
if(WITH_LLVM)
target_compile_definitions(${PROJECT_NAME} PUBLIC ${LLVM_DEFINITIONS})
target_include_directories(${PROJECT_NAME} PUBLIC ${LLVM_INCLUDE_DIRS})
if(BUILD_SHARED_LIBS)
target_link_libraries( ${PROJECT_NAME} PUBLIC ${LLVM_LIBRARIES})
endif()
endif()
2022-02-01 19:28:11 +01:00
2021-03-23 18:13:32 +01:00
set_target_properties(${PROJECT_NAME} PROPERTIES
VERSION ${PROJECT_VERSION}
2019-06-11 21:22:07 +02:00
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
)
###############################################################################
#
###############################################################################
2021-05-13 14:03:10 +02:00
project(tgc-sim)
2021-07-27 15:55:08 +02:00
find_package(Boost COMPONENTS program_options thread REQUIRED)
2021-07-26 12:03:40 +02:00
2021-03-23 18:13:32 +01:00
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()
2021-11-25 19:59:50 +01:00
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()
2021-11-25 19:59:50 +01:00
endforeach()
if(WITH_LLVM)
target_compile_definitions(${PROJECT_NAME} PRIVATE WITH_LLVM)
target_link_libraries(${PROJECT_NAME} PUBLIC ${llvm_libs})
endif()
2023-05-16 21:51:35 +02:00
if(WITH_TCC)
target_compile_definitions(${PROJECT_NAME} PRIVATE WITH_TCC)
endif()
2019-06-11 21:22:07 +02:00
# Links the target exe against the libraries
2021-10-10 19:06:41 +02:00
target_link_libraries(${PROJECT_NAME} PUBLIC dbt-rise-tgc)
2021-07-26 12:03:40 +02:00
if(TARGET Boost::program_options)
2021-11-02 10:24:34 +01:00
target_link_libraries(${PROJECT_NAME} PUBLIC Boost::program_options)
2021-07-26 12:03:40 +02:00
else()
2021-11-02 10:24:34 +01:00
target_link_libraries(${PROJECT_NAME} PUBLIC ${BOOST_program_options_LIBRARY})
2021-07-26 12:03:40 +02:00
endif()
2021-10-10 19:06:41 +02:00
target_link_libraries(${PROJECT_NAME} PUBLIC ${CMAKE_DL_LIBS})
2019-06-11 21:22:07 +02:00
if (Tcmalloc_FOUND)
2021-10-10 19:06:41 +02:00
target_link_libraries(${PROJECT_NAME} PUBLIC ${Tcmalloc_LIBRARIES})
2019-06-11 21:22:07 +02:00
endif(Tcmalloc_FOUND)
install(TARGETS tgc-sim
2019-06-11 21:22:07 +02:00
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
2019-06-11 21:22:07 +02:00
)
###############################################################################
#
###############################################################################
2023-05-11 23:43:12 +02:00
if(TARGET scc-sysc)
2023-07-10 12:52:48 +02:00
project(dbt-rise-tgc_sc VERSION 1.0.0)
2023-07-14 12:51:51 +02:00
set(LIB_SOURCES
src/sysc/core_complex.cpp
src/sysc/register_tgc_c.cpp
2023-07-14 12:51:51 +02:00
)
FILE(GLOB GEN_SC_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src-gen/sysc/register_*.cpp)
list(APPEND LIB_SOURCES ${GEN_SC_SOURCES})
add_library(${PROJECT_NAME} ${LIB_SOURCES})
2023-07-14 11:11:03 +02:00
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)
2023-07-14 11:11:03 +02:00
target_compile_definitions(${PROJECT_NAME} PRIVATE CORE_${CORE_NAME})
endif()
endforeach()
2023-07-14 11:11:03 +02:00
target_link_libraries(${PROJECT_NAME} PUBLIC dbt-rise-tgc scc-sysc)
2021-07-27 15:55:08 +02:00
if(WITH_LLVM)
2023-07-14 11:11:03 +02:00
target_link_libraries(${PROJECT_NAME} PUBLIC ${llvm_libs})
2021-07-27 15:55:08 +02:00
endif()
2022-09-27 09:11:41 +02:00
set(LIB_HEADERS ${CMAKE_CURRENT_SOURCE_DIR}/src/sysc/core_complex.h)
2023-07-14 11:11:03 +02:00
set_target_properties(${PROJECT_NAME} PROPERTIES
2021-07-27 15:55:08 +02:00
VERSION ${PROJECT_VERSION}
FRAMEWORK FALSE
PUBLIC_HEADER "${LIB_HEADERS}" # specify the public headers
)
2023-07-14 11:11:03 +02:00
install(TARGETS ${PROJECT_NAME} COMPONENT ${PROJECT_NAME}
2021-07-27 15:55:08 +02:00
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)
2021-07-27 15:55:08 +02:00
INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} # headers
)
endif()