-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathMakefile
137 lines (121 loc) · 4.44 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
all: check_latest ci-deps test
TARGETDIR:=$(HOME)/toolchain
SOURCEDIR:=$(HOME)/src
test:
grep . $(TARGETDIR)/*.ver
$(MAKE) -s -C verilog test
$(MAKE) -C verilog/test BOARD=alhambra hwbin
$(MAKE) -C verilog/test BOARD=ice40hx8k hwbin
clean:
$(MAKE) -C verilog/test clean
$(MAKE) -C verilog clean
$(MAKE) -C gui clean
$(MAKE) -C verilog/test BOARD=alhambra clean
$(MAKE) -C verilog/test BOARD=alhambra hwclean
$(MAKE) -C verilog/test BOARD=ice40hx8k clean
$(MAKE) -C verilog/test BOARD=ice40hx8k hwclean
rm -rf verilog/builddir
GIT_ICEST:=https://github.com/cliffordwolf/icestorm.git
GIT_YOSYS:=https://github.com/cliffordwolf/yosys.git
GIT_ARACH:=https://github.com/cseed/arachne-pnr.git
GIT_SYMBI:=https://github.com/cliffordwolf/SymbiYosys.git
GIT_YICES:=https://github.com/SRI-CSL/yices2.git
GIT_VLTOR:=https://github.com/verilator/verilator.git
GIT_IVRLG:=https://github.com/steveicarus/iverilog
VER_ICEST:=$(TARGETDIR)/icestorm.ver
VER_YOSYS:=$(TARGETDIR)/yosys.ver
VER_ARACH:=$(TARGETDIR)/arachne-pnr.ver
VER_SYMBI:=$(TARGETDIR)/symbiyosys.ver
VER_YICES:=$(TARGETDIR)/yices2.ver
VER_VLTOR:=$(TARGETDIR)/verilator.ver
VER_IVRLG:=$(TARGETDIR)/iverilog.ver
check_latest:
[ -e $(VER_ICEST) ] && ( git ls-remote --heads $(GIT_ICEST) refs/heads/master | cut -f1 | cmp $(VER_ICEST) - || rm -f $(VER_ICEST) ) || true
[ -e $(VER_SYMBI) ] && ( git ls-remote --heads $(GIT_SYMBI) refs/heads/master | cut -f1 | cmp $(VER_SYMBI) - || rm -f $(VER_SYMBI) ) || true
[ -e $(VER_YICES) ] && ( git ls-remote --heads $(GIT_YICES) refs/heads/master | cut -f1 | cmp $(VER_YICES) - || rm -f $(VER_YICES) ) || true
[ -e $(VER_VLTOR) ] && ( git ls-remote --heads $(GIT_VLTOR) refs/heads/stable | cut -f1 | cmp $(VER_VLTOR) - || rm -f $(VER_VLTOR) ) || true
[ -e $(VER_IVRLG) ] && ( git ls-remote --heads $(GIT_IVRLG) refs/heads/master | cut -f1 | cmp $(VER_IVRLG) - || rm -f $(VER_IVRLG) ) || true
ifneq ($(ARACHNEPNR),)
[ -e $(VER_ARACH) ] && ( git ls-remote --heads $(GIT_ARACH) refs/heads/master | cut -f1 | cmp $(VER_ARACH) - || rm -f $(VER_ARACH) ) || true
endif
ifeq ($(DOCKER_YOSYS),)
[ -e $(VER_YOSYS) ] && ( git ls-remote --heads $(GIT_YOSYS) refs/heads/master | cut -f1 | cmp $(VER_YOSYS) - || rm -f $(VER_YOSYS) ) || true
endif
ci-deps: $(VER_ICEST) $(VER_SYMBI) $(VER_YICES) $(VER_VLTOR) $(VER_IVRLG)
ifneq ($(ARACHNEPNR),)
ci-deps: $(VER_ARACH)
endif
ifeq ($(DOCKER_YOSYS),)
ci-deps: $(VER_YOSYS)
endif
ifndef TRAVIS
NPROC:= -j$(shell nproc)
endif
$(VER_ICEST):
mkdir -p $(SOURCEDIR); cd $(SOURCEDIR) && \
( [ -e icestorm ] || git clone $(GIT_ICEST) ) && \
cd icestorm && \
git pull && \
git log -1 && \
nice make $(NPROC) DESTDIR=$(TARGETDIR) PREFIX= install && \
git rev-parse HEAD > $(VER_ICEST)
$(VER_YOSYS):
mkdir -p $(SOURCEDIR); cd $(SOURCEDIR) && \
( [ -e yosys ] || git clone $(GIT_YOSYS) ) && \
cd yosys && \
git pull && \
git log -1 && \
nice make $(NPROC) PREFIX=$(TARGETDIR) install && \
git rev-parse HEAD > $(VER_YOSYS)
$(VER_ARACH):
mkdir -p $(SOURCEDIR); cd $(SOURCEDIR) && \
( [ -e arachne-pnr ] || git clone $(GIT_ARACH) ) && \
cd arachne-pnr && \
git pull && \
git log -1 && \
nice make $(NPROC) PREFIX=$(TARGETDIR) install && \
git rev-parse HEAD > $(VER_ARACH)
$(VER_SYMBI):
mkdir -p $(SOURCEDIR); cd $(SOURCEDIR) && \
( [ -e SymbiYosys ] || git clone $(GIT_SYMBI) ) && \
cd SymbiYosys && \
git pull && \
git log -1 && \
nice make PREFIX=$(TARGETDIR) install && \
git rev-parse HEAD > $(VER_SYMBI)
$(VER_YICES):
mkdir -p $(SOURCEDIR); cd $(SOURCEDIR) && \
( [ -e yices2 ] || git clone $(GIT_YICES) ) && \
cd yices2 && \
git pull && \
git log -1 && \
autoconf && \
./configure --prefix=$(TARGETDIR) && \
nice make $(NPROC) && \
make $(NPROC) install && \
git rev-parse HEAD > $(VER_YICES)
$(VER_VLTOR):
mkdir -p $(SOURCEDIR); cd $(SOURCEDIR) && \
( [ -e verilator ] || git clone $(GIT_VLTOR) ) && \
cd verilator && \
git pull && \
git checkout stable && \
git log -1 && \
unset VERILATOR_ROOT && \
autoconf && \
./configure --prefix=$(TARGETDIR) >/dev/null && \
nice make $(NPROC) && \
make install && \
git rev-parse HEAD > $(VER_VLTOR)
$(VER_IVRLG):
mkdir -p $(SOURCEDIR); cd $(SOURCEDIR) && \
( [ -e iverilog ] || git clone $(GIT_IVRLG) ) && \
cd iverilog && \
git pull && \
git log -1 && \
sh autoconf.sh && \
./configure --prefix=$(TARGETDIR) >/dev/null && \
nice make $(NPROC) && \
make install && \
git rev-parse HEAD > $(VER_IVRLG)
.PHONY: test clean ci-deps check_latest