forked from pc2/stream-fpga
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
executable file
·133 lines (107 loc) · 4.64 KB
/
Makefile
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
##
# Author: Marius Meyer
# eMail: marius.meyer@upb.de
# Date: 2019/04/05
#
# This makefile compiles the STREAM benchmark for FPGA and its OpenCL kernels.
# Currently only the Intel(R) FPGA SDK for OpenCL(TM) utitlity is supported.
#
# Please read the README contained in this folder for more information and
# instructions how to compile and execute the benchmark.
# Used compilers for C code and OpenCL kernels
CXX := g++ --std=c++11
AOC := aoc
AOCL := aocl
MKDIR_P := mkdir -p
$(info ***************************)
$(info Collected information)
# Check Quartus version
ifndef QUARTUS_VERSION
$(error QUARTUS_VERSION not defined! Quartus seems not to be set up correctly)
else
$(info QUARTUS_VERSION = $(QUARTUS_VERSION))
endif
QUARTUS_MAJOR_VERSION := $(shell echo $(QUARTUS_VERSION) | cut -d "." -f 1)
# OpenCL compile and link flags.
AOCL_COMPILE_CONFIG := $(shell $(AOCL) compile-config )
AOCL_LINK_CONFIG := $(shell $(AOCL) link-config )
KERNEL_SRCS := stream_kernels.cl
KERNEL_INPUTS = $(KERNEL_SRCS:.cl=.aocx)
STREAM_ARRAY_SIZE := 50000000
BOARD := p520_max_sg280l
STREAM_TYPE := double
UNROLL_COUNT := 8
OFFSET := 0
NTIMES := 10
BIN_DIR := bin/
ifdef BUILD_SUFFIX
$(info BUILD_SUFFIX = $(BUILD_SUFFIX))
EXT_BUILD_SUFFIX := _$(BUILD_SUFFIX)
endif
##
# Change aoc params to the ones desired (emulation,simulation,synthesis).
#
#AOC_PARAMS := -march=emulator
AOC_PARAMS := -board=$(BOARD) -DSTREAM_TYPE=$(STREAM_TYPE) -DUNROLL_COUNT=$(UNROLL_COUNT)
SRCS := stream_fpga.cpp
TARGET := $(SRCS:.cpp=)$(EXT_BUILD_SUFFIX)
KERNEL_TARGET := $(KERNEL_SRCS:.cl=)$(EXT_BUILD_SUFFIX)
COMMON_FLAGS := -DQUARTUS_MAJOR_VERSION=$(QUARTUS_MAJOR_VERSION)
HOST_FLAGS := -DSTREAM_FPGA_KERNEL=\"$(KERNEL_TARGET).aocx\" -DSTREAM_TYPE=cl_$(STREAM_TYPE) -DOFFSET=$(OFFSET) -DSTREAM_ARRAY_SIZE=$(STREAM_ARRAY_SIZE) -DNTIMES=$(NTIMES)
$(info BOARD = $(BOARD))
$(info TARGET = $(TARGET))
$(info KERNEL_TARGET = $(KERNEL_TARGET).aocx)
$(info STREAM_ARRAY_SIZE = $(STREAM_ARRAY_SIZE))
$(info STREAM_TYPE = $(STREAM_TYPE))
$(info UNROLL_COUNT = $(UNROLL_COUNT))
$(info NTIMES = $(NTIMES))
$(info OFFSET = $(OFFSET))
$(info ***************************)
default: info
$(error No target specified)
info:
$(info *************************************************)
$(info Please specify one ore more of the listed targets)
$(info *************************************************)
$(info Host Code:)
$(info no_interleave_host = Host that is trying to put every array on a separate memory bank on the FPGA)
$(info host = Use memory interleaving to store the arrays on the FPGA)
$(info *************************************************)
$(info Kernels:)
$(info kernel = Compile kernels without special flags)
$(info emulate_kernel = Compile kernels for emulation)
$(info kernel_profile = Compile kernels with profiling information enabled)
$(info no_interleave_kernel = Compile kernels without memory interleaving)
$(info no_interleave_kernel_profile = Compile kernels without memory interleaving and profiling information enabled)
$(info ************************************************)
$(info info = Print this list of available targets)
$(info ************************************************)
host:
$(MKDIR_P) $(BIN_DIR)
$(CXX) $(COMMON_FLAGS) $(HOST_FLAGS) \
$(AOCL_COMPILE_CONFIG) $(SRCS) $(AOCL_LINK_CONFIG) -o $(BIN_DIR)$(TARGET)
no_interleave_host:
$(MKDIR_P) $(BIN_DIR)
$(CXX) $(COMMON_FLAGS) $(HOST_FLAGS) \
-DNO_INTERLEAVING $(AOCL_COMPILE_CONFIG) $(SRCS) $(AOCL_LINK_CONFIG) -o $(BIN_DIR)$(TARGET)_no_interleaving
kernel: $(KERNEL_SRCS)
$(MKDIR_P) $(BIN_DIR)
$(AOC) $(AOC_PARAMS) $(COMMON_FLAGS) -o $(BIN_DIR)$(KERNEL_TARGET) $(KERNEL_SRCS)
emulate_kernel: $(KERNEL_SRCS)
$(MKDIR_P) $(BIN_DIR)
$(AOC) $(AOC_PARAMS) -march=emulator -o $(BIN_DIR)$(KERNEL_TARGET)_emulate $(KERNEL_SRCS)
kernel_profile: $(KERNEL_SRCS)
$(MKDIR_P) $(BIN_DIR)
$(AOC) $(AOC_PARAMS) $(COMMON_FLAGS) -profile -o $(BIN_DIR)$(KERNEL_TARGET)_profile $(KERNEL_SRCS)
no_interleave_kernel_profile: $(KERNEL_SRCS)
$(MKDIR_P) $(BIN_DIR)
$(AOC) $(AOC_PARAMS) $(COMMON_FLAGS) -profile -no-interleaving=default -o $(BIN_DIR)$(KERNEL_TARGET)_profile_no_interleaving $(KERNEL_SRCS)
no_interleave_kernel: $(KERNEL_SRCS)
$(MKDIR_P) $(BIN_DIR)
$(AOC) $(AOC_PARAMS) $(COMMON_FLAGS) -no-interleaving=default -o $(BIN_DIR)$(KERNEL_TARGET)_no_interleaving $(KERNEL_SRCS)
cleanhost:
rm -f $(BIN_DIR)$(TARGET)
cleanall: cleanhost
rm -f *.aoco *.aocr *.aocx *.source
rm -rf $(KERNEL_SRCS:.cl=)
rm -rf $(BIN_DIR)