
This fully preserves existing functionality, although the `embed` mode is untested and seems broken.
25 lines
960 B
CMake
25 lines
960 B
CMake
add_subdirectory(${family})
|
|
message(STATUS "Using MachXO2/XO3 chipdb: ${MACHXO2_CHIPDB}")
|
|
|
|
add_library(chipdb-${family} OBJECT)
|
|
target_compile_options(chipdb-${family} PRIVATE -w -g0 -O0)
|
|
target_compile_definitions(chipdb-${family} PRIVATE NEXTPNR_NAMESPACE=nextpnr_${family})
|
|
target_include_directories(chipdb-${family} PRIVATE ${family})
|
|
|
|
configure_file(${family}/machxo2_available.h.in ${CMAKE_CURRENT_BINARY_DIR}/generated/machxo2_available.h)
|
|
target_sources(chipdb-${family} PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/generated/machxo2_available.h)
|
|
|
|
foreach (family_target ${family_targets})
|
|
target_link_libraries(${family_target} PRIVATE chipdb-${family})
|
|
endforeach()
|
|
|
|
foreach (device ${MACHXO2_DEVICES})
|
|
add_bba_compile_command(
|
|
DEPENDS chipdb-${family}-bbas
|
|
TARGET chipdb-${family}
|
|
OUTPUT ${family}/chipdb-${device}.bin
|
|
INPUT ${MACHXO2_CHIPDB}/chipdb-${device}.bba
|
|
MODE ${BBASM_MODE}
|
|
)
|
|
endforeach()
|