-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmakefile
101 lines (76 loc) · 2.84 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
tty := /dev/ttyUSB0
sim_source := $(shell find src -name '*.sv')
fpga_source := $(shell find fpga -name '*.sv')
sv_source = $(shell find build -name '*.sv')
include_dir := include
include_source := $(shell find $(include_dir) -name '*.vh')
hex := $(shell find src -name '*.hex')
pinmap := $(shell find -name '*.lpf')
nproc := $(shell nproc)
WAVE = gtkwave --dark
BASE_SIM := $(MAKECMDGOALS:%.sim=%)
BASE_DOT := $(MAKECMDGOALS:%.dot=%)
.PHONY: clean clean_sim clean_cram clean_dot %.sim cram flash setup_tty
.PRECIOUS: obj_dir/V% obj_dir/%.vcd
default: cram
# https://stackoverflow.com/questions/2214575/passing-arguments-to-make-run
ifeq (flash,$(firstword $(MAKECMDGOALS)))
FLASH_TARGET := $(word 2,$(MAKECMDGOALS))
$(eval $(FLASH_TARGET):;@:)
endif
flash: setup_tty $(FLASH_TARGET)
cat $(FLASH_TARGET) > /dev/ttyUSB0
setup_tty:
stty -F $(tty) 406:0:18b2:8a30:3:1c:7f:15:4:2:64:0:11:13:1a:0:12:f:17:16:0:0:0:0:0:0:0:0:0:0:0:0:0:0:0:0
cram: build/build.bit
@openFPGALoader -c jlink-plus build/build.bit
build/build.bit: build/build.config
@ecppack build/build.config build/build.bit
build/build.config: build/build.json $(pinmap)
@nextpnr-ecp5 \
--12k --package CABGA256 \
--speed 6 --freq 5 \
--json build/build.json --textcfg build/build.config \
--lpf fpga/pinmap.lpf --lpf-allow-unconstrained
%.dot: build/sv $(fpga_source)
@mkdir -p dot
@yosys \
$(foreach mod,$(sv_source) $(fpga_source),-p "read_verilog -sv $(mod);") \
-p "ls; show -prefix dot/$(BASE_DOT) -notitle -colors 2 -width -format dot $(BASE_DOT)"
@dot -Tpng dot/$(BASE_DOT).dot -o dot/$(BASE_DOT).png
build/build.json: $(fpga_source) $(hex) build/sv
@$(if $(hex),cp -u $(hex) build/verilog,)
@yosys -p "synth_ecp5 -top top -json build/build.json" $(sv_source) $(fpga_source)
# stupid yosys doesn't let you do '.*' in files that end with '.v'
# can't figure out how to force it to use systemverilog frontend
# so, just make all converted sv->v files have sv endings
build/sv: build/v
@$(foreach ver,$(shell find build -name '*.v'), mv $(ver) $(ver:%.v=%.sv);)
@touch build/sv
build/v: $(sim_source) $(include_source)
@mkdir -p build/verilog
@sv2v --siloed -w adjacent -I$(include_dir) $(sim_source)
@mv $(sim_source:%.sv=%.v) build/verilog
@touch build/v
%.sim: obj_dir/%.vcd
@if ps -C "gtkwave" > /dev/null; \
then \
echo "gtkwave already running"; \
else \
$(WAVE) obj_dir/$(BASE_SIM).vcd > /dev/null 2>&1 & \
fi
obj_dir/%.vcd: obj_dir/V%
@obj_dir/V$(BASE_SIM)
@mv $(BASE_SIM).vcd obj_dir/$(BASE_SIM).vcd
obj_dir/V%: tb_%.cpp $(sim_source) $(include_source)
@verilator -cc -O3 --trace --trace-fst --top-module $(BASE_SIM) \
--threads $(nproc) \
-I$(include_dir) $(sim_source) --exe $<
@make -C obj_dir -f V$(BASE_SIM).mk -s -j $(nproc) V$(BASE_SIM)
clean: clean_cram clean_sim clean_dot
clean_cram:
@rm -rf build
clean_sim:
@rm -rf obj_dir
clean_dot:
@rm -rf dot