-
Notifications
You must be signed in to change notification settings - Fork 34
/
Copy pathsystem_vivado.mk
369 lines (314 loc) · 12.9 KB
/
system_vivado.mk
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
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
##############################################################################
## This file is part of 'SLAC Firmware Standard Library'.
## It is subject to the license terms in the LICENSE.txt file found in the
## top-level directory of this distribution and at:
## https://confluence.slac.stanford.edu/display/ppareg/LICENSE.html.
## No part of 'SLAC Firmware Standard Library', including this file,
## may be copied, modified, propagated, or distributed except according to
## the terms contained in the LICENSE.txt file.
##############################################################################
ifndef PROJECT
export PROJECT = $(notdir $(PWD))
endif
ifndef PROJ_DIR
export PROJ_DIR = $(abspath $(PWD))
endif
ifndef TOP_DIR
export TOP_DIR = $(abspath $(PROJ_DIR)/../..)
endif
ifndef RELEASE_DIR
export RELEASE_DIR = $(TOP_DIR)/release
endif
ifndef MODULES
export MODULES = $(TOP_DIR)/submodules
endif
ifndef REMOVE_UNUSED_CODE
export REMOVE_UNUSED_CODE = 0
endif
ifndef PARALLEL_SYNTH
export PARALLEL_SYNTH = $(shell cat /proc/cpuinfo | grep processor | wc -l)
endif
ifndef GIT_BYPASS
export GIT_BYPASS = 1
endif
ifndef GZIP_BUILD_IMAGE
export GZIP_BUILD_IMAGE = 1
endif
ifndef GEN_BIN_IMAGE
export GEN_BIN_IMAGE = 0
endif
ifndef RECONFIG_CHECKPOINT
export RECONFIG_CHECKPOINT = 0
export RECONFIG_STATIC_HASH = 0
else
export RECONFIG_STATIC_FILE = $(notdir $(RECONFIG_CHECKPOINT))
export RECONFIG_STATIC_HASH = -$(shell echo '$(RECONFIG_STATIC_FILE)' | awk -F'-' '{print $$5}' )
endif
ifndef RECONFIG_ENDPOINT
export RECONFIG_ENDPOINT = 0
endif
ifndef RECONFIG_PBLOCK
export RECONFIG_PBLOCK = 0
endif
# Vivado Simulation Variables
ifndef VIVADO_PROJECT_SIM
export VIVADO_PROJECT_SIM = $(PROJECT)
endif
ifndef VIVADO_PROJECT_SIM_TIME
export VIVADO_PROJECT_SIM_TIME = 1000 ns
endif
# Synthesis Variables
export VIVADO_VERSION = $(shell vivado -version | grep -Po "(\d+\.)+\d+")
export VIVADO_INSTALL = $(abspath $(shell which vivado)/../..)
export VIVADO_DIR = $(abspath $(PROJ_DIR)/vivado)
export VIVADO_PROJECT = $(PROJECT)_project
export VIVADO_DEPEND = $(OUT_DIR)/$(VIVADO_PROJECT).xpr
ifndef RUCKUS_DIR
export RUCKUS_DIR = $(MODULES)/ruckus
endif
export SOURCE_DEPEND = $(OUT_DIR)/$(PROJECT)_sources.txt
# Images Directory
export IMAGES_DIR = $(abspath $(PROJ_DIR)/images)
# Project Build Directory
export OUT_DIR = $(abspath $(TOP_DIR)/build/$(PROJECT))
export SYN_DIR = $(OUT_DIR)/$(VIVADO_PROJECT).runs/synth_1
export IMPL_DIR = $(OUT_DIR)/$(VIVADO_PROJECT).runs/impl_1
# Define the user IP repo
ifndef IP_REPO
export IP_REPO = $(OUT_DIR)/ip_repo
endif
###############################################################
# Vitis Variables (Vivado 2019.2 or newer)
###############################################################
export VITIS_PRJ = $(abspath $(OUT_DIR)/$(VIVADO_PROJECT).vitis)
export VITIS_ELF = $(abspath $(VITIS_PRJ)/$(PROJECT).elf)
ifdef SDK_LIB
export VITIS_LIB = $(SDK_LIB)
else
ifndef VITIS_LIB
export VITIS_LIB = $(MODULES)/surf/xilinx/general/sdk/common
endif
endif
# Check if SDK_SRC_PATH defined but VITIS_SRC_PATH not (legacy support)
ifdef SDK_SRC_PATH
ifndef VITIS_SRC_PATH
export VITIS_SRC_PATH = $(SDK_SRC_PATH)
endif
endif
###############################################################
# SDK Variables (Vivado 2019.1 or older)
###############################################################
export SDK_PRJ = $(abspath $(OUT_DIR)/$(VIVADO_PROJECT).sdk)
export SDK_ELF = $(abspath $(SDK_PRJ)/$(PROJECT).elf)
ifndef SDK_LIB
export SDK_LIB = $(MODULES)/surf/xilinx/general/sdk/common
endif
###############################################################
ifndef LD_PRELOAD
export LD_PRELOAD =
endif
ifndef EMBED_PROC
export EMBED_PROC = microblaze_0
endif
ifneq (, $(shell which vitis 2>/dev/null))
export EMBED_TYPE = Vitis
export EMBED_GUI = vitis -workspace $(OUT_DIR)/$(VIVADO_PROJECT).vitis -vmargs -Dorg.eclipse.swt.internal.gtk.cairoGraphics=false
export EMBED_ELF = vivado -mode batch -source $(RUCKUS_DIR)/MicroblazeBasicCore/vitis/bit.tcl
else
export EMBED_TYPE = SDK
export EMBED_GUI = xsdk -workspace $(OUT_DIR)/$(VIVADO_PROJECT).sdk -vmargs -Dorg.eclipse.swt.internal.gtk.cairoGraphics=false
export EMBED_ELF = vivado -mode batch -source $(RUCKUS_DIR)/MicroblazeBasicCore/sdk/bit.tcl
# Ubuntu SDK support
ifndef SWT_GTK3
export SWT_GTK3 = 0
endif
endif
define COPY_PROBES_FILE
@if [ -f '$(OUT_DIR)/debugProbes.ltx' ] ; then \
$(RM) '$(IMAGES_DIR)/$(IMAGENAME).ltx' ; \
cp '$(OUT_DIR)/debugProbes.ltx' '$(IMAGES_DIR)/$(IMAGENAME).ltx' ; \
echo "Debug Probes file copied to $(IMAGES_DIR)/$(IMAGENAME).ltx "; \
elif [ -f '$(IMPL_DIR)/debug_nets.ltx' ] ; then \
$(RM) '$(IMAGES_DIR)/$(IMAGENAME).ltx' ; \
cp '$(IMPL_DIR)/debug_nets.ltx' '$(IMAGES_DIR)/$(IMAGENAME).ltx' ; \
echo "Debug Probes file copied to $(IMAGES_DIR)/$(IMAGENAME).ltx "; \
else \
echo "No Debug Probes found"; \
fi
endef
include $(TOP_DIR)/submodules/ruckus/system_shared.mk
.PHONY : all
all: target
###############################################################
#### Printout Environmental Variables #########################
###############################################################
.PHONY : test
test:
@echo PROJECT: $(PROJECT)
@echo PROJ_DIR: $(PROJ_DIR)
@echo PRJ_VERSION: $(PRJ_VERSION)
@echo PRJ_PART: $(PRJ_PART)
@echo TOP_DIR: $(TOP_DIR)
@echo OUT_DIR: $(OUT_DIR)
@echo IMAGES_DIR: $(IMAGES_DIR)
@echo IMPL_DIR: $(IMPL_DIR)
@echo VIVADO_DIR: $(VIVADO_DIR)
@echo RUCKUS_DIR: $(RUCKUS_DIR)
@echo VIVADO_PROJECT: $(VIVADO_PROJECT)
@echo VIVADO_VERSION: $(VIVADO_VERSION)
@echo VIVADO_INSTALL: $(VIVADO_INSTALL)
@echo XILINX_LOCAL_USER_DATA: $(XILINX_LOCAL_USER_DATA)
@echo GIT_HASH_LONG: $(GIT_HASH_LONG)
@echo GIT_HASH_SHORT: $(GIT_HASH_SHORT)
@echo IMAGENAME: $(IMAGENAME)
@echo EMBED_PROC: $(EMBED_PROC)
@echo EMBED_TYPE: $(EMBED_TYPE)
@echo EMBED_GUI: $(EMBED_GUI)
@echo EMBED_ELF: $(EMBED_ELF)
@echo Untracked Files:
@echo "\t$(foreach ARG,$(GIT_STATUS), $(ARG)\n)"
###############################################################
#### Build Location ###########################################
###############################################################
.PHONY : dir
dir:
@test -d $(TOP_DIR)/build/ || { \
echo ""; \
echo "Build directory missing!"; \
echo "You must create a build directory at the top level."; \
echo ""; \
echo "This directory can either be a normal directory:"; \
echo " mkdir $(TOP_DIR)/build"; \
echo ""; \
echo "Or by creating a symbolic link to a directory on another disk:"; \
echo " ln -s $(TMP_DIR) $(TOP_DIR)/build"; \
echo ""; false; }
@test -d $(OUT_DIR) || mkdir $(OUT_DIR)
@test -d $(RELEASE_DIR) || mkdir $(RELEASE_DIR)
@test -d $(IP_REPO) || mkdir $(IP_REPO)
@cd $(OUT_DIR); rm -f firmware
@cd $(OUT_DIR); ln -s $(TOP_DIR) firmware
###############################################################
#### Vivado Sources ###########################################
###############################################################
$(SOURCE_DEPEND) : dir
$(call ACTION_HEADER,"Vivado Source Setup")
@cd $(OUT_DIR); vivado -mode batch -source $(RUCKUS_DIR)/vivado/sources.tcl
###############################################################
#### Vivado Project GUI mode ##################################
###############################################################
.PHONY : gui
gui : $(SOURCE_DEPEND)
$(call ACTION_HEADER,"Vivado Project GUI Mode")
@cd $(OUT_DIR); vivado -source $(RUCKUS_DIR)/vivado/gui.tcl $(VIVADO_PROJECT).xpr
###############################################################
#### Vivado Batch #############################################
###############################################################
.PHONY : bit mcs prom
bit mcs prom : $(SOURCE_DEPEND)
$(call ACTION_HEADER,"Vivado Batch Build for .bit/.mcs")
@cd $(OUT_DIR); vivado -mode batch -source $(RUCKUS_DIR)/vivado/build.tcl
###############################################################
#### Vivado Synthesis Only ####################################
###############################################################
.PHONY : syn
syn : $(SOURCE_DEPEND)
$(call ACTION_HEADER,"Vivado Synthesis Only")
@cd $(OUT_DIR); export SYNTH_ONLY=1; vivado -mode batch -source $(RUCKUS_DIR)/vivado/build.tcl
###############################################################
#### Vivado Synthesis DCP ####################################
###############################################################
.PHONY : dcp
dcp : $(SOURCE_DEPEND)
$(call ACTION_HEADER,"Vivado Synthesis DCP")
@cd $(OUT_DIR); export SYNTH_DCP=1; vivado -mode batch -source $(RUCKUS_DIR)/vivado/build.tcl
###############################################################
#### Vivado Interactive #######################################
###############################################################
.PHONY : interactive
interactive : $(SOURCE_DEPEND)
$(call ACTION_HEADER,"Vivado Interactive")
@cd $(OUT_DIR); vivado -mode tcl -source $(RUCKUS_DIR)/vivado/env_var.tcl
###############################################################
#### Vivado SDK ###############################################
###############################################################
.PHONY : sdk vitis
sdk vitis :
$(call ACTION_HEADER,"Vivado $(EMBED_TYPE) GUI")
@cd $(OUT_DIR); $(EMBED_GUI)
###############################################################
#### Vivado SDK ELF ###########################################
###############################################################
.PHONY : elf
elf :
$(call ACTION_HEADER,"Vivado $(EMBED_TYPE) .ELF generation")
@cd $(OUT_DIR); $(EMBED_ELF)
@echo ""
@echo "Bit file w/ Elf file copied to $(IMAGES_DIR)/$(IMAGENAME).bit"
###############################################################
#### Release ##################################################
###############################################################
.PHONY : release
release : dir
$(call ACTION_HEADER,"Generaring Release")
@cd $(RELEASE_DIR); python3 $(RUCKUS_DIR)/scripts/firmwareRelease.py --project=$(TOP_DIR) --release=$(RELEASE) --push
###############################################################
#### Release Files ############################################
###############################################################
.PHONY : release_files
release_files : dir
$(call ACTION_HEADER,"Generaring Release Files")
@cd $(RELEASE_DIR); python3 $(RUCKUS_DIR)/scripts/firmwareRelease.py --project=$(TOP_DIR) --release=$(RELEASE)
###############################################################
#### Vivado PyRogue ###########################################
###############################################################
.PHONY : pyrogue
pyrogue : $(SOURCE_DEPEND)
$(call ACTION_HEADER,"Generaring pyrogue.tar.gz file")
@cd $(OUT_DIR); tclsh $(RUCKUS_DIR)/vivado/pyrogue.tcl
###############################################################
#### Vivado CPSW ##############################################
###############################################################
.PHONY : yaml
yaml : $(SOURCE_DEPEND)
$(call ACTION_HEADER,"Generaring cpsw.tar.gz file")
@cd $(OUT_DIR); tclsh $(RUCKUS_DIR)/vivado/cpsw.tcl
###############################################################
#### Vivado WIS ###############################################
###############################################################
.PHONY : wis
wis : $(SOURCE_DEPEND)
$(call ACTION_HEADER,"Generating init_wis.tcl file for Windows OS")
@cd $(OUT_DIR); vivado -mode batch -source $(RUCKUS_DIR)/vivado/wis.tcl
###############################################################
#### Vivado XSIM Simulation ###################################
###############################################################
.PHONY : xsim
xsim : $(SOURCE_DEPEND)
$(call ACTION_HEADER,"Vivado XSIM Simulation")
@cd $(OUT_DIR); vivado -mode batch -source $(RUCKUS_DIR)/vivado/xsim.tcl
###############################################################
#### Vivado VCS Simulation ####################################
###############################################################
.PHONY : vcs
vcs : $(SOURCE_DEPEND)
$(call ACTION_HEADER,"Generating the VCS Simulation scripts")
@cd $(OUT_DIR); vivado -mode batch -source $(RUCKUS_DIR)/vivado/vcs.tcl
###############################################################
#### Vivado Batch Mode within the Project Environment ########
###############################################################
.PHONY : batch
batch : $(SOURCE_DEPEND)
$(call ACTION_HEADER,"Vivado Project Batch")
@cd $(OUT_DIR); vivado -mode batch -source $(RUCKUS_DIR)/vivado/batch.tcl $(VIVADO_PROJECT).xpr
###############################################################
#### Makefile Targets #########################################
###############################################################
.PHONY : sources
sources : $(SOURCE_DEPEND)
###############################################################
#### Clean ####################################################
###############################################################
.PHONY : clean
clean:
rm -rf $(OUT_DIR)