2020-06-25 01:57:24 +08:00
|
|
|
cmake_minimum_required(VERSION 3.5)
|
2020-06-24 16:17:57 +08:00
|
|
|
project(nextpnr CXX)
|
2018-06-23 20:32:18 +08:00
|
|
|
|
|
|
|
option(BUILD_GUI "Build GUI" ON)
|
|
|
|
option(BUILD_PYTHON "Build Python Integration" ON)
|
2020-02-12 21:44:22 +08:00
|
|
|
option(BUILD_TESTS "Build tests" OFF)
|
2019-02-25 19:56:10 +08:00
|
|
|
option(BUILD_HEAP "Build HeAP analytic placer" ON)
|
|
|
|
option(USE_OPENMP "Use OpenMP to accelerate analytic placer" OFF)
|
2018-08-24 00:38:13 +08:00
|
|
|
option(COVERAGE "Add code coverage info" OFF)
|
2018-08-16 16:32:34 +08:00
|
|
|
option(STATIC_BUILD "Create static build" OFF)
|
2019-02-09 20:34:57 +08:00
|
|
|
option(EXTERNAL_CHIPDB "Create build with pre-built chipdb binaries" OFF)
|
2020-06-24 23:44:45 +08:00
|
|
|
|
|
|
|
if(WIN32 OR EXTERNAL_CHIPDB)
|
|
|
|
set(BBASM_MODE "binary")
|
|
|
|
else()
|
|
|
|
set(BBASM_MODE "string")
|
|
|
|
endif()
|
2018-08-16 16:32:34 +08:00
|
|
|
|
2019-10-09 17:46:18 +08:00
|
|
|
set(Boost_NO_BOOST_CMAKE ON)
|
2019-09-28 18:33:45 +08:00
|
|
|
|
2020-05-24 03:50:09 +08:00
|
|
|
if(WASI)
|
|
|
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -lwasi-emulated-mman")
|
|
|
|
set(USE_THREADS OFF)
|
|
|
|
add_definitions(
|
|
|
|
-DBOOST_EXCEPTION_DISABLE
|
|
|
|
-DBOOST_NO_EXCEPTIONS
|
|
|
|
-DBOOST_SP_NO_ATOMIC_ACCESS
|
|
|
|
-DBOOST_AC_DISABLE_THREADS
|
|
|
|
-DBOOST_NO_CXX11_HDR_MUTEX
|
|
|
|
)
|
|
|
|
else()
|
|
|
|
set(USE_THREADS ON)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if (NOT USE_THREADS)
|
|
|
|
add_definitions(-DNPNR_DISABLE_THREADS)
|
|
|
|
endif()
|
|
|
|
|
2018-08-16 16:32:34 +08:00
|
|
|
set(link_param "")
|
|
|
|
if (STATIC_BUILD)
|
|
|
|
set(Boost_USE_STATIC_LIBS ON)
|
2019-08-15 12:59:00 +08:00
|
|
|
if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
2020-05-14 14:35:55 +08:00
|
|
|
elseif(${CMAKE_SYSTEM_NAME} MATCHES "Windows")
|
|
|
|
if (MSVC)
|
|
|
|
set(CMAKE_CXX_FLAGS_RELEASE "/MT")
|
|
|
|
set(CMAKE_CXX_FLAGS_DEBUG "/MTd")
|
|
|
|
endif()
|
2019-08-15 12:59:00 +08:00
|
|
|
if (BUILD_PYTHON)
|
|
|
|
add_definitions(-DBOOST_PYTHON_STATIC_LIB)
|
|
|
|
endif()
|
|
|
|
else()
|
2019-09-10 23:12:31 +08:00
|
|
|
set(CMAKE_FIND_LIBRARY_SUFFIXES ".a" ".so")
|
2018-09-04 01:01:56 +08:00
|
|
|
set(link_param "-static")
|
2019-09-10 23:12:31 +08:00
|
|
|
if (BUILD_PYTHON)
|
|
|
|
find_package(ZLIB)
|
|
|
|
find_package(EXPAT)
|
|
|
|
find_package(Threads)
|
|
|
|
endif()
|
2018-09-04 01:01:56 +08:00
|
|
|
endif()
|
2018-08-16 16:32:34 +08:00
|
|
|
endif()
|
2018-06-23 20:32:18 +08:00
|
|
|
|
2019-02-09 20:34:57 +08:00
|
|
|
if (EXTERNAL_CHIPDB)
|
2020-06-24 23:44:45 +08:00
|
|
|
set(EXTERNAL_CHIPDB_ROOT "${CMAKE_INSTALL_PREFIX}/share/nextpnr" CACHE STRING
|
|
|
|
"External chipdb path")
|
|
|
|
message(STATUS "Using external chipdb path: ${EXTERNAL_CHIPDB_ROOT}")
|
2019-02-09 20:34:57 +08:00
|
|
|
add_definitions("-DEXTERNAL_CHIPDB_ROOT=\"${EXTERNAL_CHIPDB_ROOT}\"")
|
|
|
|
endif()
|
|
|
|
|
2020-04-10 16:50:30 +08:00
|
|
|
set(PROGRAM_PREFIX "" CACHE STRING "Name prefix for executables")
|
|
|
|
|
2018-06-02 19:48:12 +08:00
|
|
|
# List of families to build
|
2018-07-06 02:59:11 +08:00
|
|
|
set(FAMILIES generic ice40 ecp5)
|
2018-07-08 17:20:04 +08:00
|
|
|
|
2018-07-11 16:23:23 +08:00
|
|
|
set(ARCH "" CACHE STRING "Architecture family for nextpnr build")
|
|
|
|
set_property(CACHE ARCH PROPERTY STRINGS ${FAMILIES})
|
|
|
|
|
|
|
|
if (NOT ARCH)
|
|
|
|
message(STATUS "Architecture needs to be set, set desired one with -DARCH=xxx")
|
|
|
|
message(STATUS "Supported architectures are :")
|
|
|
|
message(STATUS " all")
|
|
|
|
foreach(item ${FAMILIES})
|
|
|
|
message(STATUS " ${item}")
|
|
|
|
endforeach()
|
|
|
|
message(FATAL_ERROR "Architecture setting is mandatory")
|
|
|
|
endif ()
|
|
|
|
|
|
|
|
if (ARCH STREQUAL "all")
|
|
|
|
SET(ARCH ${FAMILIES})
|
|
|
|
endif()
|
|
|
|
|
|
|
|
foreach(item ${ARCH})
|
|
|
|
if (NOT item IN_LIST FAMILIES)
|
|
|
|
message(FATAL_ERROR "Architecture '${item}' not in list of supported architectures")
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
|
2018-06-01 17:58:31 +08:00
|
|
|
set(CMAKE_CXX_STANDARD 11)
|
2018-07-03 14:52:19 +08:00
|
|
|
if (MSVC)
|
2019-02-25 19:56:10 +08:00
|
|
|
set(CMAKE_CONFIGURATION_TYPES "Debug;Release" CACHE STRING "" FORCE)
|
|
|
|
set(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /D_DEBUG /W4 /wd4100 /wd4244 /wd4125 /wd4800 /wd4456 /wd4458 /wd4305 /wd4459 /wd4121 /wd4996")
|
|
|
|
set(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /W4 /wd4100 /wd4244 /wd4125 /wd4800 /wd4456 /wd4458 /wd4305 /wd4459 /wd4121 /wd4996 /wd4127")
|
2018-07-03 14:52:19 +08:00
|
|
|
else()
|
2019-02-25 19:56:10 +08:00
|
|
|
set(CMAKE_CXX_FLAGS_DEBUG "-Wall -fPIC -ggdb -pipe")
|
|
|
|
if (USE_OPENMP)
|
|
|
|
set(CMAKE_CXX_FLAGS_RELEASE "-Wall -fPIC -O3 -g -pipe -fopenmp")
|
|
|
|
else()
|
|
|
|
set(CMAKE_CXX_FLAGS_RELEASE "-Wall -fPIC -O3 -g -pipe")
|
|
|
|
endif()
|
2018-07-03 14:52:19 +08:00
|
|
|
endif()
|
2018-06-25 01:32:39 +08:00
|
|
|
|
2018-08-24 00:38:13 +08:00
|
|
|
set(CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/3rdparty/sanitizers-cmake/cmake;." ${CMAKE_MODULE_PATH})
|
|
|
|
|
|
|
|
if (COVERAGE)
|
|
|
|
include(CodeCoverage)
|
|
|
|
endif()
|
2018-06-25 01:32:39 +08:00
|
|
|
|
2018-07-05 16:14:19 +08:00
|
|
|
if(NOT DEFINED CMAKE_SUPPRESS_DEVELOPER_WARNINGS)
|
|
|
|
set(CMAKE_SUPPRESS_DEVELOPER_WARNINGS 1 CACHE INTERNAL "No dev warnings")
|
|
|
|
endif()
|
|
|
|
|
2018-06-25 01:32:39 +08:00
|
|
|
find_package(Sanitizers)
|
|
|
|
|
2018-06-02 19:48:12 +08:00
|
|
|
# List of Boost libraries to include
|
2020-05-24 03:50:09 +08:00
|
|
|
set(boost_libs filesystem program_options iostreams system)
|
|
|
|
if (USE_THREADS)
|
|
|
|
list(APPEND boost_libs thread)
|
|
|
|
endif()
|
2018-06-23 20:32:18 +08:00
|
|
|
|
2018-07-14 20:06:05 +08:00
|
|
|
if (BUILD_GUI AND NOT BUILD_PYTHON)
|
|
|
|
message(FATAL_ERROR "GUI requires Python to build")
|
|
|
|
endif()
|
|
|
|
|
2018-07-29 19:42:00 +08:00
|
|
|
find_package(PythonInterp 3.5 REQUIRED)
|
2018-06-23 20:32:18 +08:00
|
|
|
if (BUILD_PYTHON)
|
|
|
|
# TODO: sensible minimum Python version
|
|
|
|
find_package(PythonLibs 3.5 REQUIRED)
|
|
|
|
else()
|
|
|
|
add_definitions("-DNO_PYTHON")
|
|
|
|
endif()
|
2018-06-01 17:58:31 +08:00
|
|
|
|
|
|
|
find_package(Boost REQUIRED COMPONENTS ${boost_libs})
|
|
|
|
|
2018-06-23 20:32:18 +08:00
|
|
|
if (BUILD_GUI)
|
|
|
|
# Find the Qt5 libraries
|
|
|
|
find_package(Qt5 COMPONENTS Core Widgets OpenGL REQUIRED)
|
|
|
|
find_package(OpenGL REQUIRED)
|
|
|
|
else()
|
|
|
|
add_definitions("-DNO_GUI")
|
|
|
|
endif()
|
2018-06-20 22:13:49 +08:00
|
|
|
|
2020-01-11 18:04:07 +08:00
|
|
|
if (NOT DEFINED CURRENT_GIT_VERSION)
|
|
|
|
# Get the latest abbreviated commit hash of the working branch
|
|
|
|
# if not already defined outside (e.g. by package manager when building
|
|
|
|
# outside of git repository)
|
|
|
|
execute_process(
|
|
|
|
COMMAND git describe --tags --always
|
|
|
|
WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
|
|
|
|
OUTPUT_VARIABLE CURRENT_GIT_VERSION
|
|
|
|
OUTPUT_STRIP_TRAILING_WHITESPACE
|
|
|
|
)
|
|
|
|
endif()
|
2018-06-06 03:03:06 +08:00
|
|
|
|
2018-06-23 20:32:18 +08:00
|
|
|
if (BUILD_TESTS)
|
2018-07-04 02:46:05 +08:00
|
|
|
add_subdirectory(3rdparty/googletest/googletest ${CMAKE_CURRENT_BINARY_DIR}/generated/3rdparty/googletest EXCLUDE_FROM_ALL)
|
2018-06-23 20:32:18 +08:00
|
|
|
enable_testing()
|
|
|
|
endif()
|
2018-06-12 03:04:30 +08:00
|
|
|
|
2018-06-23 20:32:18 +08:00
|
|
|
if (BUILD_GUI)
|
2018-07-11 16:23:23 +08:00
|
|
|
add_subdirectory(3rdparty/QtPropertyBrowser ${CMAKE_CURRENT_BINARY_DIR}/generated/3rdparty/QtPropertyBrowser EXCLUDE_FROM_ALL)
|
2018-06-23 20:32:18 +08:00
|
|
|
endif()
|
2018-06-20 20:24:16 +08:00
|
|
|
|
2018-06-06 03:03:06 +08:00
|
|
|
configure_file(
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/common/version.h.in ${CMAKE_CURRENT_BINARY_DIR}/generated/version.h
|
|
|
|
)
|
|
|
|
|
2018-06-23 20:32:18 +08:00
|
|
|
if (BUILD_PYTHON)
|
|
|
|
# Find Boost::Python of a suitable version in a cross-platform way
|
|
|
|
# Some distributions (Arch) call it libboost_python3, others such as Ubuntu
|
|
|
|
# call it libboost_python35. In the latter case we must consider all minor versions
|
|
|
|
# Original source: https://github.com/BVLC/caffe/blob/master/cmake/Dependencies.cmake#L148
|
|
|
|
set(version ${PYTHONLIBS_VERSION_STRING})
|
2018-06-01 17:58:31 +08:00
|
|
|
|
2019-08-14 21:30:39 +08:00
|
|
|
STRING(REGEX REPLACE "[^0-9]" "" boost_py_version "${version}")
|
2018-11-21 02:41:24 +08:00
|
|
|
find_package(Boost QUIET COMPONENTS "python-py${boost_py_version}" ${boost_libs})
|
2018-06-01 17:58:31 +08:00
|
|
|
set(Boost_PYTHON_FOUND ${Boost_PYTHON-PY${boost_py_version}_FOUND})
|
|
|
|
|
2018-06-23 20:32:18 +08:00
|
|
|
while (NOT "${version}" STREQUAL "" AND NOT Boost_PYTHON_FOUND)
|
2019-08-14 21:30:39 +08:00
|
|
|
STRING(REGEX REPLACE "([0-9.]+).[0-9]+" "\\1" version "${version}")
|
2018-06-23 20:32:18 +08:00
|
|
|
|
2019-08-14 21:30:39 +08:00
|
|
|
STRING(REGEX REPLACE "[^0-9]" "" boost_py_version "${version}")
|
2018-11-21 02:41:24 +08:00
|
|
|
find_package(Boost QUIET COMPONENTS "python-py${boost_py_version}" ${boost_libs})
|
2018-06-23 20:32:18 +08:00
|
|
|
set(Boost_PYTHON_FOUND ${Boost_PYTHON-PY${boost_py_version}_FOUND})
|
2018-06-01 17:58:31 +08:00
|
|
|
|
2019-08-14 21:30:39 +08:00
|
|
|
STRING(REGEX MATCHALL "([0-9.]+).[0-9]+" has_more_version "${version}")
|
2018-06-23 20:32:18 +08:00
|
|
|
if ("${has_more_version}" STREQUAL "")
|
|
|
|
break()
|
|
|
|
endif ()
|
|
|
|
endwhile ()
|
|
|
|
|
|
|
|
if (NOT Boost_PYTHON_FOUND)
|
2020-01-30 01:12:07 +08:00
|
|
|
foreach (PyVer 3 36 37 38 39)
|
2019-08-21 22:49:23 +08:00
|
|
|
find_package(Boost QUIET COMPONENTS python${PyVer} ${boost_libs})
|
|
|
|
if ("${Boost_LIBRARIES}" MATCHES ".*(python|PYTHON).*" )
|
|
|
|
set(Boost_PYTHON_FOUND TRUE)
|
|
|
|
break()
|
|
|
|
endif ()
|
|
|
|
endforeach ()
|
2018-07-12 20:36:28 +08:00
|
|
|
endif ()
|
|
|
|
|
2018-06-23 20:32:18 +08:00
|
|
|
if (NOT Boost_PYTHON_FOUND)
|
2019-08-14 21:30:39 +08:00
|
|
|
STRING(REGEX REPLACE "([0-9]+\\.[0-9]+).*" "\\1" gentoo_version "${PYTHONLIBS_VERSION_STRING}")
|
2018-11-21 02:41:24 +08:00
|
|
|
find_package(Boost QUIET COMPONENTS python-${gentoo_version} ${boost_libs})
|
2018-06-23 20:32:18 +08:00
|
|
|
if ("${Boost_LIBRARIES}" MATCHES ".*(python|PYTHON).*" )
|
|
|
|
set(Boost_PYTHON_FOUND TRUE)
|
|
|
|
endif ()
|
2018-06-06 17:27:02 +08:00
|
|
|
endif ()
|
2018-06-01 17:58:31 +08:00
|
|
|
|
2018-06-23 20:32:18 +08:00
|
|
|
if (NOT Boost_PYTHON_FOUND )
|
|
|
|
message( FATAL_ERROR "No version of Boost::Python 3.x could be found.")
|
|
|
|
endif ()
|
|
|
|
endif()
|
2018-06-01 17:58:31 +08:00
|
|
|
|
2019-11-14 00:17:43 +08:00
|
|
|
include_directories(common/ json/ frontend/ 3rdparty/json11/ ${Boost_INCLUDE_DIRS} ${PYTHON_INCLUDE_DIRS})
|
2019-02-25 19:56:10 +08:00
|
|
|
|
|
|
|
if(BUILD_HEAP)
|
|
|
|
find_package (Eigen3 REQUIRED NO_MODULE)
|
|
|
|
include_directories(${EIGEN3_INCLUDE_DIRS})
|
|
|
|
add_definitions(${EIGEN3_DEFINITIONS})
|
|
|
|
add_definitions(-DWITH_HEAP)
|
|
|
|
endif()
|
2019-02-24 01:33:47 +08:00
|
|
|
|
2018-06-07 02:44:54 +08:00
|
|
|
aux_source_directory(common/ COMMON_SRC_FILES)
|
2018-06-23 22:20:31 +08:00
|
|
|
aux_source_directory(json/ JSON_PARSER_FILES)
|
2019-11-14 00:17:43 +08:00
|
|
|
aux_source_directory(3rdparty/json11 EXT_JSON11_FILES)
|
2019-11-12 19:33:49 +08:00
|
|
|
aux_source_directory(frontend/ FRONTEND_FILES)
|
|
|
|
|
2019-11-14 00:17:43 +08:00
|
|
|
set(COMMON_FILES ${COMMON_SRC_FILES} ${EXT_JSON11_FILES} ${JSON_PARSER_FILES} ${FRONTEND_FILES})
|
2018-06-20 00:04:10 +08:00
|
|
|
set(CMAKE_BUILD_TYPE Release)
|
2018-06-01 17:58:31 +08:00
|
|
|
|
2020-06-23 18:14:40 +08:00
|
|
|
if(CMAKE_CROSSCOMPILING)
|
|
|
|
set(BBA_IMPORT "IMPORTFILE-NOTFOUND" CACHE FILEPATH
|
|
|
|
"Path to the `bba-export.cmake` export file from a native build")
|
|
|
|
include(${BBA_IMPORT})
|
|
|
|
else()
|
|
|
|
add_subdirectory(bba)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
include(TestBigEndian)
|
|
|
|
test_big_endian(IS_BIG_ENDIAN)
|
|
|
|
if(IS_BIG_ENDIAN)
|
|
|
|
set(BBASM_ENDIAN_FLAG "--be")
|
|
|
|
else()
|
|
|
|
set(BBASM_ENDIAN_FLAG "--le")
|
|
|
|
endif()
|
2018-07-24 21:31:00 +08:00
|
|
|
|
2018-07-11 16:23:23 +08:00
|
|
|
foreach (family ${ARCH})
|
2020-06-24 23:44:45 +08:00
|
|
|
message(STATUS "Configuring architecture: ${family}")
|
2018-06-01 17:58:31 +08:00
|
|
|
string(TOUPPER ${family} ufamily)
|
2019-06-27 05:31:24 +08:00
|
|
|
aux_source_directory(${family}/ ${ufamily}_FILES)
|
2018-06-20 22:13:49 +08:00
|
|
|
|
2018-06-23 20:32:18 +08:00
|
|
|
if (BUILD_GUI)
|
2018-07-11 16:23:23 +08:00
|
|
|
add_subdirectory(gui ${CMAKE_CURRENT_BINARY_DIR}/generated/gui/${family} EXCLUDE_FROM_ALL)
|
2018-06-23 20:32:18 +08:00
|
|
|
endif()
|
2018-06-20 22:13:49 +08:00
|
|
|
|
2018-06-02 19:48:12 +08:00
|
|
|
# Add the CLI binary target
|
2020-04-10 16:50:30 +08:00
|
|
|
add_executable(${PROGRAM_PREFIX}nextpnr-${family} ${COMMON_FILES} ${${ufamily}_FILES})
|
2020-05-24 03:50:09 +08:00
|
|
|
if (WASI)
|
|
|
|
# set(CMAKE_EXECUTABLE_SUFFIX) breaks CMake tests for some reason
|
|
|
|
set_property(TARGET ${PROGRAM_PREFIX}nextpnr-${family} PROPERTY SUFFIX ".wasm")
|
|
|
|
endif()
|
2020-04-10 16:50:30 +08:00
|
|
|
install(TARGETS ${PROGRAM_PREFIX}nextpnr-${family} RUNTIME DESTINATION bin)
|
|
|
|
target_compile_definitions(${PROGRAM_PREFIX}nextpnr-${family} PRIVATE MAIN_EXECUTABLE)
|
2019-06-27 05:31:24 +08:00
|
|
|
|
2018-06-02 19:48:12 +08:00
|
|
|
# Add any new per-architecture targets here
|
2018-06-23 20:32:18 +08:00
|
|
|
if (BUILD_TESTS)
|
2018-08-24 00:38:13 +08:00
|
|
|
if (COVERAGE)
|
|
|
|
APPEND_COVERAGE_COMPILER_FLAGS()
|
2018-08-24 00:45:54 +08:00
|
|
|
set(COVERAGE_LCOV_EXCLUDES '/usr/include/*' '3rdparty/*' 'generated/*' 'bba/*' 'tests/*')
|
2018-08-24 00:38:13 +08:00
|
|
|
SETUP_TARGET_FOR_COVERAGE_LCOV(
|
2019-06-27 05:31:24 +08:00
|
|
|
NAME ${family}-coverage
|
2020-04-10 16:50:30 +08:00
|
|
|
EXECUTABLE ${PROGRAM_PREFIX}nextpnr-${family}-test
|
|
|
|
DEPENDENCIES ${PROGRAM_PREFIX}nextpnr-${family}-test
|
2018-08-24 00:38:13 +08:00
|
|
|
)
|
|
|
|
endif()
|
|
|
|
|
2018-06-23 20:32:18 +08:00
|
|
|
aux_source_directory(tests/${family}/ ${ufamily}_TEST_FILES)
|
2018-07-26 04:57:20 +08:00
|
|
|
if (BUILD_GUI)
|
|
|
|
aux_source_directory(tests/gui/ GUI_TEST_FILES)
|
|
|
|
endif()
|
2018-06-23 20:32:18 +08:00
|
|
|
|
2020-04-10 16:50:30 +08:00
|
|
|
add_executable(${PROGRAM_PREFIX}nextpnr-${family}-test ${${ufamily}_TEST_FILES}
|
2018-07-26 04:57:20 +08:00
|
|
|
${COMMON_FILES} ${${ufamily}_FILES} ${GUI_TEST_FILES})
|
2020-04-10 16:50:30 +08:00
|
|
|
target_link_libraries(${PROGRAM_PREFIX}nextpnr-${family}-test PRIVATE gtest_main)
|
|
|
|
add_sanitizers(${PROGRAM_PREFIX}nextpnr-${family}-test)
|
2018-06-02 19:48:12 +08:00
|
|
|
|
2018-06-23 20:32:18 +08:00
|
|
|
add_test(${family}-test ${CMAKE_CURRENT_BINARY_DIR}/nextpnr-${family}-test)
|
|
|
|
endif()
|
2018-06-13 01:56:03 +08:00
|
|
|
|
2018-06-02 19:48:12 +08:00
|
|
|
# Set ${family_targets} to the list of targets being build for this family
|
2020-04-10 16:50:30 +08:00
|
|
|
set(family_targets ${PROGRAM_PREFIX}nextpnr-${family})
|
2019-06-27 05:31:24 +08:00
|
|
|
|
2018-06-23 20:32:18 +08:00
|
|
|
if (BUILD_TESTS)
|
2020-04-10 16:50:30 +08:00
|
|
|
set(family_targets ${family_targets} ${PROGRAM_PREFIX}nextpnr-${family}-test)
|
2018-06-23 20:32:18 +08:00
|
|
|
endif()
|
|
|
|
|
2018-06-02 19:48:12 +08:00
|
|
|
# Include the family-specific CMakeFile
|
2018-06-01 17:58:31 +08:00
|
|
|
include(${family}/family.cmake)
|
|
|
|
foreach (target ${family_targets})
|
2018-06-02 19:48:12 +08:00
|
|
|
# Include family-specific source files to all family targets and set defines appropriately
|
2018-07-04 02:46:05 +08:00
|
|
|
target_include_directories(${target} PRIVATE ${family}/ ${CMAKE_CURRENT_BINARY_DIR}/generated/)
|
2018-06-23 20:32:18 +08:00
|
|
|
target_compile_definitions(${target} PRIVATE NEXTPNR_NAMESPACE=nextpnr_${family} ARCH_${ufamily} ARCHNAME=${family})
|
2019-02-24 01:33:47 +08:00
|
|
|
target_link_libraries(${target} LINK_PUBLIC ${Boost_LIBRARIES} ${link_param})
|
2018-07-16 14:07:57 +08:00
|
|
|
if (NOT MSVC)
|
|
|
|
target_link_libraries(${target} LINK_PUBLIC pthread)
|
|
|
|
endif()
|
2018-06-25 01:32:39 +08:00
|
|
|
add_sanitizers(${target})
|
2018-06-23 20:32:18 +08:00
|
|
|
if (BUILD_GUI)
|
|
|
|
target_include_directories(${target} PRIVATE gui/${family}/ gui/)
|
|
|
|
target_compile_definitions(${target} PRIVATE QT_NO_KEYWORDS)
|
|
|
|
target_link_libraries(${target} LINK_PUBLIC gui_${family} ${GUI_LIBRARY_FILES_${ufamily}})
|
|
|
|
endif()
|
2018-07-02 16:59:25 +08:00
|
|
|
if (BUILD_PYTHON)
|
|
|
|
target_link_libraries(${target} LINK_PUBLIC ${PYTHON_LIBRARIES})
|
2019-09-10 23:12:31 +08:00
|
|
|
if (STATIC_BUILD)
|
2019-10-18 16:19:30 +08:00
|
|
|
target_link_libraries(${target} LINK_PUBLIC ${CMAKE_THREAD_LIBS_INIT} ${CMAKE_DL_LIBS} ${ZLIB_LIBRARIES} ${EXPAT_LIBRARIES})
|
2019-09-10 23:12:31 +08:00
|
|
|
if(${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
2020-05-14 14:35:55 +08:00
|
|
|
elseif(${CMAKE_SYSTEM_NAME} MATCHES "Windows")
|
2019-09-10 23:12:31 +08:00
|
|
|
else()
|
|
|
|
target_link_libraries(${target} LINK_PUBLIC -lutil)
|
|
|
|
endif()
|
|
|
|
endif()
|
2018-07-02 16:59:25 +08:00
|
|
|
endif()
|
2018-06-01 17:58:31 +08:00
|
|
|
endforeach (target)
|
|
|
|
endforeach (family)
|
2018-06-03 06:31:29 +08:00
|
|
|
|
|
|
|
file(GLOB_RECURSE CLANGFORMAT_FILES *.cc *.h)
|
2018-06-03 18:42:06 +08:00
|
|
|
string(REGEX REPLACE "[^;]*/ice40/chipdbs/chipdb-[^;]*.cc" "" CLANGFORMAT_FILES "${CLANGFORMAT_FILES}")
|
2018-07-08 18:56:43 +08:00
|
|
|
string(REGEX REPLACE "[^;]*/ecp5/chipdbs/chipdb-[^;]*.cc" "" CLANGFORMAT_FILES "${CLANGFORMAT_FILES}")
|
2018-06-12 03:36:54 +08:00
|
|
|
string(REGEX REPLACE "[^;]*/3rdparty[^;]*" "" CLANGFORMAT_FILES "${CLANGFORMAT_FILES}")
|
2018-06-13 01:56:03 +08:00
|
|
|
string(REGEX REPLACE "[^;]*/generated[^;]*" "" CLANGFORMAT_FILES "${CLANGFORMAT_FILES}")
|
2018-06-03 06:31:29 +08:00
|
|
|
|
|
|
|
add_custom_target(
|
|
|
|
clangformat
|
|
|
|
COMMAND clang-format
|
|
|
|
-style=file
|
|
|
|
-i
|
|
|
|
${CLANGFORMAT_FILES}
|
|
|
|
)
|