-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMakefile
57 lines (42 loc) · 1.88 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
SHELL := /bin/bash
IVERILOG = iverilog
IVERILOG_FLAGS = -Wall -tnull -Isrc/
VERILATOR = verilator
VERILATOR_FLAGS = --language 1364-2005 --lint-only -Wall -Isrc/
YOSYS = yosys
YOSYS_FLAGS = -s synth/synth_generic.ys
SRC_DIR = src
VERILOG_SOURCES = $(shell find $(SRC_DIR) -name '*.v')
VERILOG_TOP=$(SRC_DIR)/Lucid64.v
# Define colors
RED = \033[1;31m
GREEN = \033[1;32m
BLUE = \033[1;34m
NC = \033[0m # No Color
.PHONY: all lint_verilator lint_iverilog lint_all synth always
all: lint_all synth finish
lint_verilator:
@printf "\n${BLUE}%79s${NC}\n\n" "======================== Linting With Verilator ========================"
@$(MAKE) -s $(VERILOG_SOURCES:%=%.lint_verilator)
lint_iverilog:
@printf "\n${BLUE}%79s${NC}\n\n" "======================== Linting With Iverilog ========================="
@printf "Linting full design with Iverilog"
@{ $(IVERILOG) $(IVERILOG_FLAGS) $(VERILOG_SOURCES) > /dev/null 2>&1 && printf "${GREEN}%10s${NC}\n" "PASSED"; } \
|| { printf "${RED}%10s${NC}\n" "FAILED" && $(IVERILOG) $(IVERILOG_FLAGS) $(VERILOG_SOURCES); }
lint_all: lint_verilator lint_iverilog
@echo "Completed linting with both Verilator and Iverilog."
synth:
@printf "\n${BLUE}%79s${NC}\n\n" "======================= Synthesizing with Yosys ========================"
@$(MAKE) -s $(VERILOG_TOP:%=results/synth/%.synth.log)
%.lint_verilator: %
@printf "Linting %-47s" "$<"
@{ $(VERILATOR) $(VERILATOR_FLAGS) $< > /dev/null 2>&1 && printf "${GREEN}%10s${NC}\n" "PASSED"; } \
|| { printf "${RED}%10s${NC}\n" "FAILED" && $(VERILATOR) $(VERILATOR_FLAGS) $<; }
results/synth/%.synth.log: % always
@mkdir -p $(dir $@)
@printf "Synthesizing %-41s" "$<"
@{ $(YOSYS) $(YOSYS_FLAGS) $< > $@ 2>&1 && ! grep -i -e warning -e error $@ > /dev/null && printf "${GREEN}%10s${NC}\n" "PASSED"; } \
|| { printf "${RED}%10s${NC}\n" "FAILED" && grep -B 1 -i -e warning -e error $@; }
always: ;
finish: always
@echo ""