-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
76 lines (56 loc) · 2.45 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
#####################################################################
# Written by Javier Ignacio Peralta Saenz <[email protected]>
# Copyright (C) 2016
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
########################################################################
CC := iverilog
SIM := vvp
VIEWER := gtkwave
SYN := yosys
SRC_FLAG ?= -Isrc -Isrc/common -Isrc/dat -Isrc/register_set -Isrc/dma -Isrc/buffer -Isrc/cmd -Isrc/synthetized
TEST_FLAG ?= -Itests -Itests/dat -Itests/cmd -Itests/register_set -Itests/dma -Itest/buffer
FLAGS ?= -g2012 $(SRC_FLAG) $(TEST_FLAG)
LOG ?= tests/sim.log
SYN_DIR = src/synthetized
VCD_DIR = tests/vcd
VVP_DIR = tests/vvp
test: $(VCD_DIR)/register_set.vcd $(VCD_DIR)/DAT1.vcd $(VCD_DIR)/DAT.vcd
# Register set
$(VVP_DIR)/register_set.vvp: tests/register_set/register_set-tb.v src/register_set/register_set.v $(SYN_DIR)/register_set_syn.v
$(CC) $(FLAGS) -o $@ $<
$(VCD_DIR)/register_set.vcd: $(VVP_DIR)/register_set.vvp
$(SIM) $< >> $(LOG)
$(SYN_DIR)/register_set_syn.v: src/register_set/register_set.v
$(SYN) -s syn/register_set.ys
(echo "\`include \"cmos_cells.v\""; cat src/synthetized/register_set.v) > $@
rm $(SYN_DIR)/register_set.v
# Sd data
$(VVP_DIR)/DAT.vvp: tests/dat/testbench.v tests/dat/probador.v src/dat/DAT.v
$(CC) $(FLAGS) -o $@ $< tests/dat/probador.v src/dat/DAT.v
$(VCD_DIR)/DAT.vcd: $(VVP_DIR)/DAT.vvp
$(SIM) $< >> $(LOG)
$(VVP_DIR)/DAT1.vvp: tests/dat/testbench.v tests/dat/probador1.v src/synthetized/DATsyn.v
$(CC) $(FLAGS) -o $@ $< tests/dat/probador1.v src/synthetized/DATsyn.v
$(VCD_DIR)/DAT1.vcd: $(VVP_DIR)/DAT1.vvp
$(SIM) $< >> $(LOG)
$(SYN_DIR)/DATsyn.v: src/dat/DAT.v
$(SYN) -s syn/dat.ys
(echo "\`include \"cmos_cells.v\""; cat src/synthetized/DAT.v) > $@
rm $(SYN_DIR)/DAT.v
# Others
clean:
rm -f $(VCD_DIR)/* $(VVP_DIR)/* $(LOG) $(SYN_DIR)/*
.PHONY: clean all syn test
.SECONDARY: $(OBJECTS)