-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
207 lines (154 loc) · 9 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
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
# ********************************************************************************
# * cloudFPGA
# * Copyright 2016 -- 2022 IBM Corporation
# *
# * Licensed under the Apache License, Version 2.0 (the "License");
# * you may not use this file except in compliance with the License.
# * You may obtain a copy of the License at
# *
# * http://www.apache.org/licenses/LICENSE-2.0
# *
# * Unless required by applicable law or agreed to in writing, software
# * distributed under the License is distributed on an "AS IS" BASIS,
# * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# * See the License for the specific language governing permissions and
# * limitations under the License.
# *******************************************************************************
# *
# * Created: Apr 2019
# * Authors: FAB, WEI, NGL, DID
# *
# * Description:
# * Makefile to build a cloudFPGA-project (cFp)
# *
# * Synopsis:
# * make [target] (use 'make help' to list the targets)
# *
# NO HEADING OR TRAILING SPACES!!
SHELL_DIR =$(cFpRootDir)/cFDK/SRA/LIB/SHELL/$(cFpSRAtype)/
ROLE_DIR =$(usedRoleDir)
ROLE2_DIR =$(usedRole2Dir)
CLEAN_TYPES = *.log *.jou *.str *.time
.PHONY: all clean src_based ip_based pr Role ShellSrc pr_full pr2 monolithic ensureNotMonolithic full_clean ensureMonolithic monolithic_incr save_mono_incr save_pr_incr pr_verify assert_env
#.PHONY: pr_full_mpi pr_only_mpi pr2_only_mpi monolithic_mpi monolithic_mpi_incr RoleMPItype RoleMPI2type RoleMPItypeSrc
all: pr
#all: src_based
#OR ip_based, whatever is preferred as default
# assert ENVIRONMENT
assert_env:
./cFDK/SRA/LIB/bash/assert_envs.sh
# next line until including (end of cFa placeholder) MUST STAY UNCHANGED
#cFa addtional targets
# (end of cFa placeholder)
Role: assert_env
$(MAKE) -C $(ROLE_DIR)
Role2: assert_env
$(MAKE) -C $(ROLE2_DIR)
xpr:
mkdir -p $(cFpXprDir)
RoleIp: assert_env
$(MAKE) -C $(ROLE_DIR)/ ip
RoleIp2: assert_env
$(MAKE) -C $(ROLE2_DIR)/ ip
ShellSrc: assert_env
$(MAKE) -C $(SHELL_DIR)
src_based: ensureNotMonolithic ShellSrc Role | xpr #TODO: remove, because obsolete?
$(MAKE) -C ./TOP/tcl/ full_src
pr: ensureNotMonolithic ShellSrc Role | xpr ## Builds Shell (if necessary) and first Role only using PR flow (default)
$(MAKE) -C ./TOP/tcl/ full_src_pr
pr2: ensureNotMonolithic ShellSrc Role2 | xpr ## Builds Shell (if necessary) and second Role only using PR flow
$(MAKE) -C ./TOP/tcl/ full_src_pr_2
pr_full: ensureNotMonolithic ShellSrc Role Role2 | xpr ## Builds Shell (if necessary) and both Roles using PR flow
$(MAKE) -C ./TOP/tcl/ full_src_pr_all
#pr_full_mpi: ensureNotMonolithic ShellSrcMPI RoleMPItype RoleMPI2type | xpr
# export usedRole=$(USED_MPI_ROLE); export usedRole2=$(USED_MPI_ROLE_2); $(MAKE) -C ./TOP/tcl/ full_src_pr_all_mpi
#pr_incr: ensureNotMonolithic ShellSrc Role | xpr
# export usedRole=$(USED_ROLE); export usedRole2=$(USED_ROLE_2); $(MAKE) -C ./TOP/tcl/ full_src_pr_incr
# incremental compile seems not to work with second run
#pr2_incr: ensureNotMonolithic ShellSrc Role2 | xpr
# export usedRole=$(USED_ROLE); export usedRole2=$(USED_ROLE_2); $(MAKE) -C ./TOP/tcl/ full_src_pr_2_incr
#pr_full_incr: ensureNotMonolithic ShellSrc Role Role2 | xpr
# export usedRole=$(USED_ROLE); export usedRole2=$(USED_ROLE_2); $(MAKE) -C ./TOP/tcl/ full_src_pr_all_incr
pr_only: ensureNotMonolithic Role | xpr ## Building partial bitifle for Role 1 (if Shell.dcp is present)
$(MAKE) -C ./TOP/tcl/ full_src_pr_only
pr2_only: ensureNotMonolithic Role2 | xpr ## Building partial bitifle for Role 2 (if Shell.dcp is present)
$(MAKE) -C ./TOP/tcl/ full_src_pr_2_only
#pr_only_mpi: ensureNotMonolithic RoleMPItype | xpr
# export usedRole=$(USED_MPI_ROLE); export usedRole2=$(USED_MPI_ROLE_2); $(MAKE) -C ./TOP/tcl/ full_src_pr_only_mpi
#
#pr2_only_mpi: ensureNotMonolithic RoleMPI2type | xpr
# export usedRole=$(USED_MPI_ROLE); export usedRole2=$(USED_MPI_ROLE_2); $(MAKE) -C ./TOP/tcl/ full_src_pr_2_only_mpi
#pr_incr_only: ensureNotMonolithic Role | xpr
# export usedRole=$(USED_ROLE); export usedRole2=$(USED_ROLE_2); $(MAKE) -C ./TOP/tcl/ full_src_pr_incr_only
# incremental compile seems not to work with second run
#pr2_incr_only: ensureNotMonolithic Role2 | xpr
# export usedRole=$(USED_ROLE); export usedRole2=$(USED_ROLE_2); $(MAKE) -C ./TOP/tcl/ full_src_pr_2_incr_only
ip_based:
$(error NOT YET IMPLEMENTED)
#no ROLE, because Role is synthezied with sources!
monolithic: ensureMonolithic ShellSrc RoleIp | xpr ## Default build when PR is not used.
@echo "this project was startet without Black Box flow => until you clean up, there is no other flow possible" > ./xpr/.project_monolithic.lock
@#export usedRole=$(USED_ROLE); cd tcl; vivado -mode batch -source handle_vivado.tcl -notrace -log handle_vivado.log -tclargs -full_src -force -forceWithoutBB -role -create -synth -impl -bitgen
$(MAKE) -C ./TOP/tcl/ monolithic
#no ROLE, because Role is synthezied with sources!
monolithic_incr: ensureMonolithic ShellSrc RoleIp | xpr ## Default incremental build.
@echo "this project was startet without Black Box flow => until you clean up, there is no other flow possible" > ./xpr/.project_monolithic.lock
$(MAKE) -C ./TOP/tcl/ monolithic_incr
monolithic_debug: ensureMonolithic ensureDebugNets ShellSrc RoleIp | xpr ## Default build to include a debug probe.
@echo "this project was startet without Black Box flow => until you clean up, there is no other flow possible" > ./xpr/.project_monolithic.lock
$(MAKE) -C ./TOP/tcl/ monolithic_debug
monolithic_incr_debug: ensureMonolithic ensureDebugNets ShellSrc RoleIp | xpr ## Default incremental build to include a debug probe..
@echo "this project was startet without Black Box flow => until you clean up, there is no other flow possible" > ./xpr/.project_monolithic.lock
$(MAKE) -C ./TOP/tcl/ monolithic_incr_debug
monolithic_proj: ensureMonolithic | xpr ## Only creates a new Vivado project (only works after a clean; does not take dependencies into account)
$(MAKE) -C ./TOP/tcl/ monolithic_proj
##no ROLE, because Role is synthezied with sources!
#monolithic_mpi: ensureMonolithic ShellSrcMPI RoleMPItypeSrc | xpr
# @echo "this project was startet without Black Box flow => until you clean up, there is no other flow possible" > ./xpr/.project_monolithic.lock
# export usedRole=$(USED_MPI_ROLE); $(MAKE) -C ./TOP/tcl/ monolithic_mpi
#
##no ROLE, because Role is synthezied with sources!
#monolithic_mpi_incr: ensureMonolithic ShellSrcMPI RoleMPItypeSrc | xpr
# @echo "this project was startet without Black Box flow => until you clean up, there is no other flow possible" > ./xpr/.project_monolithic.lock
# export usedRole=$(USED_MPI_ROLE); $(MAKE) -C ./TOP/tcl/ monolithic_incr_mpi
save_mono_incr: ensureMonolithic ## Saves the current monolithic for use in further incremental builds.
export usedRole=$(USED_ROLE); $(MAKE) -C ./TOP/tcl/ save_mono_incr
#save_mono_mpi_incr: ensureMonolithic
# export usedRole=$(USED_MPI_ROLE); $(MAKE) -C ./TOP/tcl/ save_mono_incr
#save_pr_incr:
# $(error THIS IS DONE AUTOMATICALLY DURING THE FLOW)
pr_verify: assert_env
$(MAKE) -C ./TOP/tcl/ pr_verify
ensureNotMonolithic: assert_env | xpr
@test ! -f ./xpr/.project_monolithic.lock || (cat ./xpr/.project_monolithic.lock && exit 1)
ensureMonolithic: assert_env
@test -f ./xpr/.project_monolithic.lock || test ! -d ./xpr/ || (echo "This project was startet with Black Box flow => please clean up first" && exit 1)
ensureDebugNets: assert_env
@test -f ./TOP/xdc/.DEBUG_SWITCH || /bin/echo -e "This file is a guard for handle_vivado.tcl and should prevent the failure of a build process\nbecuase the make target monolithic_debug is called but the debug nets aren't defined in\n<Top>/TOP/xdc/debug.xdc .\nThis must be done once manually in the Gui and then write "YES" in the last line of this file.\n(It must stay the last line...)\n\nHave you defined the debug nets etc. in <Top>/xdc/debug.xdc?\nNO" > ./TOP/xdc/.DEBUG_SWITCH
@test `tail -n 1 ./TOP/xdc/.DEBUG_SWITCH` = YES || (echo "Please define debug nets in ./TOP/xdc/debug.xdc and answer the question in ./TOP/xdc/.DEBUG_SWITCH" && exit 1)
clean: ## Cleans the current cFp project (.i.e this TOP)
$(MAKE) -C ./TOP/tcl/ clean
rm -rf $(CLEAN_TYPES)
rm -rf ./xpr/ ./hd_visual/
rm -rf ./dcps/
rm -rf ./docs/
# rm -rf ./xdc/.DEBUG_SWITCH
full_clean: clean ## Cleans the entire cFp structure (.i.e TOP, SHELL and ROLE).
$(MAKE) -C $(SHELL_DIR) clean
$(MAKE) -C $(ROLE_DIR) clean
$(MAKE) -C $(ROLE2_DIR) clean
rm -rf ./TOP/xdc/.DEBUG_SWITCH
doxygen:
doxygen Doxyfile
print-%: ## A little make receipt to print a variable (usage example --> 'make print-SHELL_DIR')
@echo $* = $($*)
help: ## Shows this help message
# This target is for self documentation of the Makefile.
# Every text starting with '##' and placed after a target will be considered as helper text.
@echo
@echo 'Usage:'
@echo ' make [target]'
@echo
@echo 'Targets:'
@cat ${MAKEFILE_LIST} | egrep '^(.+)\:(.+)##\ (.+)' | column -s ':#' | sed 's/:.*#/||/' | column -s '||' -t | sed -e 's/^/ /'
@echo