2020-06-26 08:13:11 +08:00
|
|
|
cmake_minimum_required(VERSION 3.5)
|
|
|
|
project(chipdb-machxo2 NONE)
|
|
|
|
|
2023-03-17 00:34:52 +08:00
|
|
|
set(ALL_MACHXO2_DEVICES 256X 640X 1200X 2280X 256 640 1200 2000 4000 7000 1300 2100 4300 6900 9400 4300D 9400D)
|
|
|
|
set(MACHXO2_DEVICES 1200 6900 CACHE STRING
|
|
|
|
"Include support for these MachXO2/XO3 devices (available: ${ALL_MACHXO2_DEVICES})")
|
|
|
|
message(STATUS "Enabled MachXO2/XO3 devices: ${MACHXO2_DEVICES}")
|
2020-06-26 08:13:11 +08:00
|
|
|
|
|
|
|
if(DEFINED MACHXO2_CHIPDB)
|
|
|
|
add_custom_target(chipdb-machxo2-bbas ALL)
|
|
|
|
else()
|
|
|
|
# shared among all families
|
|
|
|
set(SERIALIZE_CHIPDBS TRUE CACHE BOOL
|
|
|
|
"Serialize device data preprocessing to minimize memory use")
|
|
|
|
|
|
|
|
set(TRELLIS_PROGRAM_PREFIX "" CACHE STRING
|
|
|
|
"Trellis name prefix")
|
|
|
|
if(TRELLIS_PROGRAM_PREFIX)
|
|
|
|
message(STATUS "Trellis program prefix: ${TRELLIS_PROGRAM_PREFIX}")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
set(TRELLIS_INSTALL_PREFIX ${CMAKE_INSTALL_PREFIX} CACHE STRING
|
|
|
|
"Trellis install prefix")
|
|
|
|
message(STATUS "Trellis install prefix: ${TRELLIS_INSTALL_PREFIX}")
|
|
|
|
|
2023-04-02 18:21:26 +08:00
|
|
|
if(NOT TRELLIS_LIBDIR)
|
|
|
|
# The pytrellis library isn't a normal shared library, but rather a native Python library;
|
|
|
|
# it does not follow the normal platform conventions for shared libraries, so we can't just
|
|
|
|
# use find_library() here. Instead, we emulate the useful parts of the find_library() logic
|
|
|
|
# for use with find_path().
|
|
|
|
set(pytrellis_paths)
|
|
|
|
foreach(prefix_path ${CMAKE_PREFIX_PATH})
|
|
|
|
list(APPEND pytrellis_paths ${prefix_path}/lib)
|
|
|
|
if(CMAKE_LIBRARY_ARCHITECTURE)
|
|
|
|
list(APPEND pytrellis_paths ${prefix_path}/lib/${CMAKE_LIBRARY_ARCHITECTURE})
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
list(APPEND pytrellis_paths ${CMAKE_LIBRARY_PATH})
|
|
|
|
if(NOT NO_CMAKE_SYSTEM_PATH)
|
|
|
|
foreach(prefix_path ${CMAKE_SYSTEM_PREFIX_PATH})
|
|
|
|
list(APPEND pytrellis_paths ${prefix_path}/lib)
|
|
|
|
if(CMAKE_LIBRARY_ARCHITECTURE)
|
|
|
|
list(APPEND pytrellis_paths ${prefix_path}/lib/${CMAKE_LIBRARY_ARCHITECTURE})
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
list(APPEND pytrellis_paths ${CMAKE_SYSTEM_LIBRARY_PATH})
|
|
|
|
endif()
|
|
|
|
message(STATUS "Searching for pytrellis in: ${pytrellis_paths}")
|
|
|
|
|
2020-06-26 08:13:11 +08:00
|
|
|
if(WIN32)
|
|
|
|
set(pytrellis_lib pytrellis.pyd)
|
|
|
|
else()
|
2023-04-02 18:21:26 +08:00
|
|
|
set(pytrellis_lib pytrellis${CMAKE_SHARED_MODULE_SUFFIX})
|
2020-06-26 08:13:11 +08:00
|
|
|
endif()
|
2023-04-02 18:21:26 +08:00
|
|
|
|
2020-06-26 08:13:11 +08:00
|
|
|
find_path(TRELLIS_LIBDIR ${pytrellis_lib}
|
|
|
|
HINTS ${TRELLIS_INSTALL_PREFIX}/lib/${TRELLIS_PROGRAM_PREFIX}trellis
|
2023-04-02 18:21:26 +08:00
|
|
|
PATHS ${pytrellis_paths}
|
2020-06-26 08:13:11 +08:00
|
|
|
PATH_SUFFIXES ${TRELLIS_PROGRAM_PREFIX}trellis
|
|
|
|
DOC "Location of the pytrellis library")
|
|
|
|
if(NOT TRELLIS_LIBDIR)
|
|
|
|
message(FATAL_ERROR "Failed to locate the pytrellis library")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
message(STATUS "Trellis library directory: ${TRELLIS_LIBDIR}")
|
|
|
|
|
2023-04-02 18:21:26 +08:00
|
|
|
if(NOT TRELLIS_DATADIR)
|
2020-06-26 08:13:11 +08:00
|
|
|
set(TRELLIS_DATADIR ${TRELLIS_INSTALL_PREFIX}/share/${TRELLIS_PROGRAM_PREFIX}trellis)
|
|
|
|
endif()
|
|
|
|
message(STATUS "Trellis data directory: ${TRELLIS_DATADIR}")
|
|
|
|
|
|
|
|
set(all_device_bbas)
|
|
|
|
file(MAKE_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/chipdb)
|
|
|
|
foreach(device ${MACHXO2_DEVICES})
|
|
|
|
if(NOT device IN_LIST ALL_MACHXO2_DEVICES)
|
2023-03-17 00:34:52 +08:00
|
|
|
message(FATAL_ERROR "Device ${device} is not a supported MachXO2/XO3 device")
|
2020-06-26 08:13:11 +08:00
|
|
|
endif()
|
|
|
|
|
|
|
|
set(device_bba chipdb/chipdb-${device}.bba)
|
|
|
|
add_custom_command(
|
|
|
|
OUTPUT ${device_bba}
|
2022-08-22 00:47:35 +08:00
|
|
|
COMMAND ${Python3_EXECUTABLE} ${CMAKE_CURRENT_SOURCE_DIR}/facade_import.py
|
2020-06-26 08:13:11 +08:00
|
|
|
-L ${TRELLIS_LIBDIR}
|
|
|
|
-L ${TRELLIS_DATADIR}/util/common
|
|
|
|
-L ${TRELLIS_DATADIR}/timing/util
|
|
|
|
-p ${CMAKE_CURRENT_SOURCE_DIR}/constids.inc
|
2023-03-10 22:29:59 +08:00
|
|
|
-g ${CMAKE_CURRENT_SOURCE_DIR}/gfx.h
|
2020-06-26 08:13:11 +08:00
|
|
|
${device}
|
|
|
|
> ${device_bba}.new
|
|
|
|
# atomically update
|
|
|
|
COMMAND ${CMAKE_COMMAND} -E rename ${device_bba}.new ${device_bba}
|
|
|
|
DEPENDS
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/facade_import.py
|
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/constids.inc
|
2023-03-10 22:29:59 +08:00
|
|
|
${CMAKE_CURRENT_SOURCE_DIR}/gfx.h
|
2020-06-26 08:13:11 +08:00
|
|
|
${PREVIOUS_CHIPDB_TARGET}
|
|
|
|
VERBATIM)
|
|
|
|
list(APPEND all_device_bbas ${device_bba})
|
|
|
|
if(SERIALIZE_CHIPDBS)
|
|
|
|
set(PREVIOUS_CHIPDB_TARGET ${CMAKE_CURRENT_BINARY_DIR}/${device_bba})
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
add_custom_target(chipdb-machxo2-bbas ALL DEPENDS ${all_device_bbas})
|
|
|
|
|
|
|
|
get_directory_property(has_parent PARENT_DIRECTORY)
|
|
|
|
if(has_parent)
|
|
|
|
set(MACHXO2_CHIPDB ${CMAKE_CURRENT_BINARY_DIR}/chipdb PARENT_SCOPE)
|
|
|
|
# serialize chipdb build across multiple architectures
|
|
|
|
set(PREVIOUS_CHIPDB_TARGET chipdb-machxo2-bbas PARENT_SCOPE)
|
|
|
|
else()
|
|
|
|
message(STATUS "Build nextpnr with -DMACHXO2_CHIPDB=${CMAKE_CURRENT_BINARY_DIR}")
|
|
|
|
endif()
|
|
|
|
endif()
|