2021-02-11 23:24:49 +01:00
|
|
|
find_package(TCL)
|
|
|
|
|
if(NOT ${TCL_FOUND})
|
|
|
|
|
message(FATAL_ERROR "Tcl is required for FPGA interchange Arch.")
|
|
|
|
|
endif()
|
|
|
|
|
|
2021-02-13 01:12:16 +01:00
|
|
|
find_package(ZLIB REQUIRED)
|
|
|
|
|
|
2021-03-12 12:25:41 +01:00
|
|
|
set(RAPIDWRIGHT_PATH $ENV{HOME}/RapidWright CACHE PATH "Path to RapidWright")
|
2021-03-18 20:37:51 +01:00
|
|
|
set(INVOKE_RAPIDWRIGHT "${RAPIDWRIGHT_PATH}/scripts/invoke_rapidwright.sh" CACHE PATH "Path to RapidWright invocation script")
|
|
|
|
|
set(JAVA_HEAP_SPACE "-Xmx8g" CACHE STRING "Heap space reserved for Java")
|
2021-03-24 14:17:12 +01:00
|
|
|
set(PRJOXIDE_PREFIX $ENV{HOME}/.cargo CACHE PATH "prjoxide install prefix")
|
|
|
|
|
|
2021-03-12 12:25:41 +01:00
|
|
|
# FIXME: Make patch data available in the python package and remove this cached var
|
|
|
|
|
set(PYTHON_INTERCHANGE_PATH $ENV{HOME}/python-fpga-interchange CACHE PATH "Path to the FPGA interchange python library")
|
2021-03-20 02:28:48 +01:00
|
|
|
set(INTERCHANGE_SCHEMA_PATH ${PROJECT_SOURCE_DIR}/3rdparty/fpga-interchange-schema/interchange CACHE PATH "Path to the FPGA interchange schema dir")
|
2021-03-12 12:25:41 +01:00
|
|
|
|
2021-02-15 18:07:23 +01:00
|
|
|
add_subdirectory(3rdparty/fpga-interchange-schema/cmake/cxx_static)
|
2021-03-12 20:04:51 +01:00
|
|
|
|
2021-03-12 12:25:41 +01:00
|
|
|
include(${family}/examples/chipdb.cmake)
|
2021-03-23 20:35:53 +01:00
|
|
|
include(${family}/examples/boards.cmake)
|
2021-03-12 12:25:41 +01:00
|
|
|
include(${family}/examples/tests.cmake)
|
2021-02-13 01:12:16 +01:00
|
|
|
|
2021-03-12 20:04:51 +01:00
|
|
|
set(chipdb_dir ${CMAKE_CURRENT_BINARY_DIR}/${family}/chipdb)
|
|
|
|
|
file(MAKE_DIRECTORY ${chipdb_dir})
|
|
|
|
|
|
|
|
|
|
add_custom_target(all-${family}-tests)
|
2021-04-07 12:07:10 +02:00
|
|
|
add_custom_target(all-${family}-fasm)
|
2021-03-16 21:49:06 +01:00
|
|
|
add_custom_target(all-${family}-archcheck-tests)
|
2021-03-12 20:04:51 +01:00
|
|
|
add_subdirectory(${family}/examples/devices)
|
2021-03-23 20:35:53 +01:00
|
|
|
add_subdirectory(${family}/examples/boards)
|
2021-03-12 20:04:51 +01:00
|
|
|
add_subdirectory(${family}/examples/tests)
|
|
|
|
|
|
2021-03-23 01:46:00 +01:00
|
|
|
set(PROTOS lookahead.capnp)
|
|
|
|
|
set(CAPNP_SRCS)
|
|
|
|
|
set(CAPNP_HDRS)
|
|
|
|
|
find_package(CapnProto REQUIRED)
|
|
|
|
|
foreach (proto ${PROTOS})
|
|
|
|
|
capnp_generate_cpp(CAPNP_SRC CAPNP_HDR fpga_interchange/${proto})
|
|
|
|
|
list(APPEND CAPNP_HDRS ${CAPNP_HDR})
|
|
|
|
|
list(APPEND CAPNP_SRCS ${CAPNP_SRC})
|
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
|
|
add_library(extra_capnp STATIC ${CAPNP_SRCS})
|
|
|
|
|
target_link_libraries(extra_capnp PRIVATE CapnProto::capnp)
|
|
|
|
|
|
|
|
|
|
target_include_directories(extra_capnp INTERFACE ${CMAKE_CURRENT_BINARY_DIR}/fpga_interchange)
|
|
|
|
|
|
2021-02-11 23:24:49 +01:00
|
|
|
foreach (target ${family_targets})
|
2021-02-13 01:12:16 +01:00
|
|
|
target_include_directories(${target} PRIVATE ${TCL_INCLUDE_PATH})
|
|
|
|
|
target_link_libraries(${target} PRIVATE ${TCL_LIBRARY})
|
|
|
|
|
target_link_libraries(${target} PRIVATE fpga_interchange_capnp)
|
2021-03-23 01:46:00 +01:00
|
|
|
target_link_libraries(${target} PRIVATE extra_capnp)
|
2021-02-13 01:12:16 +01:00
|
|
|
target_link_libraries(${target} PRIVATE z)
|
2021-02-11 23:24:49 +01:00
|
|
|
endforeach()
|
2021-03-18 21:47:06 +01:00
|
|
|
|
|
|
|
|
if(BUILD_GUI)
|
|
|
|
|
target_link_libraries(gui_${family} fpga_interchange_capnp)
|
2021-03-23 01:46:00 +01:00
|
|
|
target_link_libraries(gui_${family} extra_capnp)
|
2021-03-18 21:47:06 +01:00
|
|
|
target_link_libraries(gui_${family} z)
|
|
|
|
|
endif()
|
2021-06-09 18:25:21 +02:00
|
|
|
if (BUILD_TESTS)
|
|
|
|
|
add_subdirectory(tests/${family}/site_router_tests)
|
|
|
|
|
endif()
|