-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMakefile
72 lines (53 loc) · 2.11 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
SOURCES := $(shell find . -name '*.v' -not -name '*_tb.v')
TB_SOURCES := $(shell find . -name '*_tb.v')
TB_VVP_FILES := $(TB_SOURCES:%.v=%.vvp)
TB_VVP_FILES_RES := $(TB_SOURCES:%.v=%.vvp.result)
TB_VCD_FILES := $(shell find . -name '*.vcd')
PWD := $(shell pwd)
RED := \033[31m
GREEN := \033[32m
ORANGE := \033[38;5;208m
RESET := \033[0m
DOCKER=docker
DOCKERARGS=run --rm -v $(PWD):/src -w /src
DEVICE_GOWINPACK=GW1N-9C
DEVICE_NEXTPNR=GW1NR-LV9QN88PC6/I5
FAMILY_NEXTPNR=GW1N-9C
CONSTRAINTS=tangnano9k.cst
MACRO_YOSYS = -D LEDS_NR=6 -D OSC_TYPE_OSC
IVERILOGARGS = -D LEDS_NR=6
YOSYS = $(DOCKER) $(DOCKERARGS) hdlc/yosys yosys
NEXTPNR = $(DOCKER) $(DOCKERARGS) alfredosavi/nextpnr-gowin nextpnr-gowin
GOWINPACK = $(DOCKER) $(DOCKERARGS) alfredosavi/nextpnr-gowin gowin_pack
IVERILOG = $(DOCKER) $(DOCKERARGS) alfredosavi/icarus iverilog
VVP = $(DOCKER) $(DOCKERARGS) alfredosavi/icarus vvp
all: top.fs
%.vvp.result: %.vvp
@echo "${ORANGE}Simulating $(@:%.vvp.result=%.vvp) -> $@${RESET}"
@$(VVP) $(@:%.vvp.result=%.vvp) | tee $@
@!(cat $@ | grep -q -E 'ERROR|Error|Err') || (echo "${RED}Test $@ failed $$?${RESET}"; exit 1)
%.vvp: %.v
@echo "${ORANGE}Compiling $< to $@${RESET}"
$(IVERILOG) -o $@ $< $(filter-out ./top.v, $(SOURCES)) $(IVERILOGARGS)
test: $(TB_VVP_FILES) $(TB_VVP_FILES_RES)
@echo "Tests completed!"
top.fs: top.pack
$(GOWINPACK) -d $(DEVICE_GOWINPACK) -o $@ $^
top.pack: top.json
$(NEXTPNR) --json $^ --write $@ --device $(DEVICE_NEXTPNR) --family $(FAMILY_NEXTPNR) --cst $(CONSTRAINTS)
top.json:
$(YOSYS) $(MACRO_YOSYS) -p "synth_gowin -json top.json -top top" $(SOURCES)
prog: top.fs
@echo "${ORANGE}Programming FPGA with top.fs using openFPGALoader${RESET}"
openFPGALoader -b tangnano $^
flash: top.fs
@echo "${ORANGE}Flashing FPGA with top.fs using openFPGALoader${RESET}"
openFPGALoader -b tangnano -f $^
reset:
@echo "${ORANGE}Resetting FPGA using openFPGALoader${RESET}"
openFPGALoader --reset
clean:
@echo "Cleaning up temporary and compilation files"
rm -f *.json *.fs *.pack $(TB_VVP_FILES) $(TB_VVP_FILES_RES) $(TB_VCD_FILES)
.PHONY: clean prog
.PRECIOUS: top.json