cmake_minimum_required(VERSION 3.12) project(platform VERSION 1.0.0) include(GNUInstallDirs) # library files FILE(GLOB RiscVSCHeaders ${PROJECT_SOURCE_DIR}/incl/sysc/*.h ${PROJECT_SOURCE_DIR}/incl/sysc/*/*.h) set(LIB_HEADERS ${RiscVSCHeaders} ) set(LIB_SOURCES sysc/aon.cpp sysc/BLDC.cpp sysc/clint.cpp sysc/dcmotor.cpp sysc/gpio.cpp sysc/h_bridge.cpp sysc/hifive1.cpp sysc/fe310.cpp sysc/mcp_adc.cpp sysc/plic.cpp sysc/prci.cpp sysc/pwm.cpp sysc/sc_comm_singleton.cpp sysc/spi.cpp sysc/system.cpp sysc/terminal.cpp sysc/uart.cpp CLIParser.cpp ) if(VERILATOR_FOUND) set(LIB_SOURCES ${LIB_SOURCES} rtl/spi_rtl.cpp rtl/tl_uh_bfm.cpp rtl/VTLSPI__Syms.cpp rtl/VTLSPI.cpp ) set_source_files_properties(beh/fe310.cpp PROPERTIES COMPILE_DEFINITIONS "HAS_VERILATOR") endif() add_library(platform ${LIB_SOURCES}) target_include_directories(platform PUBLIC ../incl) target_link_libraries(platform PUBLIC dbt-rise-riscv-sc Seasocks::seasocks external) if(VERILATOR_FOUND) message(STATUS "Verilator found at ${VERILATOR_EXECUTABLE}") target_include_directories(platform PRIVATE ${PROJECT_SOURCE_DIR}/incl/sysc/rtl) target_include_directories(platform SYSTEM PRIVATE ${VERILATOR_INCLUDE_DIR}) endif() set_target_properties(platform PROPERTIES VERSION ${PROJECT_VERSION} # ${VERSION} was defined in the main CMakeLists. FRAMEWORK FALSE PUBLIC_HEADER "${LIB_HEADERS}" # specify the public headers ) add_executable(riscv-vp sc_main.cpp) # include files for this application target_include_directories(riscv-vp SYSTEM PRIVATE ${LLVM_INCLUDE_DIRS}) target_link_libraries(riscv-vp PUBLIC platform dbt-rise-riscv-sc) if(VERILATOR_FOUND) set_source_files_properties(sc_main.cpp PROPERTIES COMPILE_DEFINITIONS HAS_VERILATOR) target_include_directories(riscv-vp SYSTEM PRIVATE ${VERILATOR_INCLUDE_DIR}) target_link_libraries(riscv-vp verilated) endif() if (Tcmalloc_FOUND) target_link_libraries(riscv-vp PUBLIC ${Tcmalloc_LIBRARIES}) endif(Tcmalloc_FOUND) install(TARGETS platform riscv-vp EXPORT ${PROJECT_NAME}Targets # for downstream dependencies ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} COMPONENT libs # static lib RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} COMPONENT libs # binaries LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} COMPONENT libs # shared lib FRAMEWORK DESTINATION ${CMAKE_INSTALL_LIBDIR} COMPONENT libs # for mac PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME} COMPONENT devel # headers for mac (note the different component -> different package) INCLUDES DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} # headers )