-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCMakeLists.txt
More file actions
58 lines (49 loc) · 1.84 KB
/
CMakeLists.txt
File metadata and controls
58 lines (49 loc) · 1.84 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
cmake_minimum_required(VERSION 3.14)
project(leda)
set(PLATFORM
xilinx_u280_xdma_201920_3
CACHE STRING "Target FPGA platform")
set(CMAKE_CXX_FLAGS "${CMAKE_C_FLAGS} -Wno-write-strings")
find_package(TAPA REQUIRED)
find_package(SDx REQUIRED)
find_package(OpenMP REQUIRED)
add_executable(leda)
target_sources(leda PRIVATE src/leda_host.cpp src/leda.cpp)
target_link_libraries(leda PRIVATE tapa::tapa)
target_link_libraries(leda PUBLIC OpenMP::OpenMP_CXX)
add_tapa_target(
hls
--enable-synth-util
INPUT src/leda.cpp
TOP Leda
CONNECTIVITY ${CMAKE_CURRENT_SOURCE_DIR}/link_config_4.ini
CONSTRAINT ${CMAKE_CURRENT_BINARY_DIR}/constraint.tcl
--enable-hbm-binding-adjustment
--read-only-args SpElement_list_ptr
--read-only-args Matrix_A_data*
--read-only-args Matrix_B_data*
--write-only-args Matrix_C_data*
--max-slr-width-limit 11000
PLATFORM ${PLATFORM})
add_xocc_hw_link_targets(
${CMAKE_CURRENT_BINARY_DIR}
--config=${CMAKE_CURRENT_SOURCE_DIR}/link_config_4.ini
--vivado.prop run.impl_1.STEPS.PHYS_OPT_DESIGN.is_enabled=1
--vivado.prop run.impl_1.STEPS.OPT_DESIGN.ARGS.DIRECTIVE=Explore
--vivado.prop run.impl_1.STEPS.PLACE_DESIGN.ARGS.DIRECTIVE=EarlyBlockPlacement
--vivado.prop run.impl_1.STEPS.PHYS_OPT_DESIGN.ARGS.DIRECTIVE=Explore
--vivado.prop run.impl_1.STEPS.ROUTE_DESIGN.ARGS.DIRECTIVE=Explore
--vivado.prop run.impl_1.STEPS.OPT_DESIGN.TCL.PRE=${CMAKE_CURRENT_BINARY_DIR}/constraint.tcl
INPUT hls
HW_EMU_XCLBIN hw_emu_xclbin
HW_XCLBIN hw_xclbin)
add_custom_target(
swsim
COMMAND $<TARGET_FILE:leda> ../matrices/G55/G55.mtx 8 1
DEPENDS leda
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR})
add_custom_target(
hwsim
COMMAND BITFILE=$<TARGET_PROPERTY:${hw_emu_xclbin},FILE_NAME> $<TARGET_FILE:leda> ../matrices/G55/G55.mtx 8 1
DEPENDS leda ${hw_emu_xclbin}
WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR})