OpenFPGA/openfpga/CMakeLists.txt

57 lines
1.8 KiB
CMake
Raw Normal View History

cmake_minimum_required(VERSION 3.9)
project("openfpga")
file(GLOB_RECURSE EXEC_SOURCE src/main.cpp)
file(GLOB_RECURSE LIB_SOURCES src/*/*.cpp)
file(GLOB_RECURSE LIB_HEADERS src/*/*.h)
files_to_dirs(LIB_HEADERS LIB_INCLUDE_DIRS)
#Remove test executable from library
list(REMOVE_ITEM LIB_SOURCES ${EXEC_SOURCE})
if (OPENFPGA_WITH_SWIG)
# SWIG library
SwigLib(NAME libopenfpga_swig
2022-12-01 14:30:57 -06:00
NAMESPACE std
LANGUAGE tcl
I_FILE src/openfpga.i)
2022-12-01 16:49:05 -06:00
target_include_directories(libopenfpga_swig PUBLIC ${LIB_INCLUDE_DIRS})
target_link_libraries(libopenfpga_swig
libopenfpga)
endif()
#Create the library
#Static linked library for other C++ libraries
add_library(libopenfpga STATIC
${LIB_HEADERS}
${LIB_SOURCES})
target_include_directories(libopenfpga PUBLIC ${LIB_INCLUDE_DIRS})
set_target_properties(libopenfpga PROPERTIES PREFIX "") #Avoid extra 'lib' prefix
#Specify link-time dependancies
target_link_libraries(libopenfpga
libarchopenfpga
libopenfpgashell
libopenfpgautil
libfabrickey
libfpgabitstream
2020-02-27 19:01:47 -06:00
libini
libpcf
libvtrutil
libbusgroup
libpugixml
libvpr)
#Create the test executable
add_executable(openfpga ${EXEC_SOURCE})
target_link_libraries(openfpga libopenfpga)
2022-08-24 23:51:29 -05:00
#Suppress IPO link warnings if IPO is enabled
get_target_property(OPENFPGA_USES_IPO openfpga INTERPROCEDURAL_OPTIMIZATION)
2022-08-24 16:34:33 -05:00
if (OPENFPGA_USES_IPO)
set_property(TARGET openfpga APPEND PROPERTY LINK_FLAGS ${IPO_LINK_WARN_SUPRESS_FLAGS})
endif()
install(TARGETS libopenfpga openfpga DESTINATION bin)