-
Notifications
You must be signed in to change notification settings - Fork 199
/
Copy pathMakefile
400 lines (318 loc) · 17.5 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
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
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
# --- configuration ---
ifneq (,$(wildcard workspace/config))
include workspace/config
endif
BOARD ?= nexys-video
CONFIG ?= rocket64b2
HW_SERVER_ADDR ?= localhost:3121
JAVA_OPTIONS ?=
CFG_FORMAT ?= mcs
include board/$(BOARD)/Makefile.inc
all: bitstream
# --- docker ---------------
DOCKER_VIVADO_VERSION ?= 2023.2
DOCKER_ARGS ?=
docker-image:
cd docker && docker build --build-arg HOST_UID=`id -u` --build-arg HOST_GID=`id -g` --build-arg VIVADO_VERSION=$(DOCKER_VIVADO_VERSION) --tag vivado-risc-v-tools:$(DOCKER_VIVADO_VERSION) .
docker-shell:
docker container run --interactive --tty --rm --volume .:/src $(DOCKER_ARGS) --user `id -u`:`id -g` --network host vivado-risc-v-tools:$(DOCKER_VIVADO_VERSION) bash --login || true
# --- packages and repos ---
apt-install:
sudo apt update
sudo apt upgrade
sudo apt install default-jdk device-tree-compiler curl gawk \
libtinfo5 libmpc-dev libssl-dev gcc gcc-riscv64-linux-gnu flex bison bc parted udev dosfstools
ifeq ($(shell test -r /etc/os-release && . /etc/os-release && echo $$VERSION_CODENAME),jammy)
sudo apt install python-is-python3
else
sudo apt install python
endif
apt-install-qemi:
sudo apt install qemu-system-misc opensbi u-boot-qemu qemu-utils
# skip submodules which are not needed and take long time to update
override SKIP_SUBMODULES += torture software/gemmini-rocc-tests software/onnxruntime-riscv
update:
git pull --no-recurse-submodules
rm -rf workspace/patch-*-done
git submodule sync --recursive
git $(foreach m,$(SKIP_SUBMODULES),-c submodule.$(m).update=none) submodule update --init --force --recursive
update-submodules:
rm -rf workspace/patch-*-done
git submodule sync --recursive
git $(foreach m,$(SKIP_SUBMODULES),-c submodule.$(m).update=none) submodule update --init --force --recursive
clean-submodules:
git submodule foreach --recursive git clean -xfdq
rm -rf workspace/patch-*-done
clean-sbt:
rm -rf ~/.cache ~/.config/jgit ~/.ivy2 ~/.sbt
clean:
rm -rf workspace/patch-*-done
git submodule foreach --recursive git clean -xfdq
sudo rm -rf debian-riscv64 target project/target project/project/target generators/targetutils/target vhdl-wrapper/bin
# --- download gcc, initrd and rootfs from github.com ---
workspace/gcc/tools.tar.gz:
mkdir -p workspace/gcc
curl --netrc --location --header 'Accept: application/octet-stream' \
https://api.github.com/repos/eugene-tarassov/vivado-risc-v/releases/assets/18060315 \
-o $@.tmp
mv $@.tmp $@
workspace/gcc/riscv: workspace/gcc/tools.tar.gz
cd workspace/gcc && tar xzf tools.tar.gz
touch $@
debian-riscv64/initrd:
mkdir -p debian-riscv64
curl --netrc --location --header 'Accept: application/octet-stream' \
https://api.github.com/repos/eugene-tarassov/vivado-risc-v/releases/assets/158580561 \
-o $@.tmp
mv $@.tmp $@
debian-riscv64/rootfs.tar.gz:
mkdir -p debian-riscv64
curl --netrc --location --header 'Accept: application/octet-stream' \
https://api.github.com/repos/eugene-tarassov/vivado-risc-v/releases/assets/158580569 \
-o $@.tmp
mv $@.tmp $@
# --- build Linux kernel ---
.PHONY: linux
linux: linux-stable/arch/riscv/boot/Image
CROSS_COMPILE_LINUX = /usr/bin/riscv64-linux-gnu-
workspace/patch-linux-done: patches/linux.patch patches/fpga-axi-sdc.c patches/fpga-axi-eth.c patches/linux.config
if [ -s patches/linux.patch ] ; then cd linux-stable && ( git apply -R --check ../patches/linux.patch 2>/dev/null || git apply ../patches/linux.patch ) ; fi
cp -p patches/fpga-axi-eth.c linux-stable/drivers/net/ethernet
cp -p patches/fpga-axi-sdc.c linux-stable/drivers/mmc/host
cp -p patches/fpga-axi-uart.c linux-stable/drivers/tty/serial
cp -p patches/linux.config linux-stable/.config
mkdir -p workspace && touch workspace/patch-linux-done
linux-stable/arch/riscv/boot/Image: workspace/patch-linux-done
make -C linux-stable ARCH=riscv CROSS_COMPILE=$(CROSS_COMPILE_LINUX) oldconfig
make -C linux-stable ARCH=riscv CROSS_COMPILE=$(CROSS_COMPILE_LINUX) all
# --- build U-Boot ---
ROOTFS ?= SD
ROOTFS_URL ?= 192.168.0.100:/home/nfsroot/192.168.0.243
.PHONY: u-boot
u-boot: u-boot/u-boot-nodtb.bin
U_BOOT_SRC = $(wildcard patches/u-boot/*/*) \
patches/u-boot/vivado_riscv64_defconfig \
patches/u-boot/vivado_riscv64.h \
patches/u-boot.patch
u-boot/configs/vivado_riscv64_defconfig: patches/u-boot/vivado_riscv64_defconfig Makefile
cp patches/u-boot/vivado_riscv64_defconfig u-boot/configs
ifeq ($(ROOTFS),NFS)
echo 'CONFIG_USE_BOOTARGS=y' >>u-boot/configs/vivado_riscv64_defconfig
echo 'CONFIG_BOOTCOMMAND="booti $${kernel_addr_r} - $${fdt_addr}"' >>u-boot/configs/vivado_riscv64_defconfig
echo 'CONFIG_BOOTARGS="root=/dev/nfs rootfstype=nfs rw nfsroot='$(ROOTFS_URL)',nolock,vers=4,tcp ip=dhcp earlycon console=ttyAU0,115200n8 locale.LANG=en_US.UTF-8"' >>u-boot/configs/vivado_riscv64_defconfig
else ifeq ($(JTAG_BOOT),1)
echo 'CONFIG_USE_BOOTARGS=y' >>u-boot/configs/vivado_riscv64_defconfig
echo 'CONFIG_BOOTCOMMAND="booti $${kernel_addr_r} $${ramdisk_addr_r} $${fdt_addr}"' >>u-boot/configs/vivado_riscv64_defconfig
echo 'CONFIG_BOOTARGS="ro root=UUID=68d82fa1-1bb5-435f-a5e3-862176586eec earlycon initramfs.runsize=24M locale.LANG=en_US.UTF-8"' >>u-boot/configs/vivado_riscv64_defconfig
endif
workspace/patch-u-boot-done: u-boot/configs/vivado_riscv64_defconfig
if [ -s patches/u-boot.patch ] ; then cd u-boot && ( git apply -R --check ../patches/u-boot.patch 2>/dev/null || git apply ../patches/u-boot.patch ) ; fi
mkdir -p u-boot/board/vivado_riscv
cp -p -r patches/u-boot/vivado_riscv64 u-boot/board/vivado_riscv
cp -p patches/u-boot/vivado_riscv64.h u-boot/include/configs
mkdir -p workspace && touch workspace/patch-u-boot-done
u-boot/u-boot-nodtb.bin: workspace/patch-u-boot-done $(U_BOOT_SRC)
make -C u-boot CROSS_COMPILE=$(CROSS_COMPILE_LINUX) BOARD=vivado_riscv64 vivado_riscv64_config
make -C u-boot \
BOARD=vivado_riscv64 \
CC=$(CROSS_COMPILE_LINUX)gcc \
CROSS_COMPILE=$(CROSS_COMPILE_LINUX) \
KCFLAGS='-O1 -gno-column-info' \
u-boot-nodtb.bin
u-boot-qemu:
cd qemu/ && if [ ! -d u-boot ]; then git clone ../u-boot; fi && cd u-boot && git checkout v2022.01
cd qemu/u-boot && export CROSS_COMPILE=$(CROSS_COMPILE_LINUX) && make qemu-riscv64_smode_defconfig && make -j$(nproc)
# --- build RISC-V Open Source Supervisor Binary Interface (OpenSBI) ---
bootloader: workspace/boot.elf
workspace/boot.elf: opensbi/build/platform/vivado-risc-v/firmware/fw_payload.elf
mkdir -p workspace
cp $< $@
opensbi/build/platform/vivado-risc-v/firmware/fw_payload.elf: $(wildcard patches/opensbi/*) u-boot/u-boot-nodtb.bin
mkdir -p opensbi/platform/vivado-risc-v
cp -p -r patches/opensbi/* opensbi/platform/vivado-risc-v
make -C opensbi CROSS_COMPILE=$(CROSS_COMPILE_LINUX) PLATFORM=vivado-risc-v \
FW_PAYLOAD_PATH=`realpath u-boot/u-boot-nodtb.bin`
opensbi-qemu:
cd qemu && if [ ! -d opensbi ]; then git clone ../opensbi; fi
cd qemu && make -C opensbi clean && make -C opensbi PLATFORM=generic CROSS_COMPILE=$(CROSS_COMPILE_LINUX) FW_PAYLOAD_PATH=../u-boot/u-boot.bin
# --- generate HDL ---
CONFIG_SCALA := $(subst rocket,Rocket,$(CONFIG))
# valid ROCKET_FREQ_MHZ values (MHz): 160 125 100 80 62.5 50 40 31.25 25 20
ROCKET_FREQ_MHZ ?= $(shell awk '$$3 != "" && "$(BOARD)" ~ $$1 && "$(CONFIG_SCALA)" ~ ("^" $$2 "$$") {print $$3; exit}' board/rocket-freq)
ROCKET_CLOCK_FREQ := $(shell echo - | awk '{printf("%.0f\n", $(ROCKET_FREQ_MHZ) * 1000000)}')
ROCKET_TIMEBASE_FREQ := $(shell echo - | awk '{printf("%.0f\n", $(ROCKET_FREQ_MHZ) * 10000)}')
MEMORY_SIZE ?= 0x40000000
ifneq ($(findstring Rocket32t,$(CONFIG_SCALA)),)
CROSS_COMPILE_NO_OS_TOOLS = $(realpath workspace/gcc/riscv/bin)/riscv32-unknown-elf-
CROSS_COMPILE_NO_OS_FLAGS = -march=rv32imac -mabi=ilp32 -DFF_FS_EXFAT=0
else ifneq ($(findstring Rocket32,$(CONFIG_SCALA)),)
CROSS_COMPILE_NO_OS_TOOLS = $(realpath workspace/gcc/riscv/bin)/riscv32-unknown-elf-
CROSS_COMPILE_NO_OS_FLAGS = -march=rv32imac -mabi=ilp32
else
CROSS_COMPILE_NO_OS_TOOLS = $(realpath workspace/gcc/riscv/bin)/riscv64-unknown-elf-
CROSS_COMPILE_NO_OS_FLAGS = -march=rv64imac -mabi=lp64
endif
ifeq ($(shell echo $$(($(MEMORY_SIZE) <= 0x80000000))),1)
MEMORY_ADDR_RANGE32 = 0x80000000 $(MEMORY_SIZE)
MEMORY_ADDR_RANGE64 = 0x0 0x80000000 0x0 $(MEMORY_SIZE)
else
MEMORY_ADDR_RANGE32 = 0x80000000 0x80000000
MEMORY_SIZE_CPU = ${shell cat workspace/$(CONFIG)/system.dts | sed -n 's/.*reg = <0x0 0x80000000 *\(0x[0-9A-Fa-f]*\) *0x\([0-9A-Fa-f]*\)>.*/\1\2/p'}
MEMORY_SIZE_AWK = if (CPU < DDR) SIZE=CPU; else SIZE=DDR; printf "0x%x 0x%x", SIZE / 0x100000000, SIZE % 0x100000000
MEMORY_ADDR_RANGE64 = 0x0 0x80000000 $(shell echo - | awk '{CPU=$(MEMORY_SIZE_CPU); DDR=$(MEMORY_SIZE); $(MEMORY_SIZE_AWK)}')
endif
SBT := java -Xmx12G -Xss8M $(JAVA_OPTIONS) -Dsbt.io.virtual=false -Dsbt.server.autostart=false -jar $(realpath sbt-launch.jar)
CHISEL_SRC_DIRS = \
src/main \
rocket-chip/src/main \
rocket-chip/macros/src/main \
rocket-chip/hardfloat/src/main \
generators/gemmini/src/main \
generators/riscv-boom/src/main \
generators/sifive-cache/design/craft \
generators/testchipip/src/main
CHISEL_SRC := $(foreach path, $(CHISEL_SRC_DIRS), $(shell test -d $(path) && find $(path) -iname "*.scala" -not -name ".*"))
FIRRTL = java -Xmx12G -Xss8M $(JAVA_OPTIONS) -cp `realpath target/scala-*/system.jar` firrtl.stage.FirrtlMain
workspace/patch-hdl-done:
if [ -s patches/ethernet.patch ] ; then cd ethernet/verilog-ethernet && ( git apply -R --check ../../patches/ethernet.patch 2>/dev/null || git apply ../../patches/ethernet.patch ) ; fi
if [ -s patches/rocket-chip.patch ] ; then cd rocket-chip && ( git apply -R --check ../patches/rocket-chip.patch 2>/dev/null || git apply ../patches/rocket-chip.patch ) ; fi
if [ -s patches/riscv-boom.patch ] ; then cd generators/riscv-boom && ( git apply -R --check ../../patches/riscv-boom.patch 2>/dev/null || git apply ../../patches/riscv-boom.patch ) ; fi
if [ -s patches/sifive-cache.patch ] ; then cd generators/sifive-cache && ( git apply -R --check ../../patches/sifive-cache.patch 2>/dev/null || git apply ../../patches/sifive-cache.patch ) ; fi
if [ -s patches/gemmini.patch ] ; then cd generators/gemmini && ( git apply -R --check ../../patches/gemmini.patch 2>/dev/null || git apply ../../patches/gemmini.patch ) ; fi
mkdir -p workspace && touch workspace/patch-hdl-done
# Generate default device tree - not including peripheral devices or board specific data
workspace/$(CONFIG)/system.dts: $(CHISEL_SRC) rocket-chip/bootrom/bootrom.img workspace/patch-hdl-done
rm -rf workspace/$(CONFIG)/tmp
mkdir -p workspace/$(CONFIG)/tmp
cp rocket-chip/bootrom/bootrom.img workspace/bootrom.img
$(SBT) "runMain freechips.rocketchip.diplomacy.Main --dir `realpath workspace/$(CONFIG)/tmp` --top Vivado.RocketSystem --config Vivado.$(CONFIG_SCALA)"
mv workspace/$(CONFIG)/tmp/Vivado.$(CONFIG_SCALA).dts workspace/$(CONFIG)/system.dts
rm -rf workspace/$(CONFIG)/tmp
# Generate board specific device tree, boot ROM and FIRRTL
workspace/$(CONFIG)/system-$(BOARD)/RocketSystem.fir: workspace/$(CONFIG)/system.dts $(wildcard bootrom/*) workspace/gcc/riscv
rm -rf workspace/$(CONFIG)/system-$(BOARD)
mkdir -p workspace/$(CONFIG)/system-$(BOARD)
cat workspace/$(CONFIG)/system.dts board/$(BOARD)/bootrom.dts >bootrom/system.dts
sed -i "s#reg = <0x80000000 *0x.*>#reg = <$(MEMORY_ADDR_RANGE32)>#g" bootrom/system.dts
sed -i "s#reg = <0x0 0x80000000 *0x.*>#reg = <$(MEMORY_ADDR_RANGE64)>#g" bootrom/system.dts
sed -i "s#clock-frequency = <[0-9]*>#clock-frequency = <$(ROCKET_CLOCK_FREQ)>#g" bootrom/system.dts
sed -i "s#timebase-frequency = <[0-9]*>#timebase-frequency = <$(ROCKET_TIMEBASE_FREQ)>#g" bootrom/system.dts
if [ ! -z "$(ETHER_MAC)" ] ; then sed -i "s#local-mac-address = \[.*\]#local-mac-address = [$(ETHER_MAC)]#g" bootrom/system.dts ; fi
if [ ! -z "$(ETHER_PHY)" ] ; then sed -i "s#phy-mode = \".*\"#phy-mode = \"$(ETHER_PHY)\"#g" bootrom/system.dts ; fi
sed -i "/interrupts-extended = <&.* 65535>;/d" bootrom/system.dts
make -C bootrom CROSS_COMPILE="$(CROSS_COMPILE_NO_OS_TOOLS)" CFLAGS="$(CROSS_COMPILE_NO_OS_FLAGS)" BOARD=$(BOARD) clean bootrom.img
mv bootrom/system.dts workspace/$(CONFIG)/system-$(BOARD).dts
mv bootrom/bootrom.img workspace/bootrom.img
$(SBT) "runMain freechips.rocketchip.diplomacy.Main --dir `realpath workspace/$(CONFIG)/system-$(BOARD)` --top Vivado.RocketSystem --config Vivado.$(CONFIG_SCALA)"
$(SBT) assembly
rm workspace/bootrom.img
# Generate Rocket SoC HDL
workspace/$(CONFIG)/system-$(BOARD).v: workspace/$(CONFIG)/system-$(BOARD)/RocketSystem.fir
$(FIRRTL) -i $< -o RocketSystem.v --compiler verilog \
--annotation-file workspace/$(CONFIG)/system-$(BOARD)/RocketSystem.anno.json \
--custom-transforms firrtl.passes.InlineInstances \
--target:fpga
cp workspace/$(CONFIG)/system-$(BOARD)/RocketSystem.v workspace/$(CONFIG)/system-$(BOARD).v
# Generate Rocket SoC wrapper for Vivado
workspace/$(CONFIG)/rocket.vhdl: workspace/$(CONFIG)/system-$(BOARD).v
mkdir -p vhdl-wrapper/bin
javac -g -nowarn \
-sourcepath vhdl-wrapper/src -d vhdl-wrapper/bin \
-classpath vhdl-wrapper/antlr-4.8-complete.jar \
vhdl-wrapper/src/net/largest/riscv/vhdl/Main.java
java -Xmx4G -Xss8M $(JAVA_OPTIONS) -cp \
vhdl-wrapper/src:vhdl-wrapper/bin:vhdl-wrapper/antlr-4.8-complete.jar \
net.largest.riscv.vhdl.Main -m $(CONFIG_SCALA) \
workspace/$(CONFIG)/system-$(BOARD).v >$@
# --- utility make targets to run SBT command line ---
.PHONY: sbt rocket-sbt
sbt:
$(SBT)
rocket-sbt:
cd rocket-chip && $(SBT)
# --- generate Vivado Project ---
.PHONY: vivado-tcl vivado-project vivado-gui bitstream
FPGA_FNM ?= riscv_wrapper.bit
proj_name = $(BOARD)-riscv
proj_path = workspace/$(CONFIG)/vivado-$(proj_name)
proj_file = $(proj_path)/$(proj_name).xpr
proj_time = $(proj_path)/timestamp.txt
synthesis = $(proj_path)/$(proj_name).runs/synth_1/riscv_wrapper.dcp
bitstream = $(proj_path)/$(proj_name).runs/impl_1/$(FPGA_FNM)
cfgmem_file = workspace/$(CONFIG)/$(proj_name).$(CFG_FORMAT)
prm_file = workspace/$(CONFIG)/$(proj_name).prm
vivado = env XILINX_LOCAL_USER_DATA=no vivado -mode batch -nojournal -nolog -notrace -quiet
workspace/$(CONFIG)/system-$(BOARD).tcl: workspace/$(CONFIG)/rocket.vhdl workspace/$(CONFIG)/system-$(BOARD).v
echo "set vivado_board_name $(BOARD)" >$@
if [ "$(BOARD_PART)" != "" -a "$(BOARD_PART)" != "NONE" ] ; then echo "set vivado_board_part $(BOARD_PART)" >>$@ ; fi
if [ "$(BOARD_CONFIG)" != "" ] ; then echo "set board_config $(BOARD_CONFIG)" >>$@ ; fi
echo "set xilinx_part $(XILINX_PART)" >>$@
echo "set rocket_module_name $(CONFIG_SCALA)" >>$@
echo "set riscv_clock_frequency $(ROCKET_FREQ_MHZ)" >>$@
echo "set memory_size $(MEMORY_SIZE)" >>$@
echo 'cd [file dirname [file normalize [info script]]]' >>$@
echo 'source ../../vivado.tcl' >>$@
vivado-tcl: workspace/$(CONFIG)/system-$(BOARD).tcl
$(proj_time): workspace/$(CONFIG)/system-$(BOARD).tcl
if [ ! -e $(proj_path) ] ; then $(vivado) -source workspace/$(CONFIG)/system-$(BOARD).tcl || ( rm -rf $(proj_path) ; exit 1 ) ; fi
date >$@
vivado-project: $(proj_time)
# --- generate FPGA bitstream ---
# Multi-threading appears broken in Vivado. It causes intermittent failures.
MAX_THREADS ?= 1
$(synthesis): $(proj_time)
echo "set_param general.maxThreads $(MAX_THREADS)" >>$(proj_path)/make-synthesis.tcl
echo "open_project $(proj_file)" >$(proj_path)/make-synthesis.tcl
echo "update_compile_order -fileset sources_1" >>$(proj_path)/make-synthesis.tcl
echo "reset_run synth_1" >>$(proj_path)/make-synthesis.tcl
echo "launch_runs -jobs $(MAX_THREADS) synth_1" >>$(proj_path)/make-synthesis.tcl
echo "wait_on_run synth_1" >>$(proj_path)/make-synthesis.tcl
$(vivado) -source $(proj_path)/make-synthesis.tcl
if find $(proj_path) -name "*.log" -exec cat {} \; | grep 'ERROR: ' ; then exit 1 ; fi
$(bitstream): $(synthesis)
echo "set_param general.maxThreads $(MAX_THREADS)" >>$(proj_path)/make-bitstream.tcl
echo "open_project $(proj_file)" >$(proj_path)/make-bitstream.tcl
echo "reset_run impl_1" >>$(proj_path)/make-bitstream.tcl
echo "launch_runs -to_step write_bitstream -jobs $(MAX_THREADS) impl_1" >>$(proj_path)/make-bitstream.tcl
echo "wait_on_run impl_1" >>$(proj_path)/make-bitstream.tcl
$(vivado) -source $(proj_path)/make-bitstream.tcl
if find $(proj_path) -name "*.log" -exec cat {} \; | grep 'ERROR: ' ; then exit 1 ; fi
ifeq ($(CFG_BOOT),)
CFG_FILES=$(bitstream)
else
CFG_FILES=$(bitstream) workspace/boot.elf
endif
$(cfgmem_file) $(prm_file): $(CFG_FILES)
echo "open_project $(proj_file)" >$(proj_path)/make-mcs.tcl
echo "write_cfgmem -format $(CFG_FORMAT) -interface $(CFG_DEVICE) -loadbit {up 0x0 $(bitstream)} $(CFG_BOOT) -file $(cfgmem_file) -force" >>$(proj_path)/make-mcs.tcl
$(vivado) -source $(proj_path)/make-mcs.tcl
bitstream: $(bitstream) $(cfgmem_file)
# --- program flash memory ---
flash: $(cfgmem_file) $(prm_file)
env HW_SERVER_URL=tcp:$(HW_SERVER_ADDR) \
xsdb -quiet board/jtag-freq.tcl
env HW_SERVER_ADDR=$(HW_SERVER_ADDR) \
env CFG_PART=$(CFG_PART) \
env mcs_file=$(cfgmem_file) \
env prm_file=$(prm_file) \
$(vivado) -source board/program-flash.tcl
# --- program FPGA and boot Linux ---
debian-riscv64/ramdisk: debian-riscv64/initrd
ifeq ($(ROOTFS),NFS)
mkdir -p debian-riscv64
rm -f debian-riscv64/ramdisk
dd if=/dev/zero of=debian-riscv64/ramdisk bs=32 count=1
else ifeq ($(JTAG_BOOT),1)
mkimage -A riscv -T ramdisk -C gzip -d debian-riscv64/initrd debian-riscv64/ramdisk
else
echo "JTAG boot requires either ROOTFS=NFS or JTAG_BOOT=1" && exit 1
endif
jtag-boot: $(bitstream) linux-stable/arch/riscv/boot/Image debian-riscv64/ramdisk workspace/boot.elf
env HW_SERVER_URL=tcp:$(HW_SERVER_ADDR) \
xsdb -quiet board/jtag-freq.tcl
env BITSTREAM=$(bitstream) \
env HW_SERVER_URL=tcp:$(HW_SERVER_ADDR) \
xsdb -quiet board/jtag-boot.tcl
# --- launch Vivado GUI ---
vivado-gui: $(proj_time)
vivado $(proj_file)