Newer
Older
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
# VTA Driver
CC ?= g++
CFLAGS = -Wall -O3 -std=c++11 -I/usr/include -DNO_SIM
LDFLAGS = -L/usr/lib -L/opt/python3.6/lib/python3.6/site-packages/pynq/lib/
LIBS = -l:libsds_lib.so -l:libdma.so -lstdc++
SRC_DIR = src/
DRIVER_DIR = driver/
VPATH = $(SRC_DIR) $(DRIVER_DIR)
SOURCES = pynq_driver.cc test_lib.cc
OBJECTS = pynq_driver.o test_lib.o vta_test.o
EXECUTABLE = vta
# Directories
ROOTDIR = $(CURDIR)
BUILD_DIR = $(ROOTDIR)/build
SCRIPT_DIR = $(ROOTDIR)/scripts
SRC_DIR = $(ROOTDIR)/src
# Executables
VIVADO_HLS = vivado_hls
VIVADO = vivado
HSI = hsi
# Derive config name
IP_BUILD_PATH = $(BUILD_DIR)/hls
HW_BUILD_PATH = $(BUILD_DIR)/vivado
# HLS report path
RPT_PATH = $(IP_BUILD_PATH)/vta/solution0/syn/report/vta_csynth.rpt
# IP file path
IP_PATH = $(IP_BUILD_PATH)/vta/solution0/impl/ip/xilinx_com_hls_vta_1_0.zip
# Bitstream file path
BIT_PATH = $(BUILD_DIR)/vta/export/vta.bit
.PHONY: all sim rpt ip bit bsp exe
all: bsp
# Generate HLS report only
rpt: $(RPT_PATH)
# Build IP only
ip: $(IP_PATH)
# Build bitstream only
bit: $(BIT_PATH)
# Build the Pynq executable
exe: $(EXECUTABLE)
sim: $(SRC_DIR)/*
mkdir -p $(IP_BUILD_PATH)
cd $(IP_BUILD_PATH) && \
$(VIVADO_HLS) -f $(SCRIPT_DIR)/hls.tcl
$(RPT_PATH): $(SRC_DIR)/*
mkdir -p $(IP_BUILD_PATH)
cd $(IP_BUILD_PATH) && \
$(VIVADO_HLS) -f $(SCRIPT_DIR)/hls.tcl -tclargs "rpt"
$(IP_PATH): $(SRC_DIR)/*
mkdir -p $(IP_BUILD_PATH)
cd $(IP_BUILD_PATH) && \
$(VIVADO_HLS) -f $(SCRIPT_DIR)/hls.tcl -tclargs "ip"
$(BIT_PATH): $(IP_PATH)
mkdir -p $(HW_BUILD_PATH)
cd $(HW_BUILD_PATH) && \
$(VIVADO) -mode tcl -source $(SCRIPT_DIR)/vivado.tcl
bsp: $(BIT_PATH)
cd $(HW_BUILD_PATH) && $(HSI) -mode tcl -source $(SCRIPT_DIR)/hsi.tcl -nojournal -nolog
cd $(HW_BUILD_PATH)/bsp && make
%.o: %.cc $(SOURCES)
$(CC) -c -o $@ $< $(CFLAGS)
$(EXECUTABLE): $(OBJECTS)
$(CC) $(LDFLAGS) $(OBJECTS) -o $@ $(LIBS)
clean:
rm -rf $(BUILD_DIR) $(EXECUTABLE) *.log *.o